1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
|
m = Element.prototype.matches or
Element.prototype.matchesSelector or
Element.prototype.mozMatchesSelector or
Element.prototype.msMatchesSelector or
Element.prototype.oMatchesSelector or
Element.prototype.webkitMatchesSelector
# Checks if the given native dom element matches the selector
# element::
# native DOM element
# selector::
# css selector string or
# a javascript object with `selector` and `exclude` properties
# Examples: "form", { selector: "form", exclude: "form[data-remote='true']"}
Rails.matches = (element, selector) ->
if selector.exclude?
m.call(element, selector.selector) and not m.call(element, selector.exclude)
else
m.call(element, selector)
# get and set data on a given element using "expando properties"
# See: https://developer.mozilla.org/en-US/docs/Glossary/Expando
expando = '_ujsData'
Rails.getData = (element, key) ->
element[expando]?[key]
Rails.setData = (element, key, value) ->
element[expando] ?= {}
element[expando][key] = value
Rails.isContentEditable = (element) ->
isEditable = false
loop
if(element.isContentEditable)
isEditable = true
break
element = element.parentElement
break unless(element)
return isEditable
# a wrapper for document.querySelectorAll
# returns an Array
Rails.$ = (selector) ->
Array.prototype.slice.call(document.querySelectorAll(selector))
|