2017-08-21 09:11:37 +02:00
|
|
|
/**
|
|
|
|
* --------------------------------------------------------------------------
|
|
|
|
* Bootstrap (v4.0.0-beta): dom/selectorEngine.js
|
|
|
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
|
|
* --------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
2017-08-21 16:45:29 +02:00
|
|
|
// matches polyfill (see: https://mzl.la/2ikXneG)
|
|
|
|
let fnMatches = null
|
|
|
|
if (!Element.prototype.matches) {
|
|
|
|
fnMatches =
|
|
|
|
Element.prototype.msMatchesSelector ||
|
|
|
|
Element.prototype.webkitMatchesSelector
|
|
|
|
} else {
|
|
|
|
fnMatches = Element.prototype.matches
|
|
|
|
}
|
|
|
|
|
|
|
|
// closest polyfill (see: https://mzl.la/2vXggaI)
|
2017-08-23 16:28:01 +02:00
|
|
|
let fnClosest = null
|
2017-08-21 16:45:29 +02:00
|
|
|
if (!Element.prototype.closest) {
|
2017-08-23 16:28:01 +02:00
|
|
|
fnClosest = (element, selector) => {
|
2017-08-21 16:45:29 +02:00
|
|
|
let ancestor = element
|
|
|
|
if (!document.documentElement.contains(element)) {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
|
|
|
|
do {
|
|
|
|
if (fnMatches.call(ancestor, selector)) {
|
|
|
|
return ancestor
|
|
|
|
}
|
|
|
|
|
|
|
|
ancestor = ancestor.parentElement
|
|
|
|
} while (ancestor !== null)
|
|
|
|
|
|
|
|
return null
|
|
|
|
}
|
2017-08-23 16:28:01 +02:00
|
|
|
} else {
|
|
|
|
// eslint-disable-next-line arrow-body-style
|
|
|
|
fnClosest = (element, selector) => {
|
|
|
|
return element.closest(selector)
|
|
|
|
}
|
2017-08-21 16:45:29 +02:00
|
|
|
}
|
|
|
|
|
2017-08-21 09:11:37 +02:00
|
|
|
const SelectorEngine = {
|
2017-08-21 16:45:29 +02:00
|
|
|
matches(element, selector) {
|
|
|
|
return fnMatches.call(element, selector)
|
|
|
|
},
|
2017-08-21 09:11:37 +02:00
|
|
|
|
2017-08-23 17:43:04 +03:00
|
|
|
find(element = document, selector) {
|
2017-08-21 09:11:37 +02:00
|
|
|
if (typeof selector !== 'string') {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
|
|
|
|
let selectorType = 'querySelectorAll'
|
|
|
|
if (selector.indexOf('#') === 0) {
|
|
|
|
selectorType = 'getElementById'
|
|
|
|
selector = selector.substr(1, selector.length)
|
|
|
|
}
|
2017-08-23 17:43:04 +03:00
|
|
|
return element[selectorType](selector)
|
2017-08-21 09:11:37 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
closest(element, selector) {
|
2017-08-23 16:28:01 +02:00
|
|
|
return fnClosest(element, selector)
|
2017-08-21 09:11:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default SelectorEngine
|