From 3ea3c6921fe27257dc35820060ea9b8adcce5832 Mon Sep 17 00:00:00 2001 From: Derek Date: Mon, 25 Apr 2022 14:18:00 -0500 Subject: [PATCH] fix: wrap document.querySelectorAll in try/catch. replace escapeValue with CSS.escape ala cssesc --- dist/optimal-select.js | 639 ++++++++++++++++++++------------- dist/optimal-select.min.js | 2 +- dist/optimal-select.min.js.map | 2 +- package.json | 1 + src/optimize.js | 69 +++- src/utilities.js | 5 +- 6 files changed, 451 insertions(+), 267 deletions(-) diff --git a/dist/optimal-select.js b/dist/optimal-select.js index 7bfc617..a42296b 100644 --- a/dist/optimal-select.js +++ b/dist/optimal-select.js @@ -16,9 +16,9 @@ return /******/ (function(modules) { // webpackBootstrap /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache -/******/ if(installedModules[moduleId]) +/******/ if(installedModules[moduleId]) { /******/ return installedModules[moduleId].exports; -/******/ +/******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ i: moduleId, @@ -78,7 +78,7 @@ return /******/ (function(modules) { // webpackBootstrap /************************************************************************/ /******/ ([ /* 0 */ -/***/ function(module, exports, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -94,6 +94,8 @@ exports.escapeValue = escapeValue; * Convenience helpers. */ +var cssesc = __webpack_require__(5); + /** * Create an array with the DOM nodes of the list * @@ -119,12 +121,12 @@ function convertNodeList(nodes) { * @return {String} - [description] */ function escapeValue(value) { - return value && value.replace(/['"`\\/:\?&!#$%^()[\]{|}*+;,.<=>@~]/g, '\\$&').replace(/\n/g, '\A'); + return value && cssesc(value); } -/***/ }, +/***/ }), /* 1 */ -/***/ function(module, exports, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -243,43 +245,41 @@ function getCommonProperties(elements) { // ~ attributes if (commonAttributes !== undefined) { - (function () { - var elementAttributes = element.attributes; - var attributes = Object.keys(elementAttributes).reduce(function (attributes, key) { - var attribute = elementAttributes[key]; - var attributeName = attribute.name; - // NOTE: workaround detection for non-standard phantomjs NamedNodeMap behaviour - // (issue: https://github.com/ariya/phantomjs/issues/14634) - if (attribute && attributeName !== 'class') { - attributes[attributeName] = attribute.value; - } - return attributes; - }, {}); + var elementAttributes = element.attributes; + var attributes = Object.keys(elementAttributes).reduce(function (attributes, key) { + var attribute = elementAttributes[key]; + var attributeName = attribute.name; + // NOTE: workaround detection for non-standard phantomjs NamedNodeMap behaviour + // (issue: https://github.com/ariya/phantomjs/issues/14634) + if (attribute && attributeName !== 'class') { + attributes[attributeName] = attribute.value; + } + return attributes; + }, {}); - var attributesNames = Object.keys(attributes); - var commonAttributesNames = Object.keys(commonAttributes); + var attributesNames = Object.keys(attributes); + var commonAttributesNames = Object.keys(commonAttributes); - if (attributesNames.length) { - if (!commonAttributesNames.length) { - commonProperties.attributes = attributes; - } else { - commonAttributes = commonAttributesNames.reduce(function (nextCommonAttributes, name) { - var value = commonAttributes[name]; - if (value === attributes[name]) { - nextCommonAttributes[name] = value; - } - return nextCommonAttributes; - }, {}); - if (Object.keys(commonAttributes).length) { - commonProperties.attributes = commonAttributes; - } else { - delete commonProperties.attributes; + if (attributesNames.length) { + if (!commonAttributesNames.length) { + commonProperties.attributes = attributes; + } else { + commonAttributes = commonAttributesNames.reduce(function (nextCommonAttributes, name) { + var value = commonAttributes[name]; + if (value === attributes[name]) { + nextCommonAttributes[name] = value; } + return nextCommonAttributes; + }, {}); + if (Object.keys(commonAttributes).length) { + commonProperties.attributes = commonAttributes; + } else { + delete commonProperties.attributes; } - } else { - delete commonProperties.attributes; } - })(); + } else { + delete commonProperties.attributes; + } } // ~ tag @@ -296,9 +296,9 @@ function getCommonProperties(elements) { return commonProperties; } -/***/ }, +/***/ }), /* 2 */ -/***/ function(module, exports, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -362,7 +362,12 @@ function optimize(selector, elements) { var postPart = shortened.join(' '); var pattern = prePart + ' ' + postPart; - var matches = document.querySelectorAll(pattern); + var matches = []; + try { + matches = document.querySelectorAll(pattern); + } catch (err) { + // + } if (matches.length !== elements.length) { shortened.unshift(optimizePart(prePart, current, postPart, elements)); } @@ -398,12 +403,22 @@ function optimizePart(prePart, current, postPart, elements) { if (/\[*\]/.test(current)) { var key = current.replace(/=.*$/, ']'); var pattern = '' + prePart + key + postPart; - var matches = document.querySelectorAll(pattern); + var matches = []; + try { + matches = document.querySelectorAll(pattern); + } catch (err) { + // + } if (compareResults(matches, elements)) { current = key; } else { // robustness: replace specific key-value with base tag (heuristic) - var references = document.querySelectorAll('' + prePart + key); + var references = []; + try { + references = document.querySelectorAll('' + prePart + key); + } catch (err) { + // + } var _loop = function _loop() { var reference = references[i]; @@ -412,9 +427,14 @@ function optimizePart(prePart, current, postPart, elements) { })) { var description = reference.tagName.toLowerCase(); pattern = '' + prePart + description + postPart; - matches = document.querySelectorAll(pattern); - if (compareResults(matches, elements)) { + var _matches = []; + try { + _matches = document.querySelectorAll(pattern); + } catch (err) { + // + } + if (compareResults(_matches, elements)) { current = description; } return 'break'; @@ -423,7 +443,6 @@ function optimizePart(prePart, current, postPart, elements) { for (var i = 0, l = references.length; i < l; i++) { var pattern; - var matches; var _ret = _loop(); @@ -436,8 +455,13 @@ function optimizePart(prePart, current, postPart, elements) { if (/>/.test(current)) { var descendant = current.replace(/>/, ''); var pattern = '' + prePart + descendant + postPart; - var matches = document.querySelectorAll(pattern); - if (compareResults(matches, elements)) { + var _matches2 = []; + try { + _matches2 = document.querySelectorAll(pattern); + } catch (err) { + // + } + if (compareResults(_matches2, elements)) { current = descendant; } } @@ -447,8 +471,13 @@ function optimizePart(prePart, current, postPart, elements) { // TODO: consider complete coverage of 'nth-of-type' replacement var type = current.replace(/nth-child/g, 'nth-of-type'); var pattern = '' + prePart + type + postPart; - var matches = document.querySelectorAll(pattern); - if (compareResults(matches, elements)) { + var _matches3 = []; + try { + _matches3 = document.querySelectorAll(pattern); + } catch (err) { + // + } + if (compareResults(_matches3, elements)) { current = type; } } @@ -462,12 +491,21 @@ function optimizePart(prePart, current, postPart, elements) { }); while (names.length) { var partial = current.replace(names.shift(), '').trim(); + if (partial.charAt(0) === '>' || partial.charAt(partial.length - 1) === '>') { + break; + } var pattern = ('' + prePart + partial + postPart).trim(); if (!pattern.length || pattern.charAt(0) === '>' || pattern.charAt(pattern.length - 1) === '>') { break; } - var matches = document.querySelectorAll(pattern); - if (compareResults(matches, elements)) { + var _matches4 = []; + + try { + _matches4 = document.querySelectorAll(pattern); + } catch (err) { + // + } + if (compareResults(_matches4, elements)) { current = partial; } } @@ -475,7 +513,12 @@ function optimizePart(prePart, current, postPart, elements) { // robustness: degrade complex classname (heuristic) names = current && current.match(/\./g); if (names && names.length > 2) { - var _references = document.querySelectorAll('' + prePart + current); + var _references = []; + try { + _references = document.querySelectorAll('' + prePart + current); + } catch (err) { + // + } var _loop2 = function _loop2() { var reference = _references[i]; @@ -486,9 +529,14 @@ function optimizePart(prePart, current, postPart, elements) { // - check using attributes + regard excludes var description = reference.tagName.toLowerCase(); pattern = '' + prePart + description + postPart; - matches = document.querySelectorAll(pattern); - if (compareResults(matches, elements)) { + var _matches5 = []; + try { + _matches5 = document.querySelectorAll(pattern); + } catch (err) { + // + } + if (compareResults(_matches5, elements)) { current = description; } return 'break'; @@ -497,7 +545,6 @@ function optimizePart(prePart, current, postPart, elements) { for (var i = 0, l = _references.length; i < l; i++) { var pattern; - var matches; var _ret2 = _loop2(); @@ -530,9 +577,9 @@ function compareResults(matches, elements) { } module.exports = exports['default']; -/***/ }, +/***/ }), /* 3 */ -/***/ function(module, exports, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -541,8 +588,6 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; - var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); exports.default = adapt; @@ -719,147 +764,121 @@ function getInstructions(selectors) { var validate = null; var instruction = null; - (function () { - switch (true) { + switch (true) { - // child: '>' - case />/.test(type): - instruction = function checkParent(node) { - return function (validate) { - return validate(node.parent) && node.parent; - }; - }; - break; - - // class: '.' - case /^\./.test(type): - var names = type.substr(1).split('.'); - validate = function validate(node) { - var nodeClassName = node.attribs.class; - return nodeClassName && names.every(function (name) { - return nodeClassName.indexOf(name) > -1; - }); + // child: '>' + case />/.test(type): + instruction = function checkParent(node) { + return function (validate) { + return validate(node.parent) && node.parent; }; - instruction = function checkClass(node, root) { - if (discover) { - return node.getElementsByClassName(names.join(' ')); + }; + break; + + // class: '.' + case /^\./.test(type): + var names = type.substr(1).split('.'); + validate = function validate(node) { + var nodeClassName = node.attribs.class; + return nodeClassName && names.every(function (name) { + return nodeClassName.indexOf(name) > -1; + }); + }; + instruction = function checkClass(node, root) { + if (discover) { + return node.getElementsByClassName(names.join(' ')); + } + return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); + }; + break; + + // attribute: '[key="value"]' + case /^\[/.test(type): + var _type$replace$split = type.replace(/\[|\]|"/g, '').split('='), + _type$replace$split2 = _slicedToArray(_type$replace$split, 2), + attributeKey = _type$replace$split2[0], + attributeValue = _type$replace$split2[1]; + + validate = function validate(node) { + var hasAttribute = Object.keys(node.attribs).indexOf(attributeKey) > -1; + if (hasAttribute) { + // regard optional attributeValue + if (!attributeValue || node.attribs[attributeKey] === attributeValue) { + return true; } - return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); - }; - break; - - // attribute: '[key="value"]' - case /^\[/.test(type): - var _type$replace$split = type.replace(/\[|\]|"/g, '').split('='), - _type$replace$split2 = _slicedToArray(_type$replace$split, 2), - attributeKey = _type$replace$split2[0], - attributeValue = _type$replace$split2[1]; - - validate = function validate(node) { - var hasAttribute = Object.keys(node.attribs).indexOf(attributeKey) > -1; - if (hasAttribute) { - // regard optional attributeValue - if (!attributeValue || node.attribs[attributeKey] === attributeValue) { - return true; + } + return false; + }; + instruction = function checkAttribute(node, root) { + if (discover) { + var NodeList = []; + traverseDescendants([node], function (descendant) { + if (validate(descendant)) { + NodeList.push(descendant); } - } - return false; - }; - instruction = function checkAttribute(node, root) { - if (discover) { - var _ret2 = function () { - var NodeList = []; - traverseDescendants([node], function (descendant) { - if (validate(descendant)) { - NodeList.push(descendant); - } - }); - return { - v: NodeList - }; - }(); - - if ((typeof _ret2 === 'undefined' ? 'undefined' : _typeof(_ret2)) === "object") return _ret2.v; - } - return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); - }; - break; + }); + return NodeList; + } + return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); + }; + break; - // id: '#' - case /^#/.test(type): - var id = type.substr(1); - validate = function validate(node) { - return node.attribs.id === id; - }; - instruction = function checkId(node, root) { - if (discover) { - var _ret3 = function () { - var NodeList = []; - traverseDescendants([node], function (descendant, done) { - if (validate(descendant)) { - NodeList.push(descendant); - done(); - } - }); - return { - v: NodeList - }; - }(); - - if ((typeof _ret3 === 'undefined' ? 'undefined' : _typeof(_ret3)) === "object") return _ret3.v; - } - return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); - }; - break; + // id: '#' + case /^#/.test(type): + var id = type.substr(1); + validate = function validate(node) { + return node.attribs.id === id; + }; + instruction = function checkId(node, root) { + if (discover) { + var NodeList = []; + traverseDescendants([node], function (descendant, done) { + if (validate(descendant)) { + NodeList.push(descendant); + done(); + } + }); + return NodeList; + } + return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); + }; + break; - // universal: '*' - case /\*/.test(type): - validate = function validate(node) { - return true; - }; - instruction = function checkUniversal(node, root) { - if (discover) { - var _ret4 = function () { - var NodeList = []; - traverseDescendants([node], function (descendant) { - return NodeList.push(descendant); - }); - return { - v: NodeList - }; - }(); - - if ((typeof _ret4 === 'undefined' ? 'undefined' : _typeof(_ret4)) === "object") return _ret4.v; - } - return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); - }; - break; + // universal: '*' + case /\*/.test(type): + validate = function validate(node) { + return true; + }; + instruction = function checkUniversal(node, root) { + if (discover) { + var NodeList = []; + traverseDescendants([node], function (descendant) { + return NodeList.push(descendant); + }); + return NodeList; + } + return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); + }; + break; - // tag: '...' - default: - validate = function validate(node) { - return node.name === type; - }; - instruction = function checkTag(node, root) { - if (discover) { - var _ret5 = function () { - var NodeList = []; - traverseDescendants([node], function (descendant) { - if (validate(descendant)) { - NodeList.push(descendant); - } - }); - return { - v: NodeList - }; - }(); - - if ((typeof _ret5 === 'undefined' ? 'undefined' : _typeof(_ret5)) === "object") return _ret5.v; - } - return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); - }; - } - })(); + // tag: '...' + default: + validate = function validate(node) { + return node.name === type; + }; + instruction = function checkTag(node, root) { + if (discover) { + var NodeList = []; + traverseDescendants([node], function (descendant) { + if (validate(descendant)) { + NodeList.push(descendant); + } + }); + return NodeList; + } + return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate); + }; + } if (!pseudo) { return instruction; @@ -940,9 +959,9 @@ function getAncestor(node, root, validate) { } module.exports = exports['default']; -/***/ }, +/***/ }), /* 4 */ -/***/ function(module, exports, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -966,7 +985,7 @@ var _adapt = __webpack_require__(3); var _adapt2 = _interopRequireDefault(_adapt); -var _match = __webpack_require__(5); +var _match = __webpack_require__(7); var _match2 = _interopRequireDefault(_match); @@ -1124,9 +1143,171 @@ function getQuerySelector(input) { return getSingleSelector(input, options); } -/***/ }, +/***/ }), /* 5 */ -/***/ function(module, exports, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/*! https://mths.be/cssesc v3.0.0 by @mathias */ + + +var object = {}; +var hasOwnProperty = object.hasOwnProperty; +var merge = function merge(options, defaults) { + if (!options) { + return defaults; + } + var result = {}; + for (var key in defaults) { + // `if (defaults.hasOwnProperty(key) { … }` is not needed here, since + // only recognized option names are used. + result[key] = hasOwnProperty.call(options, key) ? options[key] : defaults[key]; + } + return result; +}; + +var regexAnySingleEscape = /[ -,\.\/:-@\[-\^`\{-~]/; +var regexSingleEscape = /[ -,\.\/:-@\[\]\^`\{-~]/; +var regexAlwaysEscape = /['"\\]/; +var regexExcessiveSpaces = /(^|\\+)?(\\[A-F0-9]{1,6})\x20(?![a-fA-F0-9\x20])/g; + +// https://mathiasbynens.be/notes/css-escapes#css +var cssesc = function cssesc(string, options) { + options = merge(options, cssesc.options); + if (options.quotes != 'single' && options.quotes != 'double') { + options.quotes = 'single'; + } + var quote = options.quotes == 'double' ? '"' : '\''; + var isIdentifier = options.isIdentifier; + + var firstChar = string.charAt(0); + var output = ''; + var counter = 0; + var length = string.length; + while (counter < length) { + var character = string.charAt(counter++); + var codePoint = character.charCodeAt(); + var value = void 0; + // If it’s not a printable ASCII character… + if (codePoint < 0x20 || codePoint > 0x7E) { + if (codePoint >= 0xD800 && codePoint <= 0xDBFF && counter < length) { + // It’s a high surrogate, and there is a next character. + var extra = string.charCodeAt(counter++); + if ((extra & 0xFC00) == 0xDC00) { + // next character is low surrogate + codePoint = ((codePoint & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000; + } else { + // It’s an unmatched surrogate; only append this code unit, in case + // the next code unit is the high surrogate of a surrogate pair. + counter--; + } + } + value = '\\' + codePoint.toString(16).toUpperCase() + ' '; + } else { + if (options.escapeEverything) { + if (regexAnySingleEscape.test(character)) { + value = '\\' + character; + } else { + value = '\\' + codePoint.toString(16).toUpperCase() + ' '; + } + } else if (/[\t\n\f\r\x0B]/.test(character)) { + value = '\\' + codePoint.toString(16).toUpperCase() + ' '; + } else if (character == '\\' || !isIdentifier && (character == '"' && quote == character || character == '\'' && quote == character) || isIdentifier && regexSingleEscape.test(character)) { + value = '\\' + character; + } else { + value = character; + } + } + output += value; + } + + if (isIdentifier) { + if (/^-[-\d]/.test(output)) { + output = '\\-' + output.slice(1); + } else if (/\d/.test(firstChar)) { + output = '\\3' + firstChar + ' ' + output.slice(1); + } + } + + // Remove spaces after `\HEX` escapes that are not followed by a hex digit, + // since they’re redundant. Note that this is only possible if the escape + // sequence isn’t preceded by an odd number of backslashes. + output = output.replace(regexExcessiveSpaces, function ($0, $1, $2) { + if ($1 && $1.length % 2) { + // It’s not safe to remove the space, so don’t. + return $0; + } + // Strip the space. + return ($1 || '') + $2; + }); + + if (!isIdentifier && options.wrap) { + return quote + output + quote; + } + return output; +}; + +// Expose default options (so they can be overridden globally). +cssesc.options = { + 'escapeEverything': false, + 'isIdentifier': false, + 'quotes': 'single', + 'wrap': false +}; + +cssesc.version = '3.0.0'; + +module.exports = cssesc; + +/***/ }), +/* 6 */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = exports.common = exports.optimize = exports.getMultiSelector = exports.getSingleSelector = exports.select = undefined; + +var _select2 = __webpack_require__(4); + +Object.defineProperty(exports, 'getSingleSelector', { + enumerable: true, + get: function get() { + return _select2.getSingleSelector; + } +}); +Object.defineProperty(exports, 'getMultiSelector', { + enumerable: true, + get: function get() { + return _select2.getMultiSelector; + } +}); + +var _select3 = _interopRequireDefault(_select2); + +var _optimize2 = __webpack_require__(2); + +var _optimize3 = _interopRequireDefault(_optimize2); + +var _common2 = __webpack_require__(1); + +var _common = _interopRequireWildcard(_common2); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +exports.select = _select3.default; +exports.optimize = _optimize3.default; +exports.common = _common; +exports.default = _select3.default; + +/***/ }), +/* 7 */ +/***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -1210,12 +1391,10 @@ function match(node, options) { }); if (ignoreClass) { - (function () { - var ignoreAttribute = ignore.attribute; - ignore.attribute = function (name, value, defaultPredicate) { - return ignore.class(value) || ignoreAttribute && ignoreAttribute(name, value, defaultPredicate); - }; - })(); + var ignoreAttribute = ignore.attribute; + ignore.attribute = function (name, value, defaultPredicate) { + return ignore.class(value) || ignoreAttribute && ignoreAttribute(name, value, defaultPredicate); + }; } while (element !== root) { @@ -1429,53 +1608,7 @@ function checkIgnore(predicate, name, value, defaultPredicate) { } module.exports = exports['default']; -/***/ }, -/* 6 */ -/***/ function(module, exports, __webpack_require__) { - -"use strict"; - - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.default = exports.common = exports.optimize = exports.getMultiSelector = exports.getSingleSelector = exports.select = undefined; - -var _select2 = __webpack_require__(4); - -Object.defineProperty(exports, 'getSingleSelector', { - enumerable: true, - get: function get() { - return _select2.getSingleSelector; - } -}); -Object.defineProperty(exports, 'getMultiSelector', { - enumerable: true, - get: function get() { - return _select2.getMultiSelector; - } -}); - -var _select3 = _interopRequireDefault(_select2); - -var _optimize2 = __webpack_require__(2); - -var _optimize3 = _interopRequireDefault(_optimize2); - -var _common2 = __webpack_require__(1); - -var _common = _interopRequireWildcard(_common2); - -function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } - -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - -exports.select = _select3.default; -exports.optimize = _optimize3.default; -exports.common = _common; -exports.default = _select3.default; - -/***/ } +/***/ }) /******/ ]); }); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 93ed707cbeffca933269","webpack:///./src/utilities.js","webpack:///./src/common.js","webpack:///./src/optimize.js","webpack:///./src/adapt.js","webpack:///./src/select.js","webpack:///./src/match.js","webpack:///./src/index.js"],"names":["convertNodeList","escapeValue","nodes","length","arr","Array","i","value","replace","getCommonAncestor","getCommonProperties","elements","options","root","document","ancestors","forEach","element","index","parents","parentNode","unshift","sort","curr","next","shallowAncestor","shift","ancestor","parent","missing","some","otherParents","otherParent","l","commonProperties","classes","attributes","tag","commonClasses","commonAttributes","commonTag","undefined","getAttribute","trim","split","filter","entry","name","elementAttributes","Object","keys","reduce","key","attribute","attributeName","attributesNames","commonAttributesNames","nextCommonAttributes","tagName","toLowerCase","optimize","selector","isArray","nodeType","Error","globalModified","path","optimizePart","shortened","pop","current","prePart","join","postPart","pattern","matches","querySelectorAll","slice","test","compareResults","references","reference","contains","description","descendant","type","names","map","partial","charAt","match","every","adapt","global","context","ElementPrototype","getPrototypeOf","getOwnPropertyDescriptor","defineProperty","enumerable","get","children","node","attribs","NamedNodeMap","configurable","getElementsByTagName","HTMLCollection","traverseDescendants","childTags","push","getElementsByClassName","className","descendantClassName","class","indexOf","selectors","instructions","getInstructions","discover","total","step","inclusive","done","reverse","pseudo","validate","instruction","checkParent","substr","nodeClassName","checkClass","getAncestor","attributeKey","attributeValue","hasAttribute","checkAttribute","NodeList","id","checkId","checkUniversal","checkTag","rule","kind","parseInt","validatePseudo","compareSet","nodeIndex","findIndex","child","enhanceInstruction","matchedNode","handler","progress","getSingleSelector","getMultiSelector","getQuerySelector","optimized","ancestorSelector","commonSelectors","getCommonSelectors","descendantSelector","selectorMatches","console","warn","selectorPath","classSelector","attributeSelector","parts","input","defaultIgnore","skip","priority","ignore","ignoreClass","skipCompare","skipChecks","compare","predicate","toString","RegExp","ignoreAttribute","defaultPredicate","checkAttributes","checkChilds","findPattern","findAttributesPattern","sortedKeys","currPos","nextPos","currentIgnore","currentDefaultIgnore","checkIgnore","findTagPattern","childPattern","check","select","common","default"],"mappings":"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","file":"optimal-select.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"OptimalSelect\"] = factory();\n\telse\n\t\troot[\"OptimalSelect\"] = factory();\n})(this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 6);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 93ed707cbeffca933269","/**\n * # Utilities\n *\n * Convenience helpers.\n */\n\n/**\n * Create an array with the DOM nodes of the list\n *\n * @param  {NodeList}             nodes - [description]\n * @return {Array.<HTMLElement>}        - [description]\n */\nexport function convertNodeList (nodes) {\n  const { length } = nodes\n  const arr = new Array(length)\n  for (var i = 0; i < length; i++) {\n    arr[i] = nodes[i]\n  }\n  return arr\n}\n\n/**\n * Escape special characters and line breaks as a simplified version of 'CSS.escape()'\n *\n * Description of valid characters: https://mathiasbynens.be/notes/css-escapes\n *\n * @param  {String?} value - [description]\n * @return {String}        - [description]\n */\nexport function escapeValue (value) {\n  return value && value.replace(/['\"`\\\\/:\\?&!#$%^()[\\]{|}*+;,.<=>@~]/g, '\\\\$&')\n                       .replace(/\\n/g, '\\A')\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/utilities.js","/**\n * # Common\n *\n * Process collections for similarities.\n */\n\n/**\n * Find the last common ancestor of elements\n *\n * @param  {Array.<HTMLElements>} elements - [description]\n * @return {HTMLElement}                   - [description]\n */\nexport function getCommonAncestor (elements, options = {}) {\n\n  const {\n    root = document\n  } = options\n\n  const ancestors = []\n\n  elements.forEach((element, index) => {\n    const parents = []\n    while (element !== root) {\n      element = element.parentNode\n      parents.unshift(element)\n    }\n    ancestors[index] = parents\n  })\n\n  ancestors.sort((curr, next) => curr.length - next.length)\n\n  const shallowAncestor = ancestors.shift()\n\n  var ancestor = null\n\n  for (var i = 0, l = shallowAncestor.length; i < l; i++) {\n    const parent = shallowAncestor[i]\n    const missing = ancestors.some((otherParents) => {\n      return !otherParents.some((otherParent) => otherParent === parent)\n    })\n\n    if (missing) {\n      // TODO: find similar sub-parents, not the top root, e.g. sharing a class selector\n      break\n    }\n\n    ancestor = parent\n  }\n\n  return ancestor\n}\n\n/**\n * Get a set of common properties of elements\n *\n * @param  {Array.<HTMLElement>} elements - [description]\n * @return {Object}                       - [description]\n */\nexport function getCommonProperties (elements) {\n\n  const commonProperties = {\n    classes: [],\n    attributes: {},\n    tag: null\n  }\n\n  elements.forEach((element) => {\n\n    var {\n      classes: commonClasses,\n      attributes: commonAttributes,\n      tag: commonTag\n    } = commonProperties\n\n    // ~ classes\n    if (commonClasses !== undefined) {\n      var classes = element.getAttribute('class')\n      if (classes) {\n        classes = classes.trim().split(' ')\n        if (!commonClasses.length) {\n          commonProperties.classes = classes\n        } else {\n          commonClasses = commonClasses.filter((entry) => classes.some((name) => name === entry))\n          if (commonClasses.length) {\n            commonProperties.classes = commonClasses\n          } else {\n            delete commonProperties.classes\n          }\n        }\n      } else {\n        // TODO: restructure removal as 2x set / 2x delete, instead of modify always replacing with new collection\n        delete commonProperties.classes\n      }\n    }\n\n    // ~ attributes\n    if (commonAttributes !== undefined) {\n      const elementAttributes = element.attributes\n      const attributes = Object.keys(elementAttributes).reduce((attributes, key) => {\n        const attribute = elementAttributes[key]\n        const attributeName = attribute.name\n        // NOTE: workaround detection for non-standard phantomjs NamedNodeMap behaviour\n        // (issue: https://github.com/ariya/phantomjs/issues/14634)\n        if (attribute && attributeName !== 'class') {\n          attributes[attributeName] = attribute.value\n        }\n        return attributes\n      }, {})\n\n      const attributesNames = Object.keys(attributes)\n      const commonAttributesNames = Object.keys(commonAttributes)\n\n      if (attributesNames.length) {\n        if (!commonAttributesNames.length) {\n          commonProperties.attributes = attributes\n        } else {\n          commonAttributes = commonAttributesNames.reduce((nextCommonAttributes, name) => {\n            const value = commonAttributes[name]\n            if (value === attributes[name]) {\n              nextCommonAttributes[name] = value\n            }\n            return nextCommonAttributes\n          }, {})\n          if (Object.keys(commonAttributes).length) {\n            commonProperties.attributes = commonAttributes\n          } else {\n            delete commonProperties.attributes\n          }\n        }\n      } else {\n        delete commonProperties.attributes\n      }\n    }\n\n    // ~ tag\n    if (commonTag !== undefined) {\n      const tag = element.tagName.toLowerCase()\n      if (!commonTag) {\n        commonProperties.tag = tag\n      } else if (tag !== commonTag) {\n        delete commonProperties.tag\n      }\n    }\n  })\n\n  return commonProperties\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/common.js","/**\n * # Optimize\n *\n * 1.) Improve efficiency through shorter selectors by removing redundancy\n * 2.) Improve robustness through selector transformation\n */\n\nimport adapt from './adapt'\nimport { convertNodeList } from './utilities'\n\n/**\n * Apply different optimization techniques\n *\n * @param  {string}                          selector - [description]\n * @param  {HTMLElement|Array.<HTMLElement>} element  - [description]\n * @param  {Object}                          options  - [description]\n * @return {string}                                   - [description]\n */\nexport default function optimize (selector, elements, options = {}) {\n\n  // convert single entry and NodeList\n  if (!Array.isArray(elements)) {\n    elements = !elements.length ? [elements] : convertNodeList(elements)\n  }\n\n  if (!elements.length || elements.some((element) => element.nodeType !== 1)) {\n    throw new Error(`Invalid input - to compare HTMLElements its necessary to provide a reference of the selected node(s)! (missing \"elements\")`)\n  }\n\n  const globalModified = adapt(elements[0], options)\n\n  // chunk parts outside of quotes (http://stackoverflow.com/a/25663729)\n  var path = selector.replace(/> /g, '>').split(/\\s+(?=(?:(?:[^\"]*\"){2})*[^\"]*$)/)\n\n  if (path.length < 2) {\n    return optimizePart('', selector, '', elements)\n  }\n\n  const shortened = [path.pop()]\n  while (path.length > 1)  {\n    const current = path.pop()\n    const prePart = path.join(' ')\n    const postPart = shortened.join(' ')\n\n    const pattern = `${prePart} ${postPart}`\n    const matches = document.querySelectorAll(pattern)\n    if (matches.length !== elements.length) {\n      shortened.unshift(optimizePart(prePart, current, postPart, elements))\n    }\n  }\n  shortened.unshift(path[0])\n  path = shortened\n\n  // optimize start + end\n  path[0] = optimizePart('', path[0], path.slice(1).join(' '), elements)\n  path[path.length-1] = optimizePart(path.slice(0, -1).join(' '), path[path.length-1], '', elements)\n\n  if (globalModified) {\n    delete global.document\n  }\n\n  return path.join(' ').replace(/>/g, '> ').trim()\n}\n\n/**\n * Improve a chunk of the selector\n *\n * @param  {string}              prePart  - [description]\n * @param  {string}              current  - [description]\n * @param  {string}              postPart - [description]\n * @param  {Array.<HTMLElement>} elements - [description]\n * @return {string}                       - [description]\n */\nfunction optimizePart (prePart, current, postPart, elements) {\n  if (prePart.length) prePart = `${prePart} `\n  if (postPart.length) postPart = ` ${postPart}`\n\n  // robustness: attribute without value (generalization)\n  if (/\\[*\\]/.test(current)) {\n    const key = current.replace(/=.*$/, ']')\n    var pattern = `${prePart}${key}${postPart}`\n    var matches = document.querySelectorAll(pattern)\n    if (compareResults(matches, elements)) {\n      current = key\n    } else {\n      // robustness: replace specific key-value with base tag (heuristic)\n      const references = document.querySelectorAll(`${prePart}${key}`)\n      for (var i = 0, l = references.length; i < l; i++) {\n        const reference = references[i]\n        if (elements.some((element) => reference.contains(element))) {\n          const description = reference.tagName.toLowerCase()\n          var pattern = `${prePart}${description}${postPart}`\n          var matches = document.querySelectorAll(pattern)\n          if (compareResults(matches, elements)) {\n            current = description\n          }\n          break\n        }\n      }\n    }\n  }\n\n  // robustness: descendant instead child (heuristic)\n  if (/>/.test(current)) {\n    const descendant = current.replace(/>/, '')\n    var pattern = `${prePart}${descendant}${postPart}`\n    var matches = document.querySelectorAll(pattern)\n    if (compareResults(matches, elements)) {\n      current = descendant\n    }\n  }\n\n  // robustness: 'nth-of-type' instead 'nth-child' (heuristic)\n  if (/:nth-child/.test(current)) {\n    // TODO: consider complete coverage of 'nth-of-type' replacement\n    const type = current.replace(/nth-child/g, 'nth-of-type')\n    var pattern = `${prePart}${type}${postPart}`\n    var matches = document.querySelectorAll(pattern)\n    if (compareResults(matches, elements)) {\n      current = type\n    }\n  }\n\n  // efficiency: combinations of classname (partial permutations)\n  if (/\\.\\S+\\.\\S+/.test(current)) {\n    var names = current.trim().split('.').slice(1)\n                                         .map((name) => `.${name}`)\n                                         .sort((curr, next) => curr.length - next.length)\n    while (names.length) {\n      const partial = current.replace(names.shift(), '').trim()\n      var pattern = `${prePart}${partial}${postPart}`.trim()\n      if (!pattern.length || pattern.charAt(0) === '>' || pattern.charAt(pattern.length-1) === '>') {\n        break\n      }\n      var matches = document.querySelectorAll(pattern)\n      if (compareResults(matches, elements)) {\n        current = partial\n      }\n    }\n\n    // robustness: degrade complex classname (heuristic)\n    names = current && current.match(/\\./g)\n    if (names && names.length > 2) {\n      const references = document.querySelectorAll(`${prePart}${current}`)\n      for (var i = 0, l = references.length; i < l; i++) {\n        const reference = references[i]\n        if (elements.some((element) => reference.contains(element) )) {\n          // TODO:\n          // - check using attributes + regard excludes\n          const description = reference.tagName.toLowerCase()\n          var pattern = `${prePart}${description}${postPart}`\n          var matches = document.querySelectorAll(pattern)\n          if (compareResults(matches, elements)) {\n            current = description\n          }\n          break\n        }\n      }\n    }\n  }\n\n  return current\n}\n\n/**\n * Evaluate matches with expected elements\n *\n * @param  {Array.<HTMLElement>} matches  - [description]\n * @param  {Array.<HTMLElement>} elements - [description]\n * @return {Boolean}                      - [description]\n */\nfunction compareResults (matches, elements) {\n  const { length } = matches\n  return length === elements.length && elements.every((element) => {\n    for (var i = 0; i < length; i++) {\n      if (matches[i] === element) {\n        return true\n      }\n    }\n    return false\n  })\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/optimize.js","/**\n * # Adapt\n *\n * Check and extend the environment for universal usage.\n */\n\n/**\n * Modify the context based on the environment\n *\n * @param  {HTMLELement} element - [description]\n * @param  {Object}      options - [description]\n * @return {boolean}             - [description]\n */\nexport default function adapt (element, options) {\n\n  // detect environment setup\n  if (global.document) {\n    return false\n  } else {\n    global.document = options.context || (() => {\n      var root = element\n      while (root.parent) {\n        root = root.parent\n      }\n      return root\n    })()\n  }\n\n  // https://github.com/fb55/domhandler/blob/master/index.js#L75\n  const ElementPrototype = Object.getPrototypeOf(global.document)\n\n  // alternative descriptor to access elements with filtering invalid elements (e.g. textnodes)\n  if (!Object.getOwnPropertyDescriptor(ElementPrototype, 'childTags')) {\n    Object.defineProperty(ElementPrototype, 'childTags', {\n      enumerable: true,\n      get () {\n        return this.children.filter((node) => {\n          // https://github.com/fb55/domelementtype/blob/master/index.js#L12\n          return node.type === 'tag' || node.type === 'script' || node.type === 'style'\n        })\n      }\n    })\n  }\n\n  if (!Object.getOwnPropertyDescriptor(ElementPrototype, 'attributes')) {\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/attributes\n    // https://developer.mozilla.org/en-US/docs/Web/API/NamedNodeMap\n    Object.defineProperty(ElementPrototype, 'attributes', {\n      enumerable: true,\n      get () {\n        const { attribs } = this\n        const attributesNames = Object.keys(attribs)\n        const NamedNodeMap = attributesNames.reduce((attributes, attributeName, index) => {\n          attributes[index] = {\n            name: attributeName,\n            value: attribs[attributeName]\n          }\n          return attributes\n        }, { })\n        Object.defineProperty(NamedNodeMap, 'length', {\n          enumerable: false,\n          configurable: false,\n          value: attributesNames.length\n        })\n        return NamedNodeMap\n      }\n    })\n  }\n\n  if (!ElementPrototype.getAttribute) {\n    // https://docs.webplatform.org/wiki/dom/Element/getAttribute\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/getAttribute\n    ElementPrototype.getAttribute = function (name) {\n      return this.attribs[name] || null\n    }\n  }\n\n  if (!ElementPrototype.getElementsByTagName) {\n    // https://docs.webplatform.org/wiki/dom/Document/getElementsByTagName\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/getElementsByTagName\n    ElementPrototype.getElementsByTagName = function (tagName) {\n      const HTMLCollection = []\n      traverseDescendants(this.childTags, (descendant) => {\n        if (descendant.name === tagName || tagName === '*') {\n          HTMLCollection.push(descendant)\n        }\n      })\n      return HTMLCollection\n    }\n  }\n\n  if (!ElementPrototype.getElementsByClassName) {\n    // https://docs.webplatform.org/wiki/dom/Document/getElementsByClassName\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/getElementsByClassName\n    ElementPrototype.getElementsByClassName = function (className) {\n      const names = className.trim().replace(/\\s+/g, ' ').split(' ')\n      const HTMLCollection = []\n      traverseDescendants([this], (descendant) => {\n        const descendantClassName = descendant.attribs.class\n        if (descendantClassName && names.every((name) => descendantClassName.indexOf(name) > -1)) {\n          HTMLCollection.push(descendant)\n        }\n      })\n      return HTMLCollection\n    }\n  }\n\n  if (!ElementPrototype.querySelectorAll) {\n    // https://docs.webplatform.org/wiki/css/selectors_api/querySelectorAll\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/querySelectorAll\n    ElementPrototype.querySelectorAll = function (selectors) {\n      selectors = selectors.replace(/(>)(\\S)/g, '$1 $2').trim() // add space for '>' selector\n\n      // using right to left execution => https://github.com/fb55/css-select#how-does-it-work\n      const instructions = getInstructions(selectors)\n      const discover = instructions.shift()\n\n      const total = instructions.length\n      return discover(this).filter((node) => {\n        var step = 0\n        while (step < total) {\n          node = instructions[step](node, this)\n          if (!node) { // hierarchy doesn't match\n            return false\n          }\n          step += 1\n        }\n        return true\n      })\n    }\n  }\n\n  if (!ElementPrototype.contains) {\n    // https://developer.mozilla.org/en-US/docs/Web/API/Node/contains\n    ElementPrototype.contains = function (element) {\n      var inclusive = false\n      traverseDescendants([this], (descendant, done) => {\n        if (descendant === element) {\n          inclusive = true\n          done()\n        }\n      })\n      return inclusive\n    }\n  }\n\n  return true\n}\n\n/**\n * Retrieve transformation steps\n *\n * @param  {Array.<string>}   selectors - [description]\n * @return {Array.<Function>}           - [description]\n */\nfunction getInstructions (selectors) {\n  return selectors.split(' ').reverse().map((selector, step) => {\n    const discover = step === 0\n    const [type, pseudo] = selector.split(':')\n\n    var validate = null\n    var instruction = null\n\n    switch (true) {\n\n      // child: '>'\n      case />/.test(type):\n        instruction = function checkParent (node) {\n          return (validate) => validate(node.parent) && node.parent\n        }\n        break\n\n      // class: '.'\n      case /^\\./.test(type):\n        const names = type.substr(1).split('.')\n        validate = (node) => {\n          const nodeClassName = node.attribs.class\n          return nodeClassName && names.every((name) => nodeClassName.indexOf(name) > -1)\n        }\n        instruction = function checkClass (node, root) {\n          if (discover) {\n            return node.getElementsByClassName(names.join(' '))\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n        break\n\n      // attribute: '[key=\"value\"]'\n      case /^\\[/.test(type):\n        const [attributeKey, attributeValue] = type.replace(/\\[|\\]|\"/g, '').split('=')\n        validate = (node) => {\n          const hasAttribute = Object.keys(node.attribs).indexOf(attributeKey) > -1\n          if (hasAttribute) { // regard optional attributeValue\n            if (!attributeValue || (node.attribs[attributeKey] === attributeValue)) {\n              return true\n            }\n          }\n          return false\n        }\n        instruction = function checkAttribute (node, root) {\n          if (discover) {\n            const NodeList = []\n            traverseDescendants([node], (descendant) => {\n              if (validate(descendant)) {\n                NodeList.push(descendant)\n              }\n            })\n            return NodeList\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n        break\n\n      // id: '#'\n      case /^#/.test(type):\n        const id = type.substr(1)\n        validate = (node) => {\n          return node.attribs.id === id\n        }\n        instruction = function checkId (node, root) {\n          if (discover) {\n            const NodeList = []\n            traverseDescendants([node], (descendant, done) => {\n              if (validate(descendant)) {\n                NodeList.push(descendant)\n                done()\n              }\n            })\n            return NodeList\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n        break\n\n      // universal: '*'\n      case /\\*/.test(type):\n        validate = (node) => true\n        instruction = function checkUniversal (node, root) {\n          if (discover) {\n            const NodeList = []\n            traverseDescendants([node], (descendant) => NodeList.push(descendant))\n            return NodeList\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n        break\n\n      // tag: '...'\n      default:\n        validate = (node) => {\n          return node.name === type\n        }\n        instruction = function checkTag (node, root) {\n          if (discover) {\n            const NodeList = []\n            traverseDescendants([node], (descendant) => {\n              if (validate(descendant)) {\n                NodeList.push(descendant)\n              }\n            })\n            return NodeList\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n    }\n\n    if (!pseudo) {\n      return instruction\n    }\n\n    const rule = pseudo.match(/-(child|type)\\((\\d+)\\)$/)\n    const kind = rule[1]\n    const index = parseInt(rule[2], 10) - 1\n\n    const validatePseudo = (node) => {\n      if (node) {\n        var compareSet = node.parent.childTags\n        if (kind === 'type') {\n          compareSet = compareSet.filter(validate)\n        }\n        const nodeIndex = compareSet.findIndex((child) => child === node)\n        if (nodeIndex === index) {\n          return true\n        }\n      }\n      return false\n    }\n\n    return function enhanceInstruction (node) {\n      const match = instruction(node)\n      if (discover) {\n        return match.reduce((NodeList, matchedNode) => {\n          if (validatePseudo(matchedNode)) {\n            NodeList.push(matchedNode)\n          }\n          return NodeList\n        }, [])\n      }\n      return validatePseudo(match) && match\n    }\n  })\n}\n\n/**\n * Walking recursive to invoke callbacks\n *\n * @param {Array.<HTMLElement>} nodes   - [description]\n * @param {Function}            handler - [description]\n */\nfunction traverseDescendants (nodes, handler) {\n  nodes.forEach((node) => {\n    var progress = true\n    handler(node, () => progress = false)\n    if (node.childTags && progress) {\n      traverseDescendants(node.childTags, handler)\n    }\n  })\n}\n\n/**\n * Bubble up from bottom to top\n *\n * @param  {HTMLELement} node     - [description]\n * @param  {HTMLELement} root     - [description]\n * @param  {Function}    validate - [description]\n * @return {HTMLELement}          - [description]\n */\nfunction getAncestor (node, root, validate) {\n  while (node.parent) {\n    node = node.parent\n    if (validate(node)) {\n      return node\n    }\n    if (node === root) {\n      break\n    }\n  }\n  return null\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/adapt.js","/**\n * # Select\n *\n * Construct a unique CSS query selector to access the selected DOM element(s).\n * For longevity it applies different matching and optimization strategies.\n */\n\nimport adapt from './adapt'\nimport match from './match'\nimport optimize from './optimize'\nimport { convertNodeList } from './utilities'\nimport { getCommonAncestor, getCommonProperties } from './common'\n\n/**\n * Get a selector for the provided element\n *\n * @param  {HTMLElement} element - [description]\n * @param  {Object}      options - [description]\n * @return {string}              - [description]\n */\nexport function getSingleSelector (element, options = {}) {\n\n  if (element.nodeType === 3) {\n    element = element.parentNode\n  }\n\n  if (element.nodeType !== 1) {\n    throw new Error(`Invalid input - only HTMLElements or representations of them are supported! (not \"${typeof element}\")`)\n  }\n\n  const globalModified = adapt(element, options)\n\n  const selector = match(element, options)\n  const optimized = optimize(selector, element, options)\n\n  // debug\n  // console.log(`\n  //   selector:  ${selector}\n  //   optimized: ${optimized}\n  // `)\n\n  if (globalModified) {\n    delete global.document\n  }\n\n  return optimized\n}\n\n/**\n * Get a selector to match multiple descendants from an ancestor\n *\n * @param  {Array.<HTMLElement>|NodeList} elements - [description]\n * @param  {Object}                       options  - [description]\n * @return {string}                                - [description]\n */\nexport function getMultiSelector (elements, options = {}) {\n\n  if (!Array.isArray(elements)) {\n    elements = convertNodeList(elements)\n  }\n\n  if (elements.some((element) => element.nodeType !== 1)) {\n    throw new Error(`Invalid input - only an Array of HTMLElements or representations of them is supported!`)\n  }\n\n  const globalModified = adapt(elements[0], options)\n\n  const ancestor = getCommonAncestor(elements, options)\n  const ancestorSelector = getSingleSelector(ancestor, options)\n\n  // TODO: consider usage of multiple selectors + parent-child relation + check for part redundancy\n  const commonSelectors = getCommonSelectors(elements)\n  const descendantSelector = commonSelectors[0]\n\n  const selector = optimize(`${ancestorSelector} ${descendantSelector}`, elements, options)\n  const selectorMatches = convertNodeList(document.querySelectorAll(selector))\n\n  if (!elements.every((element) => selectorMatches.some((entry) => entry === element) )) {\n    // TODO: cluster matches to split into similar groups for sub selections\n    return console.warn(`\n      The selected elements can\\'t be efficiently mapped.\n      Its probably best to use multiple single selectors instead!\n    `, elements)\n  }\n\n  if (globalModified) {\n    delete global.document\n  }\n\n  return selector\n}\n\n/**\n * Get selectors to describe a set of elements\n *\n * @param  {Array.<HTMLElements>} elements - [description]\n * @return {string}                        - [description]\n */\nfunction getCommonSelectors (elements) {\n\n  const { classes, attributes, tag } = getCommonProperties(elements)\n\n  const selectorPath = []\n\n  if (tag) {\n    selectorPath.push(tag)\n  }\n\n  if (classes) {\n    const classSelector = classes.map((name) => `.${name}`).join('')\n    selectorPath.push(classSelector)\n  }\n\n  if (attributes) {\n    const attributeSelector = Object.keys(attributes).reduce((parts, name) => {\n      parts.push(`[${name}=\"${attributes[name]}\"]`)\n      return parts\n    }, []).join('')\n    selectorPath.push(attributeSelector)\n  }\n\n  if (selectorPath.length) {\n    // TODO: check for parent-child relation\n  }\n\n  return [\n    selectorPath.join('')\n  ]\n}\n\n/**\n * Choose action depending on the input (multiple/single)\n *\n * NOTE: extended detection is used for special cases like the <select> element with <options>\n *\n * @param  {HTMLElement|NodeList|Array.<HTMLElement>} input   - [description]\n * @param  {Object}                                   options - [description]\n * @return {string}                                           - [description]\n */\nexport default function getQuerySelector (input, options = {}) {\n  if (input.length && !input.name) {\n    return getMultiSelector(input, options)\n  }\n  return getSingleSelector(input, options)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/select.js","/**\n * # Match\n *\n * Retrieve selector for a node.\n */\n\nimport { escapeValue } from './utilities'\n\nconst defaultIgnore = {\n  attribute (attributeName) {\n    return [\n      'style',\n      'data-reactid',\n      'data-react-checksum'\n    ].indexOf(attributeName) > -1\n  }\n}\n\n/**\n * Get the path of the element\n *\n * @param  {HTMLElement} node    - [description]\n * @param  {Object}      options - [description]\n * @return {string}              - [description]\n */\nexport default function match (node, options) {\n\n  const {\n    root = document,\n    skip = null,\n    priority = ['id', 'class', 'href', 'src'],\n    ignore = {}\n  } = options\n\n  const path = []\n  var element = node\n  var length = path.length\n  var ignoreClass = false\n\n  const skipCompare = skip && (Array.isArray(skip) ? skip : [skip]).map((entry) => {\n    if (typeof entry !== 'function') {\n      return (element) => element === entry\n    }\n    return entry\n  })\n\n  const skipChecks = (element) => {\n    return skip && skipCompare.some((compare) => compare(element))\n  }\n\n  Object.keys(ignore).forEach((type) => {\n    if (type === 'class') {\n      ignoreClass = true\n    }\n    var predicate = ignore[type]\n    if (typeof predicate === 'function') return\n    if (typeof predicate === 'number') {\n      predicate = predicate.toString()\n    }\n    if (typeof predicate === 'string') {\n      predicate = new RegExp(escapeValue(predicate).replace(/\\\\/g, '\\\\\\\\'))\n    }\n    if (typeof predicate === 'boolean') {\n      predicate = predicate ? /(?:)/ : /.^/\n    }\n    // check class-/attributename for regex\n    ignore[type] = (name, value) => predicate.test(value)\n  })\n\n  if (ignoreClass) {\n    const ignoreAttribute = ignore.attribute\n    ignore.attribute = (name, value, defaultPredicate) => {\n      return ignore.class(value) || ignoreAttribute && ignoreAttribute(name, value, defaultPredicate)\n    }\n  }\n\n  while (element !== root) {\n    if (skipChecks(element) !== true) {\n      // ~ global\n      if (checkAttributes(priority, element, ignore, path, root)) break\n      if (checkTag(element, ignore, path, root)) break\n\n      // ~ local\n      checkAttributes(priority, element, ignore, path)\n      if (path.length === length) {\n        checkTag(element, ignore, path)\n      }\n\n      // define only one part each iteration\n      if (path.length === length) {\n        checkChilds(priority, element, ignore, path)\n      }\n    }\n\n    element = element.parentNode\n    length = path.length\n  }\n\n  if (element === root) {\n    const pattern = findPattern(priority, element, ignore)\n    path.unshift(pattern)\n  }\n\n  return path.join(' ')\n}\n\n/**\n * Extend path with attribute identifier\n *\n * @param  {Array.<string>} priority - [description]\n * @param  {HTMLElement}    element  - [description]\n * @param  {Object}         ignore   - [description]\n * @param  {Array.<string>} path     - [description]\n * @param  {HTMLElement}    parent   - [description]\n * @return {boolean}                 - [description]\n */\nfunction checkAttributes (priority, element, ignore, path, parent = element.parentNode) {\n  const pattern = findAttributesPattern(priority, element, ignore)\n  if (pattern) {\n    const matches = parent.querySelectorAll(pattern)\n    if (matches.length === 1) {\n      path.unshift(pattern)\n      return true\n    }\n  }\n  return false\n}\n\n/**\n * Lookup attribute identifier\n *\n * @param  {Array.<string>} priority - [description]\n * @param  {HTMLElement}    element  - [description]\n * @param  {Object}         ignore   - [description]\n * @return {string?}                 - [description]\n */\nfunction findAttributesPattern (priority, element, ignore) {\n  const attributes = element.attributes\n  const sortedKeys = Object.keys(attributes).sort((curr, next) => {\n    const currPos = priority.indexOf(attributes[curr].name)\n    const nextPos = priority.indexOf(attributes[next].name)\n    if (nextPos === -1) {\n      if (currPos === -1) {\n        return 0\n      }\n      return -1\n    }\n    if (currPos === -1) {\n      return 1\n    }\n    return currPos - nextPos;\n  })\n\n  for (var i = 0, l = sortedKeys.length; i < l; i++) {\n    const key = sortedKeys[i]\n    const attribute = attributes[key]\n    const attributeName = attribute.name\n    const attributeValue = escapeValue(attribute.value)\n\n    const currentIgnore = ignore[attributeName] || ignore.attribute\n    const currentDefaultIgnore = defaultIgnore[attributeName] || defaultIgnore.attribute\n    if (checkIgnore(currentIgnore, attributeName, attributeValue, currentDefaultIgnore)) {\n      continue\n    }\n\n    var pattern = `[${attributeName}=\"${attributeValue}\"]`\n\n    if (attributeName === 'id' && (/^[A-Za-z][-\\d\\w:,.]*$/).test(attributeValue)) {\n        pattern = `#${attributeValue}`\n    }\n\n    if (attributeName === 'class' && (/^[A-Za-z][-\\d\\w]*$/).test(attributeValue)) {\n      const className = attributeValue.trim().replace(/\\s+/g, '.')\n      pattern = `.${className}`\n    }\n\n    return pattern\n  }\n  return null\n}\n\n/**\n * Extend path with tag identifier\n *\n * @param  {HTMLElement}    element - [description]\n * @param  {Object}         ignore  - [description]\n * @param  {Array.<string>} path    - [description]\n * @param  {HTMLElement}    parent  - [description]\n * @return {boolean}                - [description]\n */\nfunction checkTag (element, ignore, path, parent = element.parentNode) {\n  const pattern = findTagPattern(element, ignore)\n  if (pattern) {\n    const matches = parent.getElementsByTagName(pattern)\n    if (matches.length === 1) {\n      path.unshift(pattern)\n      return true\n    }\n  }\n  return false\n}\n\n/**\n * Lookup tag identifier\n *\n * @param  {HTMLElement} element - [description]\n * @param  {Object}      ignore  - [description]\n * @return {boolean}             - [description]\n */\nfunction findTagPattern (element, ignore) {\n  const tagName = element.tagName.toLowerCase()\n  if (checkIgnore(ignore.tag, null, tagName)) {\n    return null\n  }\n  return tagName\n}\n\n/**\n * Extend path with specific child identifier\n *\n * NOTE: 'childTags' is a custom property to use as a view filter for tags using 'adapter.js'\n *\n * @param  {Array.<string>} priority - [description]\n * @param  {HTMLElement}    element  - [description]\n * @param  {Object}         ignore   - [description]\n * @param  {Array.<string>} path     - [description]\n * @return {boolean}                 - [description]\n */\nfunction checkChilds (priority, element, ignore, path) {\n  const parent = element.parentNode\n  const children = parent.childTags || parent.children\n  for (var i = 0, l = children.length; i < l; i++) {\n    const child = children[i]\n    if (child === element) {\n      const childPattern = findPattern(priority, child, ignore)\n      if (!childPattern) {\n        return console.warn(`\n          Element couldn\\'t be matched through strict ignore pattern!\n        `, child, ignore, childPattern)\n      }\n      const pattern = `> ${childPattern}:nth-child(${i+1})`\n      path.unshift(pattern)\n      return true\n    }\n  }\n  return false\n}\n\n/**\n * Lookup identifier\n *\n * @param  {Array.<string>} priority - [description]\n * @param  {HTMLElement}    element  - [description]\n * @param  {Object}         ignore   - [description]\n * @return {string}                  - [description]\n */\nfunction findPattern (priority, element, ignore) {\n  var pattern = findAttributesPattern(priority, element, ignore)\n  if (!pattern) {\n    pattern = findTagPattern(element, ignore)\n  }\n  return pattern\n}\n\n/**\n * Validate with custom and default functions\n *\n * @param  {Function} predicate        - [description]\n * @param  {string?}  name             - [description]\n * @param  {string}   value            - [description]\n * @param  {Function} defaultPredicate - [description]\n * @return {boolean}                   - [description]\n */\nfunction checkIgnore (predicate, name, value, defaultPredicate) {\n  if (!value) {\n    return true\n  }\n  const check = predicate || defaultPredicate\n  if (!check) {\n    return false\n  }\n  return check(name, value, defaultPredicate)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/match.js","export select, { getSingleSelector, getMultiSelector } from './select'\nexport optimize from './optimize'\nexport * as common from './common'\n\nexport default from './select'\n\n\n\n// WEBPACK FOOTER //\n// ./src/index.js"],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 5fd5b8c929ea057c50dc","webpack:///./src/utilities.js","webpack:///./src/common.js","webpack:///./src/optimize.js","webpack:///./src/adapt.js","webpack:///./src/select.js","webpack:///./~/cssesc/cssesc.js","webpack:///./src/index.js","webpack:///./src/match.js"],"names":["convertNodeList","escapeValue","cssesc","require","nodes","length","arr","Array","i","value","getCommonAncestor","getCommonProperties","elements","options","root","document","ancestors","forEach","element","index","parents","parentNode","unshift","sort","curr","next","shallowAncestor","shift","ancestor","parent","missing","some","otherParents","otherParent","l","commonProperties","classes","attributes","tag","commonClasses","commonAttributes","commonTag","undefined","getAttribute","trim","split","filter","entry","name","elementAttributes","Object","keys","reduce","key","attribute","attributeName","attributesNames","commonAttributesNames","nextCommonAttributes","tagName","toLowerCase","optimize","selector","isArray","nodeType","Error","globalModified","path","replace","optimizePart","shortened","pop","current","prePart","join","postPart","pattern","matches","querySelectorAll","err","slice","global","test","compareResults","references","reference","contains","description","descendant","type","names","map","partial","charAt","match","every","adapt","context","ElementPrototype","getPrototypeOf","getOwnPropertyDescriptor","defineProperty","enumerable","get","children","node","attribs","NamedNodeMap","configurable","getElementsByTagName","HTMLCollection","traverseDescendants","childTags","push","getElementsByClassName","className","descendantClassName","class","indexOf","selectors","instructions","getInstructions","discover","total","step","inclusive","done","reverse","pseudo","validate","instruction","checkParent","substr","nodeClassName","checkClass","getAncestor","attributeKey","attributeValue","hasAttribute","checkAttribute","NodeList","id","checkId","checkUniversal","checkTag","rule","kind","parseInt","validatePseudo","compareSet","nodeIndex","findIndex","child","enhanceInstruction","matchedNode","handler","progress","getSingleSelector","getMultiSelector","getQuerySelector","optimized","ancestorSelector","commonSelectors","getCommonSelectors","descendantSelector","selectorMatches","console","warn","selectorPath","classSelector","attributeSelector","parts","input","object","hasOwnProperty","merge","defaults","result","call","regexAnySingleEscape","regexSingleEscape","regexAlwaysEscape","regexExcessiveSpaces","string","quotes","quote","isIdentifier","firstChar","output","counter","character","codePoint","charCodeAt","extra","toString","toUpperCase","escapeEverything","$0","$1","$2","wrap","version","module","exports","select","common","default","defaultIgnore","skip","priority","ignore","ignoreClass","skipCompare","skipChecks","compare","predicate","RegExp","ignoreAttribute","defaultPredicate","checkAttributes","checkChilds","findPattern","findAttributesPattern","sortedKeys","currPos","nextPos","currentIgnore","currentDefaultIgnore","checkIgnore","findTagPattern","childPattern","check"],"mappings":"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","file":"optimal-select.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"OptimalSelect\"] = factory();\n\telse\n\t\troot[\"OptimalSelect\"] = factory();\n})(this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 6);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 5fd5b8c929ea057c50dc","/**\n * # Utilities\n *\n * Convenience helpers.\n */\n\nconst cssesc = require('cssesc');\n\n/**\n * Create an array with the DOM nodes of the list\n *\n * @param  {NodeList}             nodes - [description]\n * @return {Array.<HTMLElement>}        - [description]\n */\nexport function convertNodeList (nodes) {\n  const { length } = nodes\n  const arr = new Array(length)\n  for (var i = 0; i < length; i++) {\n    arr[i] = nodes[i]\n  }\n  return arr\n}\n\n/**\n * Escape special characters and line breaks as a simplified version of 'CSS.escape()'\n *\n * Description of valid characters: https://mathiasbynens.be/notes/css-escapes\n *\n * @param  {String?} value - [description]\n * @return {String}        - [description]\n */\nexport function escapeValue (value) {\n  return value && cssesc(value);\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/utilities.js","/**\n * # Common\n *\n * Process collections for similarities.\n */\n\n/**\n * Find the last common ancestor of elements\n *\n * @param  {Array.<HTMLElements>} elements - [description]\n * @return {HTMLElement}                   - [description]\n */\nexport function getCommonAncestor (elements, options = {}) {\n\n  const {\n    root = document\n  } = options\n\n  const ancestors = []\n\n  elements.forEach((element, index) => {\n    const parents = []\n    while (element !== root) {\n      element = element.parentNode\n      parents.unshift(element)\n    }\n    ancestors[index] = parents\n  })\n\n  ancestors.sort((curr, next) => curr.length - next.length)\n\n  const shallowAncestor = ancestors.shift()\n\n  var ancestor = null\n\n  for (var i = 0, l = shallowAncestor.length; i < l; i++) {\n    const parent = shallowAncestor[i]\n    const missing = ancestors.some((otherParents) => {\n      return !otherParents.some((otherParent) => otherParent === parent)\n    })\n\n    if (missing) {\n      // TODO: find similar sub-parents, not the top root, e.g. sharing a class selector\n      break\n    }\n\n    ancestor = parent\n  }\n\n  return ancestor\n}\n\n/**\n * Get a set of common properties of elements\n *\n * @param  {Array.<HTMLElement>} elements - [description]\n * @return {Object}                       - [description]\n */\nexport function getCommonProperties (elements) {\n\n  const commonProperties = {\n    classes: [],\n    attributes: {},\n    tag: null\n  }\n\n  elements.forEach((element) => {\n\n    var {\n      classes: commonClasses,\n      attributes: commonAttributes,\n      tag: commonTag\n    } = commonProperties\n\n    // ~ classes\n    if (commonClasses !== undefined) {\n      var classes = element.getAttribute('class')\n      if (classes) {\n        classes = classes.trim().split(' ')\n        if (!commonClasses.length) {\n          commonProperties.classes = classes\n        } else {\n          commonClasses = commonClasses.filter((entry) => classes.some((name) => name === entry))\n          if (commonClasses.length) {\n            commonProperties.classes = commonClasses\n          } else {\n            delete commonProperties.classes\n          }\n        }\n      } else {\n        // TODO: restructure removal as 2x set / 2x delete, instead of modify always replacing with new collection\n        delete commonProperties.classes\n      }\n    }\n\n    // ~ attributes\n    if (commonAttributes !== undefined) {\n      const elementAttributes = element.attributes\n      const attributes = Object.keys(elementAttributes).reduce((attributes, key) => {\n        const attribute = elementAttributes[key]\n        const attributeName = attribute.name\n        // NOTE: workaround detection for non-standard phantomjs NamedNodeMap behaviour\n        // (issue: https://github.com/ariya/phantomjs/issues/14634)\n        if (attribute && attributeName !== 'class') {\n          attributes[attributeName] = attribute.value\n        }\n        return attributes\n      }, {})\n\n      const attributesNames = Object.keys(attributes)\n      const commonAttributesNames = Object.keys(commonAttributes)\n\n      if (attributesNames.length) {\n        if (!commonAttributesNames.length) {\n          commonProperties.attributes = attributes\n        } else {\n          commonAttributes = commonAttributesNames.reduce((nextCommonAttributes, name) => {\n            const value = commonAttributes[name]\n            if (value === attributes[name]) {\n              nextCommonAttributes[name] = value\n            }\n            return nextCommonAttributes\n          }, {})\n          if (Object.keys(commonAttributes).length) {\n            commonProperties.attributes = commonAttributes\n          } else {\n            delete commonProperties.attributes\n          }\n        }\n      } else {\n        delete commonProperties.attributes\n      }\n    }\n\n    // ~ tag\n    if (commonTag !== undefined) {\n      const tag = element.tagName.toLowerCase()\n      if (!commonTag) {\n        commonProperties.tag = tag\n      } else if (tag !== commonTag) {\n        delete commonProperties.tag\n      }\n    }\n  })\n\n  return commonProperties\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/common.js","/**\n * # Optimize\n *\n * 1.) Improve efficiency through shorter selectors by removing redundancy\n * 2.) Improve robustness through selector transformation\n */\n\nimport adapt from './adapt'\nimport { convertNodeList } from './utilities'\n\n/**\n * Apply different optimization techniques\n *\n * @param  {string}                          selector - [description]\n * @param  {HTMLElement|Array.<HTMLElement>} element  - [description]\n * @param  {Object}                          options  - [description]\n * @return {string}                                   - [description]\n */\nexport default function optimize (selector, elements, options = {}) {\n\n  // convert single entry and NodeList\n  if (!Array.isArray(elements)) {\n    elements = !elements.length ? [elements] : convertNodeList(elements)\n  }\n\n  if (!elements.length || elements.some((element) => element.nodeType !== 1)) {\n    throw new Error(`Invalid input - to compare HTMLElements its necessary to provide a reference of the selected node(s)! (missing \"elements\")`)\n  }\n\n  const globalModified = adapt(elements[0], options)\n\n  // chunk parts outside of quotes (http://stackoverflow.com/a/25663729)\n  var path = selector.replace(/> /g, '>').split(/\\s+(?=(?:(?:[^\"]*\"){2})*[^\"]*$)/)\n\n  if (path.length < 2) {\n    return optimizePart('', selector, '', elements)\n  }\n\n  const shortened = [path.pop()]\n  while (path.length > 1)  {\n    const current = path.pop()\n    const prePart = path.join(' ')\n    const postPart = shortened.join(' ')\n\n    const pattern = `${prePart} ${postPart}`\n    let matches = [];\n    try {\n      matches = document.querySelectorAll(pattern)\n    } catch(err) {\n      //\n    }\n    if (matches.length !== elements.length) {\n      shortened.unshift(optimizePart(prePart, current, postPart, elements))\n    }\n  }\n  shortened.unshift(path[0])\n  path = shortened\n\n  // optimize start + end\n  path[0] = optimizePart('', path[0], path.slice(1).join(' '), elements)\n  path[path.length-1] = optimizePart(path.slice(0, -1).join(' '), path[path.length-1], '', elements)\n\n  if (globalModified) {\n    delete global.document\n  }\n\n  return path.join(' ').replace(/>/g, '> ').trim()\n}\n\n/**\n * Improve a chunk of the selector\n *\n * @param  {string}              prePart  - [description]\n * @param  {string}              current  - [description]\n * @param  {string}              postPart - [description]\n * @param  {Array.<HTMLElement>} elements - [description]\n * @return {string}                       - [description]\n */\nfunction optimizePart (prePart, current, postPart, elements) {\n  if (prePart.length) prePart = `${prePart} `\n  if (postPart.length) postPart = ` ${postPart}`\n\n  // robustness: attribute without value (generalization)\n  if (/\\[*\\]/.test(current)) {\n    const key = current.replace(/=.*$/, ']')\n    var pattern = `${prePart}${key}${postPart}`\n    let matches = [];\n    try {\n      matches = document.querySelectorAll(pattern)\n    } catch(err) {\n      //\n    }\n    if (compareResults(matches, elements)) {\n      current = key\n    } else {\n      // robustness: replace specific key-value with base tag (heuristic)\n      let references = [];\n      try {\n        references = document.querySelectorAll(`${prePart}${key}`)\n      } catch(err) {\n        //\n      }\n      for (var i = 0, l = references.length; i < l; i++) {\n        const reference = references[i]\n        if (elements.some((element) => reference.contains(element))) {\n          const description = reference.tagName.toLowerCase()\n          var pattern = `${prePart}${description}${postPart}`\n          let matches = [];\n          try {\n            matches = document.querySelectorAll(pattern)\n          } catch(err) {\n            //\n          }\n          if (compareResults(matches, elements)) {\n            current = description\n          }\n          break\n        }\n      }\n    }\n  }\n\n  // robustness: descendant instead child (heuristic)\n  if (/>/.test(current)) {\n    const descendant = current.replace(/>/, '')\n    var pattern = `${prePart}${descendant}${postPart}`\n    let matches = [];\n    try {\n      matches = document.querySelectorAll(pattern)\n    } catch(err) {\n      //\n    }\n    if (compareResults(matches, elements)) {\n      current = descendant\n    }\n  }\n\n  // robustness: 'nth-of-type' instead 'nth-child' (heuristic)\n  if (/:nth-child/.test(current)) {\n    // TODO: consider complete coverage of 'nth-of-type' replacement\n    const type = current.replace(/nth-child/g, 'nth-of-type')\n    var pattern = `${prePart}${type}${postPart}`\n    let matches = [];\n    try {\n      matches = document.querySelectorAll(pattern)\n    } catch(err) {\n      //\n    }\n    if (compareResults(matches, elements)) {\n      current = type\n    }\n  }\n\n  // efficiency: combinations of classname (partial permutations)\n  if (/\\.\\S+\\.\\S+/.test(current)) {\n    var names = current.trim().split('.').slice(1)\n                                         .map((name) => `.${name}`)\n                                         .sort((curr, next) => curr.length - next.length);\n    while (names.length) {\n      const partial = current.replace(names.shift(), '').trim()\n      if(partial.charAt(0) === '>' || partial.charAt(partial.length-1) === '>') {\n        break\n      }\n      var pattern = `${prePart}${partial}${postPart}`.trim()\n      if (!pattern.length || pattern.charAt(0) === '>' || pattern.charAt(pattern.length-1) === '>') {\n        break\n      }\n      let matches = [];\n\n      try {\n        matches = document.querySelectorAll(pattern)\n      } catch(err) {\n        //\n      }\n      if (compareResults(matches, elements)) {\n        current = partial\n      }\n    }\n\n    // robustness: degrade complex classname (heuristic)\n    names = current && current.match(/\\./g)\n    if (names && names.length > 2) {\n      let references = [];\n      try {\n        references = document.querySelectorAll(`${prePart}${current}`);\n      } catch (err) {\n        //\n      }\n      for (var i = 0, l = references.length; i < l; i++) {\n        const reference = references[i]\n        if (elements.some((element) => reference.contains(element) )) {\n          // TODO:\n          // - check using attributes + regard excludes\n          const description = reference.tagName.toLowerCase()\n          var pattern = `${prePart}${description}${postPart}`\n          let matches = [];\n          try {\n            matches = document.querySelectorAll(pattern)\n          } catch(err) {\n            //\n          }\n          if (compareResults(matches, elements)) {\n            current = description\n          }\n          break\n        }\n      }\n    }\n  }\n\n  return current\n}\n\n/**\n * Evaluate matches with expected elements\n *\n * @param  {Array.<HTMLElement>} matches  - [description]\n * @param  {Array.<HTMLElement>} elements - [description]\n * @return {Boolean}                      - [description]\n */\nfunction compareResults (matches, elements) {\n  const { length } = matches\n  return length === elements.length && elements.every((element) => {\n    for (var i = 0; i < length; i++) {\n      if (matches[i] === element) {\n        return true\n      }\n    }\n    return false\n  })\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/optimize.js","/**\n * # Adapt\n *\n * Check and extend the environment for universal usage.\n */\n\n/**\n * Modify the context based on the environment\n *\n * @param  {HTMLELement} element - [description]\n * @param  {Object}      options - [description]\n * @return {boolean}             - [description]\n */\nexport default function adapt (element, options) {\n\n  // detect environment setup\n  if (global.document) {\n    return false\n  } else {\n    global.document = options.context || (() => {\n      var root = element\n      while (root.parent) {\n        root = root.parent\n      }\n      return root\n    })()\n  }\n\n  // https://github.com/fb55/domhandler/blob/master/index.js#L75\n  const ElementPrototype = Object.getPrototypeOf(global.document)\n\n  // alternative descriptor to access elements with filtering invalid elements (e.g. textnodes)\n  if (!Object.getOwnPropertyDescriptor(ElementPrototype, 'childTags')) {\n    Object.defineProperty(ElementPrototype, 'childTags', {\n      enumerable: true,\n      get () {\n        return this.children.filter((node) => {\n          // https://github.com/fb55/domelementtype/blob/master/index.js#L12\n          return node.type === 'tag' || node.type === 'script' || node.type === 'style'\n        })\n      }\n    })\n  }\n\n  if (!Object.getOwnPropertyDescriptor(ElementPrototype, 'attributes')) {\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/attributes\n    // https://developer.mozilla.org/en-US/docs/Web/API/NamedNodeMap\n    Object.defineProperty(ElementPrototype, 'attributes', {\n      enumerable: true,\n      get () {\n        const { attribs } = this\n        const attributesNames = Object.keys(attribs)\n        const NamedNodeMap = attributesNames.reduce((attributes, attributeName, index) => {\n          attributes[index] = {\n            name: attributeName,\n            value: attribs[attributeName]\n          }\n          return attributes\n        }, { })\n        Object.defineProperty(NamedNodeMap, 'length', {\n          enumerable: false,\n          configurable: false,\n          value: attributesNames.length\n        })\n        return NamedNodeMap\n      }\n    })\n  }\n\n  if (!ElementPrototype.getAttribute) {\n    // https://docs.webplatform.org/wiki/dom/Element/getAttribute\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/getAttribute\n    ElementPrototype.getAttribute = function (name) {\n      return this.attribs[name] || null\n    }\n  }\n\n  if (!ElementPrototype.getElementsByTagName) {\n    // https://docs.webplatform.org/wiki/dom/Document/getElementsByTagName\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/getElementsByTagName\n    ElementPrototype.getElementsByTagName = function (tagName) {\n      const HTMLCollection = []\n      traverseDescendants(this.childTags, (descendant) => {\n        if (descendant.name === tagName || tagName === '*') {\n          HTMLCollection.push(descendant)\n        }\n      })\n      return HTMLCollection\n    }\n  }\n\n  if (!ElementPrototype.getElementsByClassName) {\n    // https://docs.webplatform.org/wiki/dom/Document/getElementsByClassName\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/getElementsByClassName\n    ElementPrototype.getElementsByClassName = function (className) {\n      const names = className.trim().replace(/\\s+/g, ' ').split(' ')\n      const HTMLCollection = []\n      traverseDescendants([this], (descendant) => {\n        const descendantClassName = descendant.attribs.class\n        if (descendantClassName && names.every((name) => descendantClassName.indexOf(name) > -1)) {\n          HTMLCollection.push(descendant)\n        }\n      })\n      return HTMLCollection\n    }\n  }\n\n  if (!ElementPrototype.querySelectorAll) {\n    // https://docs.webplatform.org/wiki/css/selectors_api/querySelectorAll\n    // https://developer.mozilla.org/en-US/docs/Web/API/Element/querySelectorAll\n    ElementPrototype.querySelectorAll = function (selectors) {\n      selectors = selectors.replace(/(>)(\\S)/g, '$1 $2').trim() // add space for '>' selector\n\n      // using right to left execution => https://github.com/fb55/css-select#how-does-it-work\n      const instructions = getInstructions(selectors)\n      const discover = instructions.shift()\n\n      const total = instructions.length\n      return discover(this).filter((node) => {\n        var step = 0\n        while (step < total) {\n          node = instructions[step](node, this)\n          if (!node) { // hierarchy doesn't match\n            return false\n          }\n          step += 1\n        }\n        return true\n      })\n    }\n  }\n\n  if (!ElementPrototype.contains) {\n    // https://developer.mozilla.org/en-US/docs/Web/API/Node/contains\n    ElementPrototype.contains = function (element) {\n      var inclusive = false\n      traverseDescendants([this], (descendant, done) => {\n        if (descendant === element) {\n          inclusive = true\n          done()\n        }\n      })\n      return inclusive\n    }\n  }\n\n  return true\n}\n\n/**\n * Retrieve transformation steps\n *\n * @param  {Array.<string>}   selectors - [description]\n * @return {Array.<Function>}           - [description]\n */\nfunction getInstructions (selectors) {\n  return selectors.split(' ').reverse().map((selector, step) => {\n    const discover = step === 0\n    const [type, pseudo] = selector.split(':')\n\n    var validate = null\n    var instruction = null\n\n    switch (true) {\n\n      // child: '>'\n      case />/.test(type):\n        instruction = function checkParent (node) {\n          return (validate) => validate(node.parent) && node.parent\n        }\n        break\n\n      // class: '.'\n      case /^\\./.test(type):\n        const names = type.substr(1).split('.')\n        validate = (node) => {\n          const nodeClassName = node.attribs.class\n          return nodeClassName && names.every((name) => nodeClassName.indexOf(name) > -1)\n        }\n        instruction = function checkClass (node, root) {\n          if (discover) {\n            return node.getElementsByClassName(names.join(' '))\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n        break\n\n      // attribute: '[key=\"value\"]'\n      case /^\\[/.test(type):\n        const [attributeKey, attributeValue] = type.replace(/\\[|\\]|\"/g, '').split('=')\n        validate = (node) => {\n          const hasAttribute = Object.keys(node.attribs).indexOf(attributeKey) > -1\n          if (hasAttribute) { // regard optional attributeValue\n            if (!attributeValue || (node.attribs[attributeKey] === attributeValue)) {\n              return true\n            }\n          }\n          return false\n        }\n        instruction = function checkAttribute (node, root) {\n          if (discover) {\n            const NodeList = []\n            traverseDescendants([node], (descendant) => {\n              if (validate(descendant)) {\n                NodeList.push(descendant)\n              }\n            })\n            return NodeList\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n        break\n\n      // id: '#'\n      case /^#/.test(type):\n        const id = type.substr(1)\n        validate = (node) => {\n          return node.attribs.id === id\n        }\n        instruction = function checkId (node, root) {\n          if (discover) {\n            const NodeList = []\n            traverseDescendants([node], (descendant, done) => {\n              if (validate(descendant)) {\n                NodeList.push(descendant)\n                done()\n              }\n            })\n            return NodeList\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n        break\n\n      // universal: '*'\n      case /\\*/.test(type):\n        validate = (node) => true\n        instruction = function checkUniversal (node, root) {\n          if (discover) {\n            const NodeList = []\n            traverseDescendants([node], (descendant) => NodeList.push(descendant))\n            return NodeList\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n        break\n\n      // tag: '...'\n      default:\n        validate = (node) => {\n          return node.name === type\n        }\n        instruction = function checkTag (node, root) {\n          if (discover) {\n            const NodeList = []\n            traverseDescendants([node], (descendant) => {\n              if (validate(descendant)) {\n                NodeList.push(descendant)\n              }\n            })\n            return NodeList\n          }\n          return (typeof node === 'function') ? node(validate) : getAncestor(node, root, validate)\n        }\n    }\n\n    if (!pseudo) {\n      return instruction\n    }\n\n    const rule = pseudo.match(/-(child|type)\\((\\d+)\\)$/)\n    const kind = rule[1]\n    const index = parseInt(rule[2], 10) - 1\n\n    const validatePseudo = (node) => {\n      if (node) {\n        var compareSet = node.parent.childTags\n        if (kind === 'type') {\n          compareSet = compareSet.filter(validate)\n        }\n        const nodeIndex = compareSet.findIndex((child) => child === node)\n        if (nodeIndex === index) {\n          return true\n        }\n      }\n      return false\n    }\n\n    return function enhanceInstruction (node) {\n      const match = instruction(node)\n      if (discover) {\n        return match.reduce((NodeList, matchedNode) => {\n          if (validatePseudo(matchedNode)) {\n            NodeList.push(matchedNode)\n          }\n          return NodeList\n        }, [])\n      }\n      return validatePseudo(match) && match\n    }\n  })\n}\n\n/**\n * Walking recursive to invoke callbacks\n *\n * @param {Array.<HTMLElement>} nodes   - [description]\n * @param {Function}            handler - [description]\n */\nfunction traverseDescendants (nodes, handler) {\n  nodes.forEach((node) => {\n    var progress = true\n    handler(node, () => progress = false)\n    if (node.childTags && progress) {\n      traverseDescendants(node.childTags, handler)\n    }\n  })\n}\n\n/**\n * Bubble up from bottom to top\n *\n * @param  {HTMLELement} node     - [description]\n * @param  {HTMLELement} root     - [description]\n * @param  {Function}    validate - [description]\n * @return {HTMLELement}          - [description]\n */\nfunction getAncestor (node, root, validate) {\n  while (node.parent) {\n    node = node.parent\n    if (validate(node)) {\n      return node\n    }\n    if (node === root) {\n      break\n    }\n  }\n  return null\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/adapt.js","/**\n * # Select\n *\n * Construct a unique CSS query selector to access the selected DOM element(s).\n * For longevity it applies different matching and optimization strategies.\n */\n\nimport adapt from './adapt'\nimport match from './match'\nimport optimize from './optimize'\nimport { convertNodeList } from './utilities'\nimport { getCommonAncestor, getCommonProperties } from './common'\n\n/**\n * Get a selector for the provided element\n *\n * @param  {HTMLElement} element - [description]\n * @param  {Object}      options - [description]\n * @return {string}              - [description]\n */\nexport function getSingleSelector (element, options = {}) {\n\n  if (element.nodeType === 3) {\n    element = element.parentNode\n  }\n\n  if (element.nodeType !== 1) {\n    throw new Error(`Invalid input - only HTMLElements or representations of them are supported! (not \"${typeof element}\")`)\n  }\n\n  const globalModified = adapt(element, options)\n\n  const selector = match(element, options)\n  const optimized = optimize(selector, element, options)\n\n  // debug\n  // console.log(`\n  //   selector:  ${selector}\n  //   optimized: ${optimized}\n  // `)\n\n  if (globalModified) {\n    delete global.document\n  }\n\n  return optimized\n}\n\n/**\n * Get a selector to match multiple descendants from an ancestor\n *\n * @param  {Array.<HTMLElement>|NodeList} elements - [description]\n * @param  {Object}                       options  - [description]\n * @return {string}                                - [description]\n */\nexport function getMultiSelector (elements, options = {}) {\n\n  if (!Array.isArray(elements)) {\n    elements = convertNodeList(elements)\n  }\n\n  if (elements.some((element) => element.nodeType !== 1)) {\n    throw new Error(`Invalid input - only an Array of HTMLElements or representations of them is supported!`)\n  }\n\n  const globalModified = adapt(elements[0], options)\n\n  const ancestor = getCommonAncestor(elements, options)\n  const ancestorSelector = getSingleSelector(ancestor, options)\n\n  // TODO: consider usage of multiple selectors + parent-child relation + check for part redundancy\n  const commonSelectors = getCommonSelectors(elements)\n  const descendantSelector = commonSelectors[0]\n\n  const selector = optimize(`${ancestorSelector} ${descendantSelector}`, elements, options)\n  const selectorMatches = convertNodeList(document.querySelectorAll(selector))\n\n  if (!elements.every((element) => selectorMatches.some((entry) => entry === element) )) {\n    // TODO: cluster matches to split into similar groups for sub selections\n    return console.warn(`\n      The selected elements can\\'t be efficiently mapped.\n      Its probably best to use multiple single selectors instead!\n    `, elements)\n  }\n\n  if (globalModified) {\n    delete global.document\n  }\n\n  return selector\n}\n\n/**\n * Get selectors to describe a set of elements\n *\n * @param  {Array.<HTMLElements>} elements - [description]\n * @return {string}                        - [description]\n */\nfunction getCommonSelectors (elements) {\n\n  const { classes, attributes, tag } = getCommonProperties(elements)\n\n  const selectorPath = []\n\n  if (tag) {\n    selectorPath.push(tag)\n  }\n\n  if (classes) {\n    const classSelector = classes.map((name) => `.${name}`).join('')\n    selectorPath.push(classSelector)\n  }\n\n  if (attributes) {\n    const attributeSelector = Object.keys(attributes).reduce((parts, name) => {\n      parts.push(`[${name}=\"${attributes[name]}\"]`)\n      return parts\n    }, []).join('')\n    selectorPath.push(attributeSelector)\n  }\n\n  if (selectorPath.length) {\n    // TODO: check for parent-child relation\n  }\n\n  return [\n    selectorPath.join('')\n  ]\n}\n\n/**\n * Choose action depending on the input (multiple/single)\n *\n * NOTE: extended detection is used for special cases like the <select> element with <options>\n *\n * @param  {HTMLElement|NodeList|Array.<HTMLElement>} input   - [description]\n * @param  {Object}                                   options - [description]\n * @return {string}                                           - [description]\n */\nexport default function getQuerySelector (input, options = {}) {\n  if (input.length && !input.name) {\n    return getMultiSelector(input, options)\n  }\n  return getSingleSelector(input, options)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/select.js","/*! https://mths.be/cssesc v3.0.0 by @mathias */\n'use strict';\n\nvar object = {};\nvar hasOwnProperty = object.hasOwnProperty;\nvar merge = function merge(options, defaults) {\n\tif (!options) {\n\t\treturn defaults;\n\t}\n\tvar result = {};\n\tfor (var key in defaults) {\n\t\t// `if (defaults.hasOwnProperty(key) { … }` is not needed here, since\n\t\t// only recognized option names are used.\n\t\tresult[key] = hasOwnProperty.call(options, key) ? options[key] : defaults[key];\n\t}\n\treturn result;\n};\n\nvar regexAnySingleEscape = /[ -,\\.\\/:-@\\[-\\^`\\{-~]/;\nvar regexSingleEscape = /[ -,\\.\\/:-@\\[\\]\\^`\\{-~]/;\nvar regexAlwaysEscape = /['\"\\\\]/;\nvar regexExcessiveSpaces = /(^|\\\\+)?(\\\\[A-F0-9]{1,6})\\x20(?![a-fA-F0-9\\x20])/g;\n\n// https://mathiasbynens.be/notes/css-escapes#css\nvar cssesc = function cssesc(string, options) {\n\toptions = merge(options, cssesc.options);\n\tif (options.quotes != 'single' && options.quotes != 'double') {\n\t\toptions.quotes = 'single';\n\t}\n\tvar quote = options.quotes == 'double' ? '\"' : '\\'';\n\tvar isIdentifier = options.isIdentifier;\n\n\tvar firstChar = string.charAt(0);\n\tvar output = '';\n\tvar counter = 0;\n\tvar length = string.length;\n\twhile (counter < length) {\n\t\tvar character = string.charAt(counter++);\n\t\tvar codePoint = character.charCodeAt();\n\t\tvar value = void 0;\n\t\t// If it’s not a printable ASCII character…\n\t\tif (codePoint < 0x20 || codePoint > 0x7E) {\n\t\t\tif (codePoint >= 0xD800 && codePoint <= 0xDBFF && counter < length) {\n\t\t\t\t// It’s a high surrogate, and there is a next character.\n\t\t\t\tvar extra = string.charCodeAt(counter++);\n\t\t\t\tif ((extra & 0xFC00) == 0xDC00) {\n\t\t\t\t\t// next character is low surrogate\n\t\t\t\t\tcodePoint = ((codePoint & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000;\n\t\t\t\t} else {\n\t\t\t\t\t// It’s an unmatched surrogate; only append this code unit, in case\n\t\t\t\t\t// the next code unit is the high surrogate of a surrogate pair.\n\t\t\t\t\tcounter--;\n\t\t\t\t}\n\t\t\t}\n\t\t\tvalue = '\\\\' + codePoint.toString(16).toUpperCase() + ' ';\n\t\t} else {\n\t\t\tif (options.escapeEverything) {\n\t\t\t\tif (regexAnySingleEscape.test(character)) {\n\t\t\t\t\tvalue = '\\\\' + character;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = '\\\\' + codePoint.toString(16).toUpperCase() + ' ';\n\t\t\t\t}\n\t\t\t} else if (/[\\t\\n\\f\\r\\x0B]/.test(character)) {\n\t\t\t\tvalue = '\\\\' + codePoint.toString(16).toUpperCase() + ' ';\n\t\t\t} else if (character == '\\\\' || !isIdentifier && (character == '\"' && quote == character || character == '\\'' && quote == character) || isIdentifier && regexSingleEscape.test(character)) {\n\t\t\t\tvalue = '\\\\' + character;\n\t\t\t} else {\n\t\t\t\tvalue = character;\n\t\t\t}\n\t\t}\n\t\toutput += value;\n\t}\n\n\tif (isIdentifier) {\n\t\tif (/^-[-\\d]/.test(output)) {\n\t\t\toutput = '\\\\-' + output.slice(1);\n\t\t} else if (/\\d/.test(firstChar)) {\n\t\t\toutput = '\\\\3' + firstChar + ' ' + output.slice(1);\n\t\t}\n\t}\n\n\t// Remove spaces after `\\HEX` escapes that are not followed by a hex digit,\n\t// since they’re redundant. Note that this is only possible if the escape\n\t// sequence isn’t preceded by an odd number of backslashes.\n\toutput = output.replace(regexExcessiveSpaces, function ($0, $1, $2) {\n\t\tif ($1 && $1.length % 2) {\n\t\t\t// It’s not safe to remove the space, so don’t.\n\t\t\treturn $0;\n\t\t}\n\t\t// Strip the space.\n\t\treturn ($1 || '') + $2;\n\t});\n\n\tif (!isIdentifier && options.wrap) {\n\t\treturn quote + output + quote;\n\t}\n\treturn output;\n};\n\n// Expose default options (so they can be overridden globally).\ncssesc.options = {\n\t'escapeEverything': false,\n\t'isIdentifier': false,\n\t'quotes': 'single',\n\t'wrap': false\n};\n\ncssesc.version = '3.0.0';\n\nmodule.exports = cssesc;\n\n\n\n// WEBPACK FOOTER //\n// ./~/cssesc/cssesc.js","export select, { getSingleSelector, getMultiSelector } from './select'\nexport optimize from './optimize'\nexport * as common from './common'\n\nexport default from './select'\n\n\n\n// WEBPACK FOOTER //\n// ./src/index.js","/**\n * # Match\n *\n * Retrieve selector for a node.\n */\n\nimport { escapeValue } from './utilities'\n\nconst defaultIgnore = {\n  attribute (attributeName) {\n    return [\n      'style',\n      'data-reactid',\n      'data-react-checksum'\n    ].indexOf(attributeName) > -1\n  }\n}\n\n/**\n * Get the path of the element\n *\n * @param  {HTMLElement} node    - [description]\n * @param  {Object}      options - [description]\n * @return {string}              - [description]\n */\nexport default function match (node, options) {\n\n  const {\n    root = document,\n    skip = null,\n    priority = ['id', 'class', 'href', 'src'],\n    ignore = {}\n  } = options\n\n  const path = []\n  var element = node\n  var length = path.length\n  var ignoreClass = false\n\n  const skipCompare = skip && (Array.isArray(skip) ? skip : [skip]).map((entry) => {\n    if (typeof entry !== 'function') {\n      return (element) => element === entry\n    }\n    return entry\n  })\n\n  const skipChecks = (element) => {\n    return skip && skipCompare.some((compare) => compare(element))\n  }\n\n  Object.keys(ignore).forEach((type) => {\n    if (type === 'class') {\n      ignoreClass = true\n    }\n    var predicate = ignore[type]\n    if (typeof predicate === 'function') return\n    if (typeof predicate === 'number') {\n      predicate = predicate.toString()\n    }\n    if (typeof predicate === 'string') {\n      predicate = new RegExp(escapeValue(predicate).replace(/\\\\/g, '\\\\\\\\'))\n    }\n    if (typeof predicate === 'boolean') {\n      predicate = predicate ? /(?:)/ : /.^/\n    }\n    // check class-/attributename for regex\n    ignore[type] = (name, value) => predicate.test(value)\n  })\n\n  if (ignoreClass) {\n    const ignoreAttribute = ignore.attribute\n    ignore.attribute = (name, value, defaultPredicate) => {\n      return ignore.class(value) || ignoreAttribute && ignoreAttribute(name, value, defaultPredicate)\n    }\n  }\n\n  while (element !== root) {\n    if (skipChecks(element) !== true) {\n      // ~ global\n      if (checkAttributes(priority, element, ignore, path, root)) break\n      if (checkTag(element, ignore, path, root)) break\n\n      // ~ local\n      checkAttributes(priority, element, ignore, path)\n      if (path.length === length) {\n        checkTag(element, ignore, path)\n      }\n\n      // define only one part each iteration\n      if (path.length === length) {\n        checkChilds(priority, element, ignore, path)\n      }\n    }\n\n    element = element.parentNode\n    length = path.length\n  }\n\n  if (element === root) {\n    const pattern = findPattern(priority, element, ignore)\n    path.unshift(pattern)\n  }\n\n  return path.join(' ')\n}\n\n/**\n * Extend path with attribute identifier\n *\n * @param  {Array.<string>} priority - [description]\n * @param  {HTMLElement}    element  - [description]\n * @param  {Object}         ignore   - [description]\n * @param  {Array.<string>} path     - [description]\n * @param  {HTMLElement}    parent   - [description]\n * @return {boolean}                 - [description]\n */\nfunction checkAttributes (priority, element, ignore, path, parent = element.parentNode) {\n  const pattern = findAttributesPattern(priority, element, ignore)\n  if (pattern) {\n    const matches = parent.querySelectorAll(pattern)\n    if (matches.length === 1) {\n      path.unshift(pattern)\n      return true\n    }\n  }\n  return false\n}\n\n/**\n * Lookup attribute identifier\n *\n * @param  {Array.<string>} priority - [description]\n * @param  {HTMLElement}    element  - [description]\n * @param  {Object}         ignore   - [description]\n * @return {string?}                 - [description]\n */\nfunction findAttributesPattern (priority, element, ignore) {\n  const attributes = element.attributes\n  const sortedKeys = Object.keys(attributes).sort((curr, next) => {\n    const currPos = priority.indexOf(attributes[curr].name)\n    const nextPos = priority.indexOf(attributes[next].name)\n    if (nextPos === -1) {\n      if (currPos === -1) {\n        return 0\n      }\n      return -1\n    }\n    if (currPos === -1) {\n      return 1\n    }\n    return currPos - nextPos;\n  })\n\n  for (var i = 0, l = sortedKeys.length; i < l; i++) {\n    const key = sortedKeys[i]\n    const attribute = attributes[key]\n    const attributeName = attribute.name\n    const attributeValue = escapeValue(attribute.value)\n\n    const currentIgnore = ignore[attributeName] || ignore.attribute\n    const currentDefaultIgnore = defaultIgnore[attributeName] || defaultIgnore.attribute\n    if (checkIgnore(currentIgnore, attributeName, attributeValue, currentDefaultIgnore)) {\n      continue\n    }\n\n    var pattern = `[${attributeName}=\"${attributeValue}\"]`\n\n    if (attributeName === 'id' && (/^[A-Za-z][-\\d\\w:,.]*$/).test(attributeValue)) {\n        pattern = `#${attributeValue}`\n    }\n\n    if (attributeName === 'class' && (/^[A-Za-z][-\\d\\w]*$/).test(attributeValue)) {\n      const className = attributeValue.trim().replace(/\\s+/g, '.')\n      pattern = `.${className}`\n    }\n\n    return pattern\n  }\n  return null\n}\n\n/**\n * Extend path with tag identifier\n *\n * @param  {HTMLElement}    element - [description]\n * @param  {Object}         ignore  - [description]\n * @param  {Array.<string>} path    - [description]\n * @param  {HTMLElement}    parent  - [description]\n * @return {boolean}                - [description]\n */\nfunction checkTag (element, ignore, path, parent = element.parentNode) {\n  const pattern = findTagPattern(element, ignore)\n  if (pattern) {\n    const matches = parent.getElementsByTagName(pattern)\n    if (matches.length === 1) {\n      path.unshift(pattern)\n      return true\n    }\n  }\n  return false\n}\n\n/**\n * Lookup tag identifier\n *\n * @param  {HTMLElement} element - [description]\n * @param  {Object}      ignore  - [description]\n * @return {boolean}             - [description]\n */\nfunction findTagPattern (element, ignore) {\n  const tagName = element.tagName.toLowerCase()\n  if (checkIgnore(ignore.tag, null, tagName)) {\n    return null\n  }\n  return tagName\n}\n\n/**\n * Extend path with specific child identifier\n *\n * NOTE: 'childTags' is a custom property to use as a view filter for tags using 'adapter.js'\n *\n * @param  {Array.<string>} priority - [description]\n * @param  {HTMLElement}    element  - [description]\n * @param  {Object}         ignore   - [description]\n * @param  {Array.<string>} path     - [description]\n * @return {boolean}                 - [description]\n */\nfunction checkChilds (priority, element, ignore, path) {\n  const parent = element.parentNode\n  const children = parent.childTags || parent.children\n  for (var i = 0, l = children.length; i < l; i++) {\n    const child = children[i]\n    if (child === element) {\n      const childPattern = findPattern(priority, child, ignore)\n      if (!childPattern) {\n        return console.warn(`\n          Element couldn\\'t be matched through strict ignore pattern!\n        `, child, ignore, childPattern)\n      }\n      const pattern = `> ${childPattern}:nth-child(${i+1})`\n      path.unshift(pattern)\n      return true\n    }\n  }\n  return false\n}\n\n/**\n * Lookup identifier\n *\n * @param  {Array.<string>} priority - [description]\n * @param  {HTMLElement}    element  - [description]\n * @param  {Object}         ignore   - [description]\n * @return {string}                  - [description]\n */\nfunction findPattern (priority, element, ignore) {\n  var pattern = findAttributesPattern(priority, element, ignore)\n  if (!pattern) {\n    pattern = findTagPattern(element, ignore)\n  }\n  return pattern\n}\n\n/**\n * Validate with custom and default functions\n *\n * @param  {Function} predicate        - [description]\n * @param  {string?}  name             - [description]\n * @param  {string}   value            - [description]\n * @param  {Function} defaultPredicate - [description]\n * @return {boolean}                   - [description]\n */\nfunction checkIgnore (predicate, name, value, defaultPredicate) {\n  if (!value) {\n    return true\n  }\n  const check = predicate || defaultPredicate\n  if (!check) {\n    return false\n  }\n  return check(name, value, defaultPredicate)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/match.js"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/optimal-select.min.js b/dist/optimal-select.min.js index baf4430..e10f51c 100644 --- a/dist/optimal-select.min.js +++ b/dist/optimal-select.min.js @@ -1,2 +1,2 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.OptimalSelect=t():e.OptimalSelect=t()}(this,function(){return function(e){function t(n){if(r[n])return r[n].exports;var o=r[n]={i:n,l:!1,exports:{}};return e[n].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var r={};return t.m=e,t.c=r,t.i=function(e){return e},t.d=function(e,r,n){t.o(e,r)||Object.defineProperty(e,r,{configurable:!1,enumerable:!0,get:n})},t.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(r,"a",r),r},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=6)}([function(e,t,r){"use strict";function n(e){for(var t=e.length,r=new Array(t),n=0;n@~]/g,"\\$&").replace(/\n/g,"A")}Object.defineProperty(t,"__esModule",{value:!0}),t.convertNodeList=n,t.escapeValue=o},function(e,t,r){"use strict";function n(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=t.root,n=void 0===r?document:r,o=[];e.forEach(function(e,t){for(var r=[];e!==n;)e=e.parentNode,r.unshift(e);o[t]=r}),o.sort(function(e,t){return e.length-t.length});for(var u=o.shift(),i=null,l=function(){var e=u[a],t=o.some(function(t){return!t.some(function(t){return t===e})});return t?"break":void(i=e)},a=0,c=u.length;a2&&void 0!==arguments[2]?arguments[2]:{};if(Array.isArray(t)||(t=t.length?(0,c.convertNodeList)(t):[t]),!t.length||t.some(function(e){return 1!==e.nodeType}))throw new Error('Invalid input - to compare HTMLElements its necessary to provide a reference of the selected node(s)! (missing "elements")');var n=(0,a.default)(t[0],r),o=e.replace(/> /g,">").split(/\s+(?=(?:(?:[^"]*"){2})*[^"]*$)/);if(o.length<2)return u("",e,"",t);for(var i=[o.pop()];o.length>1;){var l=o.pop(),f=o.join(" "),s=i.join(" "),d=f+" "+s,p=document.querySelectorAll(d);p.length!==t.length&&i.unshift(u(f,l,s,t))}return i.unshift(o[0]),o=i,o[0]=u("",o[0],o.slice(1).join(" "),t),o[o.length-1]=u(o.slice(0,-1).join(" "),o[o.length-1],"",t),n&&delete!0,o.join(" ").replace(/>/g,"> ").trim()}function u(e,t,r,n){if(e.length&&(e+=" "),r.length&&(r=" "+r),/\[*\]/.test(t)){var o=t.replace(/=.*$/,"]"),u=""+e+o+r,l=document.querySelectorAll(u);if(i(l,n))t=o;else for(var a=document.querySelectorAll(""+e+o),c=function(){var o=a[f];if(n.some(function(e){return o.contains(e)})){var c=o.tagName.toLowerCase();return u=""+e+c+r,l=document.querySelectorAll(u),i(l,n)&&(t=c),"break"}},f=0,s=a.length;f/.test(t)){var p=t.replace(/>/,""),u=""+e+p+r,l=document.querySelectorAll(u);i(l,n)&&(t=p)}if(/:nth-child/.test(t)){var v=t.replace(/nth-child/g,"nth-of-type"),u=""+e+v+r,l=document.querySelectorAll(u);i(l,n)&&(t=v)}if(/\.\S+\.\S+/.test(t)){for(var y=t.trim().split(".").slice(1).map(function(e){return"."+e}).sort(function(e,t){return e.length-t.length});y.length;){var g=t.replace(y.shift(),"").trim(),u=(""+e+g+r).trim();if(!u.length||">"===u.charAt(0)||">"===u.charAt(u.length-1))break;var l=document.querySelectorAll(u);i(l,n)&&(t=g)}if(y=t&&t.match(/\./g),y&&y.length>2)for(var m=document.querySelectorAll(""+e+t),h=function(){var o=m[f];if(n.some(function(e){return o.contains(e)})){var a=o.tagName.toLowerCase();return u=""+e+a+r,l=document.querySelectorAll(u),i(l,n)&&(t=a),"break"}},f=0,s=m.length;f1&&void 0!==arguments[1]?arguments[1]:{};if(3===e.nodeType&&(e=e.parentNode),1!==e.nodeType)throw new Error('Invalid input - only HTMLElements or representations of them are supported! (not "'+("undefined"==typeof e?"undefined":a(e))+'")');var r=(0,f.default)(e,t),n=(0,d.default)(e,t),o=(0,v.default)(n,e,t);return r&&delete!0,o}function u(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(Array.isArray(e)||(e=(0,y.convertNodeList)(e)),e.some(function(e){return 1!==e.nodeType}))throw new Error("Invalid input - only an Array of HTMLElements or representations of them is supported!");var r=(0,f.default)(e[0],t),n=(0,g.getCommonAncestor)(e,t),u=o(n,t),l=i(e),a=l[0],c=(0,v.default)(u+" "+a,e,t),s=(0,y.convertNodeList)(document.querySelectorAll(c));return e.every(function(e){return s.some(function(t){return t===e})})?(r&&delete!0,c):console.warn("\n The selected elements can't be efficiently mapped.\n Its probably best to use multiple single selectors instead!\n ",e)}function i(e){var t=(0,g.getCommonProperties)(e),r=t.classes,n=t.attributes,o=t.tag,u=[];if(o&&u.push(o),r){var i=r.map(function(e){return"."+e}).join("");u.push(i)}if(n){var l=Object.keys(n).reduce(function(e,t){return e.push("["+t+'="'+n[t]+'"]'),e},[]).join("");u.push(l)}return u.length,[u.join("")]}function l(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return e.length&&!e.name?u(e,t):o(e,t)}Object.defineProperty(t,"__esModule",{value:!0});var a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};t.getSingleSelector=o,t.getMultiSelector=u,t.default=l;var c=r(3),f=n(c),s=r(5),d=n(s),p=r(2),v=n(p),y=r(0),g=r(1)},function(e,t,r){"use strict";function n(e,t){var r=t.root,n=void 0===r?document:r,u=t.skip,l=void 0===u?null:u,f=t.priority,d=void 0===f?["id","class","href","src"]:f,p=t.ignore,v=void 0===p?{}:p,y=[],g=e,m=y.length,h=!1,b=l&&(Array.isArray(l)?l:[l]).map(function(e){return"function"!=typeof e?function(t){return t===e}:e}),S=function(e){return l&&b.some(function(t){return t(e)})};for(Object.keys(v).forEach(function(e){"class"===e&&(h=!0);var t=v[e];"function"!=typeof t&&("number"==typeof t&&(t=t.toString()),"string"==typeof t&&(t=new RegExp((0,s.escapeValue)(t).replace(/\\/g,"\\\\"))),"boolean"==typeof t&&(t=t?/(?:)/:/.^/),v[e]=function(e,r){return t.test(r)})}),h&&!function(){var e=v.attribute;v.attribute=function(t,r,n){return v.class(r)||e&&e(t,r,n)}}();g!==n;){if(S(g)!==!0){if(o(d,g,v,y,n))break;if(i(g,v,y,n))break;o(d,g,v,y),y.length===m&&i(g,v,y),y.length===m&&a(d,g,v,y)}g=g.parentNode,m=y.length}if(g===n){var j=c(d,g,v);y.unshift(j)}return y.join(" ")}function o(e,t,r,n){var o=arguments.length>4&&void 0!==arguments[4]?arguments[4]:t.parentNode,i=u(e,t,r);if(i){var l=o.querySelectorAll(i);if(1===l.length)return n.unshift(i),!0}return!1}function u(e,t,r){for(var n=t.attributes,o=Object.keys(n).sort(function(t,r){var o=e.indexOf(n[t].name),u=e.indexOf(n[r].name);return u===-1?o===-1?0:-1:o===-1?1:o-u}),u=0,i=o.length;u3&&void 0!==arguments[3]?arguments[3]:e.parentNode,o=l(e,t);if(o){var u=n.getElementsByTagName(o);if(1===u.length)return r.unshift(o),!0}return!1}function l(e,t){var r=e.tagName.toLowerCase();return f(t.tag,null,r)?null:r}function a(e,t,r,n){for(var o=t.parentNode,u=o.childTags||o.children,i=0,l=u.length;i-1}};e.exports=t.default},function(e,t,r){"use strict";function n(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&(t[r]=e[r]);return t.default=e,t}function o(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.default=t.common=t.optimize=t.getMultiSelector=t.getSingleSelector=t.select=void 0;var u=r(4);Object.defineProperty(t,"getSingleSelector",{enumerable:!0,get:function(){return u.getSingleSelector}}),Object.defineProperty(t,"getMultiSelector",{enumerable:!0,get:function(){return u.getMultiSelector}});var i=o(u),l=r(2),a=o(l),c=r(1),f=n(c);t.select=i.default,t.optimize=a.default,t.common=f,t.default=i.default}])}); +!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.OptimalSelect=t():e.OptimalSelect=t()}(this,function(){return function(e){function t(n){if(r[n])return r[n].exports;var o=r[n]={i:n,l:!1,exports:{}};return e[n].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var r={};return t.m=e,t.c=r,t.i=function(e){return e},t.d=function(e,r,n){t.o(e,r)||Object.defineProperty(e,r,{configurable:!1,enumerable:!0,get:n})},t.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(r,"a",r),r},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=6)}([function(e,t,r){"use strict";function n(e){for(var t=e.length,r=new Array(t),n=0;n1&&void 0!==arguments[1]?arguments[1]:{},r=t.root,n=void 0===r?document:r,o=[];e.forEach(function(e,t){for(var r=[];e!==n;)e=e.parentNode,r.unshift(e);o[t]=r}),o.sort(function(e,t){return e.length-t.length});for(var u=o.shift(),i=null,a=0,l=u.length;a2&&void 0!==arguments[2]?arguments[2]:{};if(Array.isArray(t)||(t=t.length?(0,l.convertNodeList)(t):[t]),!t.length||t.some(function(e){return 1!==e.nodeType}))throw new Error('Invalid input - to compare HTMLElements its necessary to provide a reference of the selected node(s)! (missing "elements")');var n=((0,a.default)(t[0],r),e.replace(/> /g,">").split(/\s+(?=(?:(?:[^"]*"){2})*[^"]*$)/));if(n.length<2)return o("",e,"",t);for(var u=[n.pop()];n.length>1;){var i=n.pop(),c=n.join(" "),f=u.join(" "),s=c+" "+f,d=[];try{d=document.querySelectorAll(s)}catch(e){}d.length!==t.length&&u.unshift(o(c,i,f,t))}return u.unshift(n[0]),n=u,n[0]=o("",n[0],n.slice(1).join(" "),t),n[n.length-1]=o(n.slice(0,-1).join(" "),n[n.length-1],"",t),n.join(" ").replace(/>/g,"> ").trim()}function o(e,t,r,n){if(e.length&&(e+=" "),r.length&&(r=" "+r),/\[*\]/.test(t)){var o=t.replace(/=.*$/,"]"),i=""+e+o+r,a=[];try{a=document.querySelectorAll(i)}catch(e){}if(u(a,n))t=o;else{var l=[];try{l=document.querySelectorAll(""+e+o)}catch(e){}for(var c=0,f=l.length;c/.test(t)){var s=t.replace(/>/,""),i=""+e+s+r,d=[];try{d=document.querySelectorAll(i)}catch(e){}u(d,n)&&(t=s)}if(/:nth-child/.test(t)){var v=t.replace(/nth-child/g,"nth-of-type"),i=""+e+v+r,p=[];try{p=document.querySelectorAll(i)}catch(e){}u(p,n)&&(t=v)}if(/\.\S+\.\S+/.test(t)){for(var h=t.trim().split(".").slice(1).map(function(e){return"."+e}).sort(function(e,t){return e.length-t.length});h.length;){var g=t.replace(h.shift(),"").trim();if(">"===g.charAt(0)||">"===g.charAt(g.length-1))break;var i=(""+e+g+r).trim();if(!i.length||">"===i.charAt(0)||">"===i.charAt(i.length-1))break;var y=[];try{y=document.querySelectorAll(i)}catch(e){}u(y,n)&&(t=g)}if((h=t&&t.match(/\./g))&&h.length>2){var m=[];try{m=document.querySelectorAll(""+e+t)}catch(e){}for(var c=0,f=m.length;c1&&void 0!==arguments[1]?arguments[1]:{};if(3===e.nodeType&&(e=e.parentNode),1!==e.nodeType)throw new Error('Invalid input - only HTMLElements or representations of them are supported! (not "'+(void 0===e?"undefined":l(e))+'")');var r=((0,f.default)(e,t),(0,d.default)(e,t));return(0,p.default)(r,e,t)}function u(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(Array.isArray(e)||(e=(0,h.convertNodeList)(e)),e.some(function(e){return 1!==e.nodeType}))throw new Error("Invalid input - only an Array of HTMLElements or representations of them is supported!");var r=((0,f.default)(e[0],t),(0,g.getCommonAncestor)(e,t)),n=o(r,t),u=i(e),a=u[0],l=(0,p.default)(n+" "+a,e,t),c=(0,h.convertNodeList)(document.querySelectorAll(l));return e.every(function(e){return c.some(function(t){return t===e})})?l:console.warn("\n The selected elements can't be efficiently mapped.\n Its probably best to use multiple single selectors instead!\n ",e)}function i(e){var t=(0,g.getCommonProperties)(e),r=t.classes,n=t.attributes,o=t.tag,u=[];if(o&&u.push(o),r){var i=r.map(function(e){return"."+e}).join("");u.push(i)}if(n){var a=Object.keys(n).reduce(function(e,t){return e.push("["+t+'="'+n[t]+'"]'),e},[]).join("");u.push(a)}return u.length,[u.join("")]}function a(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return e.length&&!e.name?u(e,t):o(e,t)}Object.defineProperty(t,"__esModule",{value:!0});var l="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};t.getSingleSelector=o,t.getMultiSelector=u,t.default=a;var c=r(3),f=n(c),s=r(7),d=n(s),v=r(2),p=n(v),h=r(0),g=r(1)},function(e,t,r){"use strict";var n={},o=n.hasOwnProperty,u=function(e,t){if(!e)return t;var r={};for(var n in t)r[n]=o.call(e,n)?e[n]:t[n];return r},i=/[ -,\.\/:-@\[-\^`\{-~]/,a=/[ -,\.\/:-@\[\]\^`\{-~]/,l=/(^|\\+)?(\\[A-F0-9]{1,6})\x20(?![a-fA-F0-9\x20])/g,c=function e(t,r){r=u(r,e.options),"single"!=r.quotes&&"double"!=r.quotes&&(r.quotes="single");for(var n="double"==r.quotes?'"':"'",o=r.isIdentifier,c=t.charAt(0),f="",s=0,d=t.length;s126){if(p>=55296&&p<=56319&&s4&&void 0!==arguments[4]?arguments[4]:t.parentNode,i=u(e,t,r);if(i){if(1===o.querySelectorAll(i).length)return n.unshift(i),!0}return!1}function u(e,t,r){for(var n=t.attributes,o=Object.keys(n).sort(function(t,r){var o=e.indexOf(n[t].name),u=e.indexOf(n[r].name);return-1===u?-1===o?0:-1:-1===o?1:o-u}),u=0,i=o.length;u3&&void 0!==arguments[3]?arguments[3]:e.parentNode,o=a(e,t);if(o){if(1===n.getElementsByTagName(o).length)return r.unshift(o),!0}return!1}function a(e,t){var r=e.tagName.toLowerCase();return f(t.tag,null,r)?null:r}function l(e,t,r,n){for(var o=t.parentNode,u=o.childTags||o.children,i=0,a=u.length;i-1}};e.exports=t.default}])}); //# sourceMappingURL=optimal-select.min.js.map \ No newline at end of file diff --git a/dist/optimal-select.min.js.map b/dist/optimal-select.min.js.map index ef873f5..4a9dd6c 100644 --- a/dist/optimal-select.min.js.map +++ b/dist/optimal-select.min.js.map @@ -1 +1 @@ -{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///optimal-select.min.js","webpack:///webpack/bootstrap 7a14bf1294f51172b93a","webpack:///./src/utilities.js","webpack:///./src/common.js","webpack:///./src/optimize.js","webpack:///./src/adapt.js","webpack:///./src/select.js","webpack:///./src/match.js","webpack:///./src/index.js"],"names":["root","factory","exports","module","define","amd","this","modules","__webpack_require__","moduleId","installedModules","i","l","call","m","c","value","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","object","property","prototype","hasOwnProperty","p","s","convertNodeList","nodes","length","arr","Array","escapeValue","replace","getCommonAncestor","elements","options","arguments","undefined","_options$root","document","ancestors","forEach","element","index","parents","parentNode","unshift","sort","curr","next","shallowAncestor","shift","ancestor","_loop","parent","missing","some","otherParents","otherParent","_ret","getCommonProperties","commonProperties","classes","attributes","tag","commonClasses","commonAttributes","commonTag","getAttribute","trim","split","filter","entry","elementAttributes","keys","reduce","key","attribute","attributeName","attributesNames","commonAttributesNames","nextCommonAttributes","tagName","toLowerCase","_interopRequireDefault","obj","default","optimize","selector","isArray","_utilities","nodeType","Error","globalModified","_adapt2","path","optimizePart","shortened","pop","current","prePart","join","postPart","pattern","matches","querySelectorAll","slice","test","compareResults","references","reference","contains","description","descendant","type","names","map","partial","charAt","match","_loop2","_ret2","every","_adapt","adapt","Symbol","iterator","constructor","sliceIterator","_arr","_n","_d","_e","_s","_i","done","push","err","TypeError","getSingleSelector","_typeof","_match2","optimized","_optimize2","getMultiSelector","_common","ancestorSelector","commonSelectors","getCommonSelectors","descendantSelector","selectorMatches","console","warn","_getCommonProperties","selectorPath","classSelector","attributeSelector","parts","getQuerySelector","input","_match","_optimize","node","_options$skip","skip","_options$priority","priority","_options$ignore","ignore","ignoreClass","skipCompare","skipChecks","compare","predicate","toString","RegExp","ignoreAttribute","defaultPredicate","class","checkAttributes","checkTag","checkChilds","findPattern","findAttributesPattern","sortedKeys","currPos","indexOf","nextPos","attributeValue","currentIgnore","currentDefaultIgnore","defaultIgnore","checkIgnore","className","findTagPattern","getElementsByTagName","children","childTags","child","childPattern","check","_interopRequireWildcard","newObj","common","select","_select2","_select3","_optimize3","_common2"],"mappings":"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","file":"optimal-select.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"OptimalSelect\"] = factory();\n\telse\n\t\troot[\"OptimalSelect\"] = factory();\n})(this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"OptimalSelect\"] = factory();\n\telse\n\t\troot[\"OptimalSelect\"] = factory();\n})(this, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// identity function for calling harmony imports with the correct context\n/******/ \t__webpack_require__.i = function(value) { return value; };\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 6);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.convertNodeList = convertNodeList;\nexports.escapeValue = escapeValue;\n/**\n * # Utilities\n *\n * Convenience helpers.\n */\n\n/**\n * Create an array with the DOM nodes of the list\n *\n * @param {NodeList} nodes - [description]\n * @return {Array.} - [description]\n */\nfunction convertNodeList(nodes) {\n var length = nodes.length;\n\n var arr = new Array(length);\n for (var i = 0; i < length; i++) {\n arr[i] = nodes[i];\n }\n return arr;\n}\n\n/**\n * Escape special characters and line breaks as a simplified version of 'CSS.escape()'\n *\n * Description of valid characters: https://mathiasbynens.be/notes/css-escapes\n *\n * @param {String?} value - [description]\n * @return {String} - [description]\n */\nfunction escapeValue(value) {\n return value && value.replace(/['\"`\\\\/:\\?&!#$%^()[\\]{|}*+;,.<=>@~]/g, '\\\\$&').replace(/\\n/g, '\\A');\n}\n\n/***/ },\n/* 1 */\n/***/ function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getCommonAncestor = getCommonAncestor;\nexports.getCommonProperties = getCommonProperties;\n/**\n * # Common\n *\n * Process collections for similarities.\n */\n\n/**\n * Find the last common ancestor of elements\n *\n * @param {Array.} elements - [description]\n * @return {HTMLElement} - [description]\n */\nfunction getCommonAncestor(elements) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var _options$root = options.root,\n root = _options$root === undefined ? document : _options$root;\n\n\n var ancestors = [];\n\n elements.forEach(function (element, index) {\n var parents = [];\n while (element !== root) {\n element = element.parentNode;\n parents.unshift(element);\n }\n ancestors[index] = parents;\n });\n\n ancestors.sort(function (curr, next) {\n return curr.length - next.length;\n });\n\n var shallowAncestor = ancestors.shift();\n\n var ancestor = null;\n\n var _loop = function _loop() {\n var parent = shallowAncestor[i];\n var missing = ancestors.some(function (otherParents) {\n return !otherParents.some(function (otherParent) {\n return otherParent === parent;\n });\n });\n\n if (missing) {\n // TODO: find similar sub-parents, not the top root, e.g. sharing a class selector\n return 'break';\n }\n\n ancestor = parent;\n };\n\n for (var i = 0, l = shallowAncestor.length; i < l; i++) {\n var _ret = _loop();\n\n if (_ret === 'break') break;\n }\n\n return ancestor;\n}\n\n/**\n * Get a set of common properties of elements\n *\n * @param {Array.} elements - [description]\n * @return {Object} - [description]\n */\nfunction getCommonProperties(elements) {\n\n var commonProperties = {\n classes: [],\n attributes: {},\n tag: null\n };\n\n elements.forEach(function (element) {\n var commonClasses = commonProperties.classes,\n commonAttributes = commonProperties.attributes,\n commonTag = commonProperties.tag;\n\n // ~ classes\n\n if (commonClasses !== undefined) {\n var classes = element.getAttribute('class');\n if (classes) {\n classes = classes.trim().split(' ');\n if (!commonClasses.length) {\n commonProperties.classes = classes;\n } else {\n commonClasses = commonClasses.filter(function (entry) {\n return classes.some(function (name) {\n return name === entry;\n });\n });\n if (commonClasses.length) {\n commonProperties.classes = commonClasses;\n } else {\n delete commonProperties.classes;\n }\n }\n } else {\n // TODO: restructure removal as 2x set / 2x delete, instead of modify always replacing with new collection\n delete commonProperties.classes;\n }\n }\n\n // ~ attributes\n if (commonAttributes !== undefined) {\n (function () {\n var elementAttributes = element.attributes;\n var attributes = Object.keys(elementAttributes).reduce(function (attributes, key) {\n var attribute = elementAttributes[key];\n var attributeName = attribute.name;\n // NOTE: workaround detection for non-standard phantomjs NamedNodeMap behaviour\n // (issue: https://github.com/ariya/phantomjs/issues/14634)\n if (attribute && attributeName !== 'class') {\n attributes[attributeName] = attribute.value;\n }\n return attributes;\n }, {});\n\n var attributesNames = Object.keys(attributes);\n var commonAttributesNames = Object.keys(commonAttributes);\n\n if (attributesNames.length) {\n if (!commonAttributesNames.length) {\n commonProperties.attributes = attributes;\n } else {\n commonAttributes = commonAttributesNames.reduce(function (nextCommonAttributes, name) {\n var value = commonAttributes[name];\n if (value === attributes[name]) {\n nextCommonAttributes[name] = value;\n }\n return nextCommonAttributes;\n }, {});\n if (Object.keys(commonAttributes).length) {\n commonProperties.attributes = commonAttributes;\n } else {\n delete commonProperties.attributes;\n }\n }\n } else {\n delete commonProperties.attributes;\n }\n })();\n }\n\n // ~ tag\n if (commonTag !== undefined) {\n var tag = element.tagName.toLowerCase();\n if (!commonTag) {\n commonProperties.tag = tag;\n } else if (tag !== commonTag) {\n delete commonProperties.tag;\n }\n }\n });\n\n return commonProperties;\n}\n\n/***/ },\n/* 2 */\n/***/ function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = optimize;\n\nvar _adapt = __webpack_require__(3);\n\nvar _adapt2 = _interopRequireDefault(_adapt);\n\nvar _utilities = __webpack_require__(0);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Apply different optimization techniques\n *\n * @param {string} selector - [description]\n * @param {HTMLElement|Array.} element - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\n/**\n * # Optimize\n *\n * 1.) Improve efficiency through shorter selectors by removing redundancy\n * 2.) Improve robustness through selector transformation\n */\n\nfunction optimize(selector, elements) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n\n // convert single entry and NodeList\n if (!Array.isArray(elements)) {\n elements = !elements.length ? [elements] : (0, _utilities.convertNodeList)(elements);\n }\n\n if (!elements.length || elements.some(function (element) {\n return element.nodeType !== 1;\n })) {\n throw new Error('Invalid input - to compare HTMLElements its necessary to provide a reference of the selected node(s)! (missing \"elements\")');\n }\n\n var globalModified = (0, _adapt2.default)(elements[0], options);\n\n // chunk parts outside of quotes (http://stackoverflow.com/a/25663729)\n var path = selector.replace(/> /g, '>').split(/\\s+(?=(?:(?:[^\"]*\"){2})*[^\"]*$)/);\n\n if (path.length < 2) {\n return optimizePart('', selector, '', elements);\n }\n\n var shortened = [path.pop()];\n while (path.length > 1) {\n var current = path.pop();\n var prePart = path.join(' ');\n var postPart = shortened.join(' ');\n\n var pattern = prePart + ' ' + postPart;\n var matches = document.querySelectorAll(pattern);\n if (matches.length !== elements.length) {\n shortened.unshift(optimizePart(prePart, current, postPart, elements));\n }\n }\n shortened.unshift(path[0]);\n path = shortened;\n\n // optimize start + end\n path[0] = optimizePart('', path[0], path.slice(1).join(' '), elements);\n path[path.length - 1] = optimizePart(path.slice(0, -1).join(' '), path[path.length - 1], '', elements);\n\n if (globalModified) {\n delete true;\n }\n\n return path.join(' ').replace(/>/g, '> ').trim();\n}\n\n/**\n * Improve a chunk of the selector\n *\n * @param {string} prePart - [description]\n * @param {string} current - [description]\n * @param {string} postPart - [description]\n * @param {Array.} elements - [description]\n * @return {string} - [description]\n */\nfunction optimizePart(prePart, current, postPart, elements) {\n if (prePart.length) prePart = prePart + ' ';\n if (postPart.length) postPart = ' ' + postPart;\n\n // robustness: attribute without value (generalization)\n if (/\\[*\\]/.test(current)) {\n var key = current.replace(/=.*$/, ']');\n var pattern = '' + prePart + key + postPart;\n var matches = document.querySelectorAll(pattern);\n if (compareResults(matches, elements)) {\n current = key;\n } else {\n // robustness: replace specific key-value with base tag (heuristic)\n var references = document.querySelectorAll('' + prePart + key);\n\n var _loop = function _loop() {\n var reference = references[i];\n if (elements.some(function (element) {\n return reference.contains(element);\n })) {\n var description = reference.tagName.toLowerCase();\n pattern = '' + prePart + description + postPart;\n matches = document.querySelectorAll(pattern);\n\n if (compareResults(matches, elements)) {\n current = description;\n }\n return 'break';\n }\n };\n\n for (var i = 0, l = references.length; i < l; i++) {\n var pattern;\n var matches;\n\n var _ret = _loop();\n\n if (_ret === 'break') break;\n }\n }\n }\n\n // robustness: descendant instead child (heuristic)\n if (/>/.test(current)) {\n var descendant = current.replace(/>/, '');\n var pattern = '' + prePart + descendant + postPart;\n var matches = document.querySelectorAll(pattern);\n if (compareResults(matches, elements)) {\n current = descendant;\n }\n }\n\n // robustness: 'nth-of-type' instead 'nth-child' (heuristic)\n if (/:nth-child/.test(current)) {\n // TODO: consider complete coverage of 'nth-of-type' replacement\n var type = current.replace(/nth-child/g, 'nth-of-type');\n var pattern = '' + prePart + type + postPart;\n var matches = document.querySelectorAll(pattern);\n if (compareResults(matches, elements)) {\n current = type;\n }\n }\n\n // efficiency: combinations of classname (partial permutations)\n if (/\\.\\S+\\.\\S+/.test(current)) {\n var names = current.trim().split('.').slice(1).map(function (name) {\n return '.' + name;\n }).sort(function (curr, next) {\n return curr.length - next.length;\n });\n while (names.length) {\n var partial = current.replace(names.shift(), '').trim();\n var pattern = ('' + prePart + partial + postPart).trim();\n if (!pattern.length || pattern.charAt(0) === '>' || pattern.charAt(pattern.length - 1) === '>') {\n break;\n }\n var matches = document.querySelectorAll(pattern);\n if (compareResults(matches, elements)) {\n current = partial;\n }\n }\n\n // robustness: degrade complex classname (heuristic)\n names = current && current.match(/\\./g);\n if (names && names.length > 2) {\n var _references = document.querySelectorAll('' + prePart + current);\n\n var _loop2 = function _loop2() {\n var reference = _references[i];\n if (elements.some(function (element) {\n return reference.contains(element);\n })) {\n // TODO:\n // - check using attributes + regard excludes\n var description = reference.tagName.toLowerCase();\n pattern = '' + prePart + description + postPart;\n matches = document.querySelectorAll(pattern);\n\n if (compareResults(matches, elements)) {\n current = description;\n }\n return 'break';\n }\n };\n\n for (var i = 0, l = _references.length; i < l; i++) {\n var pattern;\n var matches;\n\n var _ret2 = _loop2();\n\n if (_ret2 === 'break') break;\n }\n }\n }\n\n return current;\n}\n\n/**\n * Evaluate matches with expected elements\n *\n * @param {Array.} matches - [description]\n * @param {Array.} elements - [description]\n * @return {Boolean} - [description]\n */\nfunction compareResults(matches, elements) {\n var length = matches.length;\n\n return length === elements.length && elements.every(function (element) {\n for (var i = 0; i < length; i++) {\n if (matches[i] === element) {\n return true;\n }\n }\n return false;\n });\n}\nmodule.exports = exports['default'];\n\n/***/ },\n/* 3 */\n/***/ function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nexports.default = adapt;\n/**\n * # Adapt\n *\n * Check and extend the environment for universal usage.\n */\n\n/**\n * Modify the context based on the environment\n *\n * @param {HTMLELement} element - [description]\n * @param {Object} options - [description]\n * @return {boolean} - [description]\n */\nfunction adapt(element, options) {\n\n // detect environment setup\n if (true) {\n return false;\n } else {\n global.document = options.context || function () {\n var root = element;\n while (root.parent) {\n root = root.parent;\n }\n return root;\n }();\n }\n\n // https://github.com/fb55/domhandler/blob/master/index.js#L75\n var ElementPrototype = Object.getPrototypeOf(true);\n\n // alternative descriptor to access elements with filtering invalid elements (e.g. textnodes)\n if (!Object.getOwnPropertyDescriptor(ElementPrototype, 'childTags')) {\n Object.defineProperty(ElementPrototype, 'childTags', {\n enumerable: true,\n get: function get() {\n return this.children.filter(function (node) {\n // https://github.com/fb55/domelementtype/blob/master/index.js#L12\n return node.type === 'tag' || node.type === 'script' || node.type === 'style';\n });\n }\n });\n }\n\n if (!Object.getOwnPropertyDescriptor(ElementPrototype, 'attributes')) {\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/attributes\n // https://developer.mozilla.org/en-US/docs/Web/API/NamedNodeMap\n Object.defineProperty(ElementPrototype, 'attributes', {\n enumerable: true,\n get: function get() {\n var attribs = this.attribs;\n\n var attributesNames = Object.keys(attribs);\n var NamedNodeMap = attributesNames.reduce(function (attributes, attributeName, index) {\n attributes[index] = {\n name: attributeName,\n value: attribs[attributeName]\n };\n return attributes;\n }, {});\n Object.defineProperty(NamedNodeMap, 'length', {\n enumerable: false,\n configurable: false,\n value: attributesNames.length\n });\n return NamedNodeMap;\n }\n });\n }\n\n if (!ElementPrototype.getAttribute) {\n // https://docs.webplatform.org/wiki/dom/Element/getAttribute\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/getAttribute\n ElementPrototype.getAttribute = function (name) {\n return this.attribs[name] || null;\n };\n }\n\n if (!ElementPrototype.getElementsByTagName) {\n // https://docs.webplatform.org/wiki/dom/Document/getElementsByTagName\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/getElementsByTagName\n ElementPrototype.getElementsByTagName = function (tagName) {\n var HTMLCollection = [];\n traverseDescendants(this.childTags, function (descendant) {\n if (descendant.name === tagName || tagName === '*') {\n HTMLCollection.push(descendant);\n }\n });\n return HTMLCollection;\n };\n }\n\n if (!ElementPrototype.getElementsByClassName) {\n // https://docs.webplatform.org/wiki/dom/Document/getElementsByClassName\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/getElementsByClassName\n ElementPrototype.getElementsByClassName = function (className) {\n var names = className.trim().replace(/\\s+/g, ' ').split(' ');\n var HTMLCollection = [];\n traverseDescendants([this], function (descendant) {\n var descendantClassName = descendant.attribs.class;\n if (descendantClassName && names.every(function (name) {\n return descendantClassName.indexOf(name) > -1;\n })) {\n HTMLCollection.push(descendant);\n }\n });\n return HTMLCollection;\n };\n }\n\n if (!ElementPrototype.querySelectorAll) {\n // https://docs.webplatform.org/wiki/css/selectors_api/querySelectorAll\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/querySelectorAll\n ElementPrototype.querySelectorAll = function (selectors) {\n var _this = this;\n\n selectors = selectors.replace(/(>)(\\S)/g, '$1 $2').trim(); // add space for '>' selector\n\n // using right to left execution => https://github.com/fb55/css-select#how-does-it-work\n var instructions = getInstructions(selectors);\n var discover = instructions.shift();\n\n var total = instructions.length;\n return discover(this).filter(function (node) {\n var step = 0;\n while (step < total) {\n node = instructions[step](node, _this);\n if (!node) {\n // hierarchy doesn't match\n return false;\n }\n step += 1;\n }\n return true;\n });\n };\n }\n\n if (!ElementPrototype.contains) {\n // https://developer.mozilla.org/en-US/docs/Web/API/Node/contains\n ElementPrototype.contains = function (element) {\n var inclusive = false;\n traverseDescendants([this], function (descendant, done) {\n if (descendant === element) {\n inclusive = true;\n done();\n }\n });\n return inclusive;\n };\n }\n\n return true;\n}\n\n/**\n * Retrieve transformation steps\n *\n * @param {Array.} selectors - [description]\n * @return {Array.} - [description]\n */\nfunction getInstructions(selectors) {\n return selectors.split(' ').reverse().map(function (selector, step) {\n var discover = step === 0;\n\n var _selector$split = selector.split(':'),\n _selector$split2 = _slicedToArray(_selector$split, 2),\n type = _selector$split2[0],\n pseudo = _selector$split2[1];\n\n var validate = null;\n var instruction = null;\n\n (function () {\n switch (true) {\n\n // child: '>'\n case />/.test(type):\n instruction = function checkParent(node) {\n return function (validate) {\n return validate(node.parent) && node.parent;\n };\n };\n break;\n\n // class: '.'\n case /^\\./.test(type):\n var names = type.substr(1).split('.');\n validate = function validate(node) {\n var nodeClassName = node.attribs.class;\n return nodeClassName && names.every(function (name) {\n return nodeClassName.indexOf(name) > -1;\n });\n };\n instruction = function checkClass(node, root) {\n if (discover) {\n return node.getElementsByClassName(names.join(' '));\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n break;\n\n // attribute: '[key=\"value\"]'\n case /^\\[/.test(type):\n var _type$replace$split = type.replace(/\\[|\\]|\"/g, '').split('='),\n _type$replace$split2 = _slicedToArray(_type$replace$split, 2),\n attributeKey = _type$replace$split2[0],\n attributeValue = _type$replace$split2[1];\n\n validate = function validate(node) {\n var hasAttribute = Object.keys(node.attribs).indexOf(attributeKey) > -1;\n if (hasAttribute) {\n // regard optional attributeValue\n if (!attributeValue || node.attribs[attributeKey] === attributeValue) {\n return true;\n }\n }\n return false;\n };\n instruction = function checkAttribute(node, root) {\n if (discover) {\n var _ret2 = function () {\n var NodeList = [];\n traverseDescendants([node], function (descendant) {\n if (validate(descendant)) {\n NodeList.push(descendant);\n }\n });\n return {\n v: NodeList\n };\n }();\n\n if ((typeof _ret2 === 'undefined' ? 'undefined' : _typeof(_ret2)) === \"object\") return _ret2.v;\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n break;\n\n // id: '#'\n case /^#/.test(type):\n var id = type.substr(1);\n validate = function validate(node) {\n return node.attribs.id === id;\n };\n instruction = function checkId(node, root) {\n if (discover) {\n var _ret3 = function () {\n var NodeList = [];\n traverseDescendants([node], function (descendant, done) {\n if (validate(descendant)) {\n NodeList.push(descendant);\n done();\n }\n });\n return {\n v: NodeList\n };\n }();\n\n if ((typeof _ret3 === 'undefined' ? 'undefined' : _typeof(_ret3)) === \"object\") return _ret3.v;\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n break;\n\n // universal: '*'\n case /\\*/.test(type):\n validate = function validate(node) {\n return true;\n };\n instruction = function checkUniversal(node, root) {\n if (discover) {\n var _ret4 = function () {\n var NodeList = [];\n traverseDescendants([node], function (descendant) {\n return NodeList.push(descendant);\n });\n return {\n v: NodeList\n };\n }();\n\n if ((typeof _ret4 === 'undefined' ? 'undefined' : _typeof(_ret4)) === \"object\") return _ret4.v;\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n break;\n\n // tag: '...'\n default:\n validate = function validate(node) {\n return node.name === type;\n };\n instruction = function checkTag(node, root) {\n if (discover) {\n var _ret5 = function () {\n var NodeList = [];\n traverseDescendants([node], function (descendant) {\n if (validate(descendant)) {\n NodeList.push(descendant);\n }\n });\n return {\n v: NodeList\n };\n }();\n\n if ((typeof _ret5 === 'undefined' ? 'undefined' : _typeof(_ret5)) === \"object\") return _ret5.v;\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n }\n })();\n\n if (!pseudo) {\n return instruction;\n }\n\n var rule = pseudo.match(/-(child|type)\\((\\d+)\\)$/);\n var kind = rule[1];\n var index = parseInt(rule[2], 10) - 1;\n\n var validatePseudo = function validatePseudo(node) {\n if (node) {\n var compareSet = node.parent.childTags;\n if (kind === 'type') {\n compareSet = compareSet.filter(validate);\n }\n var nodeIndex = compareSet.findIndex(function (child) {\n return child === node;\n });\n if (nodeIndex === index) {\n return true;\n }\n }\n return false;\n };\n\n return function enhanceInstruction(node) {\n var match = instruction(node);\n if (discover) {\n return match.reduce(function (NodeList, matchedNode) {\n if (validatePseudo(matchedNode)) {\n NodeList.push(matchedNode);\n }\n return NodeList;\n }, []);\n }\n return validatePseudo(match) && match;\n };\n });\n}\n\n/**\n * Walking recursive to invoke callbacks\n *\n * @param {Array.} nodes - [description]\n * @param {Function} handler - [description]\n */\nfunction traverseDescendants(nodes, handler) {\n nodes.forEach(function (node) {\n var progress = true;\n handler(node, function () {\n return progress = false;\n });\n if (node.childTags && progress) {\n traverseDescendants(node.childTags, handler);\n }\n });\n}\n\n/**\n * Bubble up from bottom to top\n *\n * @param {HTMLELement} node - [description]\n * @param {HTMLELement} root - [description]\n * @param {Function} validate - [description]\n * @return {HTMLELement} - [description]\n */\nfunction getAncestor(node, root, validate) {\n while (node.parent) {\n node = node.parent;\n if (validate(node)) {\n return node;\n }\n if (node === root) {\n break;\n }\n }\n return null;\n}\nmodule.exports = exports['default'];\n\n/***/ },\n/* 4 */\n/***/ function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; /**\n * # Select\n *\n * Construct a unique CSS query selector to access the selected DOM element(s).\n * For longevity it applies different matching and optimization strategies.\n */\n\nexports.getSingleSelector = getSingleSelector;\nexports.getMultiSelector = getMultiSelector;\nexports.default = getQuerySelector;\n\nvar _adapt = __webpack_require__(3);\n\nvar _adapt2 = _interopRequireDefault(_adapt);\n\nvar _match = __webpack_require__(5);\n\nvar _match2 = _interopRequireDefault(_match);\n\nvar _optimize = __webpack_require__(2);\n\nvar _optimize2 = _interopRequireDefault(_optimize);\n\nvar _utilities = __webpack_require__(0);\n\nvar _common = __webpack_require__(1);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Get a selector for the provided element\n *\n * @param {HTMLElement} element - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\nfunction getSingleSelector(element) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n if (element.nodeType === 3) {\n element = element.parentNode;\n }\n\n if (element.nodeType !== 1) {\n throw new Error('Invalid input - only HTMLElements or representations of them are supported! (not \"' + (typeof element === 'undefined' ? 'undefined' : _typeof(element)) + '\")');\n }\n\n var globalModified = (0, _adapt2.default)(element, options);\n\n var selector = (0, _match2.default)(element, options);\n var optimized = (0, _optimize2.default)(selector, element, options);\n\n // debug\n // console.log(`\n // selector: ${selector}\n // optimized: ${optimized}\n // `)\n\n if (globalModified) {\n delete true;\n }\n\n return optimized;\n}\n\n/**\n * Get a selector to match multiple descendants from an ancestor\n *\n * @param {Array.|NodeList} elements - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\nfunction getMultiSelector(elements) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n if (!Array.isArray(elements)) {\n elements = (0, _utilities.convertNodeList)(elements);\n }\n\n if (elements.some(function (element) {\n return element.nodeType !== 1;\n })) {\n throw new Error('Invalid input - only an Array of HTMLElements or representations of them is supported!');\n }\n\n var globalModified = (0, _adapt2.default)(elements[0], options);\n\n var ancestor = (0, _common.getCommonAncestor)(elements, options);\n var ancestorSelector = getSingleSelector(ancestor, options);\n\n // TODO: consider usage of multiple selectors + parent-child relation + check for part redundancy\n var commonSelectors = getCommonSelectors(elements);\n var descendantSelector = commonSelectors[0];\n\n var selector = (0, _optimize2.default)(ancestorSelector + ' ' + descendantSelector, elements, options);\n var selectorMatches = (0, _utilities.convertNodeList)(document.querySelectorAll(selector));\n\n if (!elements.every(function (element) {\n return selectorMatches.some(function (entry) {\n return entry === element;\n });\n })) {\n // TODO: cluster matches to split into similar groups for sub selections\n return console.warn('\\n The selected elements can\\'t be efficiently mapped.\\n Its probably best to use multiple single selectors instead!\\n ', elements);\n }\n\n if (globalModified) {\n delete true;\n }\n\n return selector;\n}\n\n/**\n * Get selectors to describe a set of elements\n *\n * @param {Array.} elements - [description]\n * @return {string} - [description]\n */\nfunction getCommonSelectors(elements) {\n var _getCommonProperties = (0, _common.getCommonProperties)(elements),\n classes = _getCommonProperties.classes,\n attributes = _getCommonProperties.attributes,\n tag = _getCommonProperties.tag;\n\n var selectorPath = [];\n\n if (tag) {\n selectorPath.push(tag);\n }\n\n if (classes) {\n var classSelector = classes.map(function (name) {\n return '.' + name;\n }).join('');\n selectorPath.push(classSelector);\n }\n\n if (attributes) {\n var attributeSelector = Object.keys(attributes).reduce(function (parts, name) {\n parts.push('[' + name + '=\"' + attributes[name] + '\"]');\n return parts;\n }, []).join('');\n selectorPath.push(attributeSelector);\n }\n\n if (selectorPath.length) {\n // TODO: check for parent-child relation\n }\n\n return [selectorPath.join('')];\n}\n\n/**\n * Choose action depending on the input (multiple/single)\n *\n * NOTE: extended detection is used for special cases like the element with \n *\n * @param {HTMLElement|NodeList|Array.} input - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\nexport default function getQuerySelector (input, options = {}) {\n if (input.length && !input.name) {\n return getMultiSelector(input, options)\n }\n return getSingleSelector(input, options)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/select.js","/**\n * # Match\n *\n * Retrieve selector for a node.\n */\n\nimport { escapeValue } from './utilities'\n\nconst defaultIgnore = {\n attribute (attributeName) {\n return [\n 'style',\n 'data-reactid',\n 'data-react-checksum'\n ].indexOf(attributeName) > -1\n }\n}\n\n/**\n * Get the path of the element\n *\n * @param {HTMLElement} node - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\nexport default function match (node, options) {\n\n const {\n root = document,\n skip = null,\n priority = ['id', 'class', 'href', 'src'],\n ignore = {}\n } = options\n\n const path = []\n var element = node\n var length = path.length\n var ignoreClass = false\n\n const skipCompare = skip && (Array.isArray(skip) ? skip : [skip]).map((entry) => {\n if (typeof entry !== 'function') {\n return (element) => element === entry\n }\n return entry\n })\n\n const skipChecks = (element) => {\n return skip && skipCompare.some((compare) => compare(element))\n }\n\n Object.keys(ignore).forEach((type) => {\n if (type === 'class') {\n ignoreClass = true\n }\n var predicate = ignore[type]\n if (typeof predicate === 'function') return\n if (typeof predicate === 'number') {\n predicate = predicate.toString()\n }\n if (typeof predicate === 'string') {\n predicate = new RegExp(escapeValue(predicate).replace(/\\\\/g, '\\\\\\\\'))\n }\n if (typeof predicate === 'boolean') {\n predicate = predicate ? /(?:)/ : /.^/\n }\n // check class-/attributename for regex\n ignore[type] = (name, value) => predicate.test(value)\n })\n\n if (ignoreClass) {\n const ignoreAttribute = ignore.attribute\n ignore.attribute = (name, value, defaultPredicate) => {\n return ignore.class(value) || ignoreAttribute && ignoreAttribute(name, value, defaultPredicate)\n }\n }\n\n while (element !== root) {\n if (skipChecks(element) !== true) {\n // ~ global\n if (checkAttributes(priority, element, ignore, path, root)) break\n if (checkTag(element, ignore, path, root)) break\n\n // ~ local\n checkAttributes(priority, element, ignore, path)\n if (path.length === length) {\n checkTag(element, ignore, path)\n }\n\n // define only one part each iteration\n if (path.length === length) {\n checkChilds(priority, element, ignore, path)\n }\n }\n\n element = element.parentNode\n length = path.length\n }\n\n if (element === root) {\n const pattern = findPattern(priority, element, ignore)\n path.unshift(pattern)\n }\n\n return path.join(' ')\n}\n\n/**\n * Extend path with attribute identifier\n *\n * @param {Array.} priority - [description]\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @param {Array.} path - [description]\n * @param {HTMLElement} parent - [description]\n * @return {boolean} - [description]\n */\nfunction checkAttributes (priority, element, ignore, path, parent = element.parentNode) {\n const pattern = findAttributesPattern(priority, element, ignore)\n if (pattern) {\n const matches = parent.querySelectorAll(pattern)\n if (matches.length === 1) {\n path.unshift(pattern)\n return true\n }\n }\n return false\n}\n\n/**\n * Lookup attribute identifier\n *\n * @param {Array.} priority - [description]\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @return {string?} - [description]\n */\nfunction findAttributesPattern (priority, element, ignore) {\n const attributes = element.attributes\n const sortedKeys = Object.keys(attributes).sort((curr, next) => {\n const currPos = priority.indexOf(attributes[curr].name)\n const nextPos = priority.indexOf(attributes[next].name)\n if (nextPos === -1) {\n if (currPos === -1) {\n return 0\n }\n return -1\n }\n if (currPos === -1) {\n return 1\n }\n return currPos - nextPos;\n })\n\n for (var i = 0, l = sortedKeys.length; i < l; i++) {\n const key = sortedKeys[i]\n const attribute = attributes[key]\n const attributeName = attribute.name\n const attributeValue = escapeValue(attribute.value)\n\n const currentIgnore = ignore[attributeName] || ignore.attribute\n const currentDefaultIgnore = defaultIgnore[attributeName] || defaultIgnore.attribute\n if (checkIgnore(currentIgnore, attributeName, attributeValue, currentDefaultIgnore)) {\n continue\n }\n\n var pattern = `[${attributeName}=\"${attributeValue}\"]`\n\n if (attributeName === 'id' && (/^[A-Za-z][-\\d\\w:,.]*$/).test(attributeValue)) {\n pattern = `#${attributeValue}`\n }\n\n if (attributeName === 'class' && (/^[A-Za-z][-\\d\\w]*$/).test(attributeValue)) {\n const className = attributeValue.trim().replace(/\\s+/g, '.')\n pattern = `.${className}`\n }\n\n return pattern\n }\n return null\n}\n\n/**\n * Extend path with tag identifier\n *\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @param {Array.} path - [description]\n * @param {HTMLElement} parent - [description]\n * @return {boolean} - [description]\n */\nfunction checkTag (element, ignore, path, parent = element.parentNode) {\n const pattern = findTagPattern(element, ignore)\n if (pattern) {\n const matches = parent.getElementsByTagName(pattern)\n if (matches.length === 1) {\n path.unshift(pattern)\n return true\n }\n }\n return false\n}\n\n/**\n * Lookup tag identifier\n *\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @return {boolean} - [description]\n */\nfunction findTagPattern (element, ignore) {\n const tagName = element.tagName.toLowerCase()\n if (checkIgnore(ignore.tag, null, tagName)) {\n return null\n }\n return tagName\n}\n\n/**\n * Extend path with specific child identifier\n *\n * NOTE: 'childTags' is a custom property to use as a view filter for tags using 'adapter.js'\n *\n * @param {Array.} priority - [description]\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @param {Array.} path - [description]\n * @return {boolean} - [description]\n */\nfunction checkChilds (priority, element, ignore, path) {\n const parent = element.parentNode\n const children = parent.childTags || parent.children\n for (var i = 0, l = children.length; i < l; i++) {\n const child = children[i]\n if (child === element) {\n const childPattern = findPattern(priority, child, ignore)\n if (!childPattern) {\n return console.warn(`\n Element couldn\\'t be matched through strict ignore pattern!\n `, child, ignore, childPattern)\n }\n const pattern = `> ${childPattern}:nth-child(${i+1})`\n path.unshift(pattern)\n return true\n }\n }\n return false\n}\n\n/**\n * Lookup identifier\n *\n * @param {Array.} priority - [description]\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @return {string} - [description]\n */\nfunction findPattern (priority, element, ignore) {\n var pattern = findAttributesPattern(priority, element, ignore)\n if (!pattern) {\n pattern = findTagPattern(element, ignore)\n }\n return pattern\n}\n\n/**\n * Validate with custom and default functions\n *\n * @param {Function} predicate - [description]\n * @param {string?} name - [description]\n * @param {string} value - [description]\n * @param {Function} defaultPredicate - [description]\n * @return {boolean} - [description]\n */\nfunction checkIgnore (predicate, name, value, defaultPredicate) {\n if (!value) {\n return true\n }\n const check = predicate || defaultPredicate\n if (!check) {\n return false\n }\n return check(name, value, defaultPredicate)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/match.js","export select, { getSingleSelector, getMultiSelector } from './select'\nexport optimize from './optimize'\nexport * as common from './common'\n\nexport default from './select'\n\n\n\n// WEBPACK FOOTER //\n// ./src/index.js"],"sourceRoot":""} \ No newline at end of file +{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 9e56bb83f3630d81e1d9","webpack:///optimal-select.min.js","webpack:///./src/utilities.js","webpack:///./src/common.js","webpack:///./src/optimize.js","webpack:///./src/adapt.js","webpack:///./src/select.js","webpack:///./~/cssesc/cssesc.js","webpack:///./src/index.js","webpack:///./src/match.js"],"names":["root","factory","exports","module","define","amd","this","__webpack_require__","moduleId","installedModules","i","l","modules","call","m","c","value","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","object","property","prototype","hasOwnProperty","p","s","convertNodeList","nodes","length","arr","Array","escapeValue","cssesc","require","getCommonAncestor","elements","options","document","ancestors","forEach","element","index","parents","parentNode","unshift","sort","curr","next","shallowAncestor","shift","ancestor","parent","some","otherParents","otherParent","getCommonProperties","commonProperties","classes","attributes","tag","commonClasses","commonAttributes","commonTag","undefined","getAttribute","trim","split","filter","entry","elementAttributes","keys","reduce","key","attribute","attributeName","attributesNames","commonAttributesNames","nextCommonAttributes","tagName","toLowerCase","optimize","selector","isArray","nodeType","Error","path","replace","optimizePart","shortened","pop","current","prePart","join","postPart","pattern","matches","querySelectorAll","err","slice","test","compareResults","references","reference","contains","description","descendant","type","names","map","partial","charAt","match","every","default","_adapt2","obj","_adapt","adapt","sliceIterator","_arr","_n","_d","_e","_s","_i","Symbol","iterator","done","push","_interopRequireDefault","getSingleSelector","getMultiSelector","ancestorSelector","commonSelectors","getCommonSelectors","descendantSelector","selectorMatches","console","warn","selectorPath","classSelector","attributeSelector","parts","getQuerySelector","input","_typeof","constructor","_match2","_match","_optimize2","_optimize","merge","defaults","result","regexAnySingleEscape","regexSingleEscape","regexExcessiveSpaces","string","quotes","quote","isIdentifier","firstChar","output","counter","character","codePoint","charCodeAt","extra","toString","toUpperCase","escapeEverything","$0","$1","$2","wrap","version","common","select","_select2","_select3","_optimize3","_common2","_common","newObj","node","skip","priority","ignore","ignoreClass","skipCompare","predicate","RegExp","ignoreAttribute","defaultPredicate","class","compare","checkAttributes","checkTag","checkChilds","findPattern","findAttributesPattern","sortedKeys","currPos","indexOf","nextPos","attributeValue","checkIgnore","defaultIgnore","findTagPattern","getElementsByTagName","children","childTags","child","childPattern","check"],"mappings":"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","file":"optimal-select.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"OptimalSelect\"] = factory();\n\telse\n\t\troot[\"OptimalSelect\"] = factory();\n})(this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 6);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 9e56bb83f3630d81e1d9","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"OptimalSelect\"] = factory();\n\telse\n\t\troot[\"OptimalSelect\"] = factory();\n})(this, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// identity function for calling harmony imports with the correct context\n/******/ \t__webpack_require__.i = function(value) { return value; };\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 6);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.convertNodeList = convertNodeList;\nexports.escapeValue = escapeValue;\n/**\n * # Utilities\n *\n * Convenience helpers.\n */\n\nvar cssesc = __webpack_require__(5);\n\n/**\n * Create an array with the DOM nodes of the list\n *\n * @param {NodeList} nodes - [description]\n * @return {Array.} - [description]\n */\nfunction convertNodeList(nodes) {\n var length = nodes.length;\n\n var arr = new Array(length);\n for (var i = 0; i < length; i++) {\n arr[i] = nodes[i];\n }\n return arr;\n}\n\n/**\n * Escape special characters and line breaks as a simplified version of 'CSS.escape()'\n *\n * Description of valid characters: https://mathiasbynens.be/notes/css-escapes\n *\n * @param {String?} value - [description]\n * @return {String} - [description]\n */\nfunction escapeValue(value) {\n return value && cssesc(value);\n}\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getCommonAncestor = getCommonAncestor;\nexports.getCommonProperties = getCommonProperties;\n/**\n * # Common\n *\n * Process collections for similarities.\n */\n\n/**\n * Find the last common ancestor of elements\n *\n * @param {Array.} elements - [description]\n * @return {HTMLElement} - [description]\n */\nfunction getCommonAncestor(elements) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var _options$root = options.root,\n root = _options$root === undefined ? document : _options$root;\n\n\n var ancestors = [];\n\n elements.forEach(function (element, index) {\n var parents = [];\n while (element !== root) {\n element = element.parentNode;\n parents.unshift(element);\n }\n ancestors[index] = parents;\n });\n\n ancestors.sort(function (curr, next) {\n return curr.length - next.length;\n });\n\n var shallowAncestor = ancestors.shift();\n\n var ancestor = null;\n\n var _loop = function _loop() {\n var parent = shallowAncestor[i];\n var missing = ancestors.some(function (otherParents) {\n return !otherParents.some(function (otherParent) {\n return otherParent === parent;\n });\n });\n\n if (missing) {\n // TODO: find similar sub-parents, not the top root, e.g. sharing a class selector\n return 'break';\n }\n\n ancestor = parent;\n };\n\n for (var i = 0, l = shallowAncestor.length; i < l; i++) {\n var _ret = _loop();\n\n if (_ret === 'break') break;\n }\n\n return ancestor;\n}\n\n/**\n * Get a set of common properties of elements\n *\n * @param {Array.} elements - [description]\n * @return {Object} - [description]\n */\nfunction getCommonProperties(elements) {\n\n var commonProperties = {\n classes: [],\n attributes: {},\n tag: null\n };\n\n elements.forEach(function (element) {\n var commonClasses = commonProperties.classes,\n commonAttributes = commonProperties.attributes,\n commonTag = commonProperties.tag;\n\n // ~ classes\n\n if (commonClasses !== undefined) {\n var classes = element.getAttribute('class');\n if (classes) {\n classes = classes.trim().split(' ');\n if (!commonClasses.length) {\n commonProperties.classes = classes;\n } else {\n commonClasses = commonClasses.filter(function (entry) {\n return classes.some(function (name) {\n return name === entry;\n });\n });\n if (commonClasses.length) {\n commonProperties.classes = commonClasses;\n } else {\n delete commonProperties.classes;\n }\n }\n } else {\n // TODO: restructure removal as 2x set / 2x delete, instead of modify always replacing with new collection\n delete commonProperties.classes;\n }\n }\n\n // ~ attributes\n if (commonAttributes !== undefined) {\n var elementAttributes = element.attributes;\n var attributes = Object.keys(elementAttributes).reduce(function (attributes, key) {\n var attribute = elementAttributes[key];\n var attributeName = attribute.name;\n // NOTE: workaround detection for non-standard phantomjs NamedNodeMap behaviour\n // (issue: https://github.com/ariya/phantomjs/issues/14634)\n if (attribute && attributeName !== 'class') {\n attributes[attributeName] = attribute.value;\n }\n return attributes;\n }, {});\n\n var attributesNames = Object.keys(attributes);\n var commonAttributesNames = Object.keys(commonAttributes);\n\n if (attributesNames.length) {\n if (!commonAttributesNames.length) {\n commonProperties.attributes = attributes;\n } else {\n commonAttributes = commonAttributesNames.reduce(function (nextCommonAttributes, name) {\n var value = commonAttributes[name];\n if (value === attributes[name]) {\n nextCommonAttributes[name] = value;\n }\n return nextCommonAttributes;\n }, {});\n if (Object.keys(commonAttributes).length) {\n commonProperties.attributes = commonAttributes;\n } else {\n delete commonProperties.attributes;\n }\n }\n } else {\n delete commonProperties.attributes;\n }\n }\n\n // ~ tag\n if (commonTag !== undefined) {\n var tag = element.tagName.toLowerCase();\n if (!commonTag) {\n commonProperties.tag = tag;\n } else if (tag !== commonTag) {\n delete commonProperties.tag;\n }\n }\n });\n\n return commonProperties;\n}\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = optimize;\n\nvar _adapt = __webpack_require__(3);\n\nvar _adapt2 = _interopRequireDefault(_adapt);\n\nvar _utilities = __webpack_require__(0);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Apply different optimization techniques\n *\n * @param {string} selector - [description]\n * @param {HTMLElement|Array.} element - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\n/**\n * # Optimize\n *\n * 1.) Improve efficiency through shorter selectors by removing redundancy\n * 2.) Improve robustness through selector transformation\n */\n\nfunction optimize(selector, elements) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n\n // convert single entry and NodeList\n if (!Array.isArray(elements)) {\n elements = !elements.length ? [elements] : (0, _utilities.convertNodeList)(elements);\n }\n\n if (!elements.length || elements.some(function (element) {\n return element.nodeType !== 1;\n })) {\n throw new Error('Invalid input - to compare HTMLElements its necessary to provide a reference of the selected node(s)! (missing \"elements\")');\n }\n\n var globalModified = (0, _adapt2.default)(elements[0], options);\n\n // chunk parts outside of quotes (http://stackoverflow.com/a/25663729)\n var path = selector.replace(/> /g, '>').split(/\\s+(?=(?:(?:[^\"]*\"){2})*[^\"]*$)/);\n\n if (path.length < 2) {\n return optimizePart('', selector, '', elements);\n }\n\n var shortened = [path.pop()];\n while (path.length > 1) {\n var current = path.pop();\n var prePart = path.join(' ');\n var postPart = shortened.join(' ');\n\n var pattern = prePart + ' ' + postPart;\n var matches = [];\n try {\n matches = document.querySelectorAll(pattern);\n } catch (err) {\n //\n }\n if (matches.length !== elements.length) {\n shortened.unshift(optimizePart(prePart, current, postPart, elements));\n }\n }\n shortened.unshift(path[0]);\n path = shortened;\n\n // optimize start + end\n path[0] = optimizePart('', path[0], path.slice(1).join(' '), elements);\n path[path.length - 1] = optimizePart(path.slice(0, -1).join(' '), path[path.length - 1], '', elements);\n\n if (globalModified) {\n delete true;\n }\n\n return path.join(' ').replace(/>/g, '> ').trim();\n}\n\n/**\n * Improve a chunk of the selector\n *\n * @param {string} prePart - [description]\n * @param {string} current - [description]\n * @param {string} postPart - [description]\n * @param {Array.} elements - [description]\n * @return {string} - [description]\n */\nfunction optimizePart(prePart, current, postPart, elements) {\n if (prePart.length) prePart = prePart + ' ';\n if (postPart.length) postPart = ' ' + postPart;\n\n // robustness: attribute without value (generalization)\n if (/\\[*\\]/.test(current)) {\n var key = current.replace(/=.*$/, ']');\n var pattern = '' + prePart + key + postPart;\n var matches = [];\n try {\n matches = document.querySelectorAll(pattern);\n } catch (err) {\n //\n }\n if (compareResults(matches, elements)) {\n current = key;\n } else {\n // robustness: replace specific key-value with base tag (heuristic)\n var references = [];\n try {\n references = document.querySelectorAll('' + prePart + key);\n } catch (err) {\n //\n }\n\n var _loop = function _loop() {\n var reference = references[i];\n if (elements.some(function (element) {\n return reference.contains(element);\n })) {\n var description = reference.tagName.toLowerCase();\n pattern = '' + prePart + description + postPart;\n\n var _matches = [];\n try {\n _matches = document.querySelectorAll(pattern);\n } catch (err) {\n //\n }\n if (compareResults(_matches, elements)) {\n current = description;\n }\n return 'break';\n }\n };\n\n for (var i = 0, l = references.length; i < l; i++) {\n var pattern;\n\n var _ret = _loop();\n\n if (_ret === 'break') break;\n }\n }\n }\n\n // robustness: descendant instead child (heuristic)\n if (/>/.test(current)) {\n var descendant = current.replace(/>/, '');\n var pattern = '' + prePart + descendant + postPart;\n var _matches2 = [];\n try {\n _matches2 = document.querySelectorAll(pattern);\n } catch (err) {\n //\n }\n if (compareResults(_matches2, elements)) {\n current = descendant;\n }\n }\n\n // robustness: 'nth-of-type' instead 'nth-child' (heuristic)\n if (/:nth-child/.test(current)) {\n // TODO: consider complete coverage of 'nth-of-type' replacement\n var type = current.replace(/nth-child/g, 'nth-of-type');\n var pattern = '' + prePart + type + postPart;\n var _matches3 = [];\n try {\n _matches3 = document.querySelectorAll(pattern);\n } catch (err) {\n //\n }\n if (compareResults(_matches3, elements)) {\n current = type;\n }\n }\n\n // efficiency: combinations of classname (partial permutations)\n if (/\\.\\S+\\.\\S+/.test(current)) {\n var names = current.trim().split('.').slice(1).map(function (name) {\n return '.' + name;\n }).sort(function (curr, next) {\n return curr.length - next.length;\n });\n while (names.length) {\n var partial = current.replace(names.shift(), '').trim();\n if (partial.charAt(0) === '>' || partial.charAt(partial.length - 1) === '>') {\n break;\n }\n var pattern = ('' + prePart + partial + postPart).trim();\n if (!pattern.length || pattern.charAt(0) === '>' || pattern.charAt(pattern.length - 1) === '>') {\n break;\n }\n var _matches4 = [];\n\n try {\n _matches4 = document.querySelectorAll(pattern);\n } catch (err) {\n //\n }\n if (compareResults(_matches4, elements)) {\n current = partial;\n }\n }\n\n // robustness: degrade complex classname (heuristic)\n names = current && current.match(/\\./g);\n if (names && names.length > 2) {\n var _references = [];\n try {\n _references = document.querySelectorAll('' + prePart + current);\n } catch (err) {\n //\n }\n\n var _loop2 = function _loop2() {\n var reference = _references[i];\n if (elements.some(function (element) {\n return reference.contains(element);\n })) {\n // TODO:\n // - check using attributes + regard excludes\n var description = reference.tagName.toLowerCase();\n pattern = '' + prePart + description + postPart;\n\n var _matches5 = [];\n try {\n _matches5 = document.querySelectorAll(pattern);\n } catch (err) {\n //\n }\n if (compareResults(_matches5, elements)) {\n current = description;\n }\n return 'break';\n }\n };\n\n for (var i = 0, l = _references.length; i < l; i++) {\n var pattern;\n\n var _ret2 = _loop2();\n\n if (_ret2 === 'break') break;\n }\n }\n }\n\n return current;\n}\n\n/**\n * Evaluate matches with expected elements\n *\n * @param {Array.} matches - [description]\n * @param {Array.} elements - [description]\n * @return {Boolean} - [description]\n */\nfunction compareResults(matches, elements) {\n var length = matches.length;\n\n return length === elements.length && elements.every(function (element) {\n for (var i = 0; i < length; i++) {\n if (matches[i] === element) {\n return true;\n }\n }\n return false;\n });\n}\nmodule.exports = exports['default'];\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nexports.default = adapt;\n/**\n * # Adapt\n *\n * Check and extend the environment for universal usage.\n */\n\n/**\n * Modify the context based on the environment\n *\n * @param {HTMLELement} element - [description]\n * @param {Object} options - [description]\n * @return {boolean} - [description]\n */\nfunction adapt(element, options) {\n\n // detect environment setup\n if (true) {\n return false;\n } else {\n global.document = options.context || function () {\n var root = element;\n while (root.parent) {\n root = root.parent;\n }\n return root;\n }();\n }\n\n // https://github.com/fb55/domhandler/blob/master/index.js#L75\n var ElementPrototype = Object.getPrototypeOf(true);\n\n // alternative descriptor to access elements with filtering invalid elements (e.g. textnodes)\n if (!Object.getOwnPropertyDescriptor(ElementPrototype, 'childTags')) {\n Object.defineProperty(ElementPrototype, 'childTags', {\n enumerable: true,\n get: function get() {\n return this.children.filter(function (node) {\n // https://github.com/fb55/domelementtype/blob/master/index.js#L12\n return node.type === 'tag' || node.type === 'script' || node.type === 'style';\n });\n }\n });\n }\n\n if (!Object.getOwnPropertyDescriptor(ElementPrototype, 'attributes')) {\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/attributes\n // https://developer.mozilla.org/en-US/docs/Web/API/NamedNodeMap\n Object.defineProperty(ElementPrototype, 'attributes', {\n enumerable: true,\n get: function get() {\n var attribs = this.attribs;\n\n var attributesNames = Object.keys(attribs);\n var NamedNodeMap = attributesNames.reduce(function (attributes, attributeName, index) {\n attributes[index] = {\n name: attributeName,\n value: attribs[attributeName]\n };\n return attributes;\n }, {});\n Object.defineProperty(NamedNodeMap, 'length', {\n enumerable: false,\n configurable: false,\n value: attributesNames.length\n });\n return NamedNodeMap;\n }\n });\n }\n\n if (!ElementPrototype.getAttribute) {\n // https://docs.webplatform.org/wiki/dom/Element/getAttribute\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/getAttribute\n ElementPrototype.getAttribute = function (name) {\n return this.attribs[name] || null;\n };\n }\n\n if (!ElementPrototype.getElementsByTagName) {\n // https://docs.webplatform.org/wiki/dom/Document/getElementsByTagName\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/getElementsByTagName\n ElementPrototype.getElementsByTagName = function (tagName) {\n var HTMLCollection = [];\n traverseDescendants(this.childTags, function (descendant) {\n if (descendant.name === tagName || tagName === '*') {\n HTMLCollection.push(descendant);\n }\n });\n return HTMLCollection;\n };\n }\n\n if (!ElementPrototype.getElementsByClassName) {\n // https://docs.webplatform.org/wiki/dom/Document/getElementsByClassName\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/getElementsByClassName\n ElementPrototype.getElementsByClassName = function (className) {\n var names = className.trim().replace(/\\s+/g, ' ').split(' ');\n var HTMLCollection = [];\n traverseDescendants([this], function (descendant) {\n var descendantClassName = descendant.attribs.class;\n if (descendantClassName && names.every(function (name) {\n return descendantClassName.indexOf(name) > -1;\n })) {\n HTMLCollection.push(descendant);\n }\n });\n return HTMLCollection;\n };\n }\n\n if (!ElementPrototype.querySelectorAll) {\n // https://docs.webplatform.org/wiki/css/selectors_api/querySelectorAll\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/querySelectorAll\n ElementPrototype.querySelectorAll = function (selectors) {\n var _this = this;\n\n selectors = selectors.replace(/(>)(\\S)/g, '$1 $2').trim(); // add space for '>' selector\n\n // using right to left execution => https://github.com/fb55/css-select#how-does-it-work\n var instructions = getInstructions(selectors);\n var discover = instructions.shift();\n\n var total = instructions.length;\n return discover(this).filter(function (node) {\n var step = 0;\n while (step < total) {\n node = instructions[step](node, _this);\n if (!node) {\n // hierarchy doesn't match\n return false;\n }\n step += 1;\n }\n return true;\n });\n };\n }\n\n if (!ElementPrototype.contains) {\n // https://developer.mozilla.org/en-US/docs/Web/API/Node/contains\n ElementPrototype.contains = function (element) {\n var inclusive = false;\n traverseDescendants([this], function (descendant, done) {\n if (descendant === element) {\n inclusive = true;\n done();\n }\n });\n return inclusive;\n };\n }\n\n return true;\n}\n\n/**\n * Retrieve transformation steps\n *\n * @param {Array.} selectors - [description]\n * @return {Array.} - [description]\n */\nfunction getInstructions(selectors) {\n return selectors.split(' ').reverse().map(function (selector, step) {\n var discover = step === 0;\n\n var _selector$split = selector.split(':'),\n _selector$split2 = _slicedToArray(_selector$split, 2),\n type = _selector$split2[0],\n pseudo = _selector$split2[1];\n\n var validate = null;\n var instruction = null;\n\n switch (true) {\n\n // child: '>'\n case />/.test(type):\n instruction = function checkParent(node) {\n return function (validate) {\n return validate(node.parent) && node.parent;\n };\n };\n break;\n\n // class: '.'\n case /^\\./.test(type):\n var names = type.substr(1).split('.');\n validate = function validate(node) {\n var nodeClassName = node.attribs.class;\n return nodeClassName && names.every(function (name) {\n return nodeClassName.indexOf(name) > -1;\n });\n };\n instruction = function checkClass(node, root) {\n if (discover) {\n return node.getElementsByClassName(names.join(' '));\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n break;\n\n // attribute: '[key=\"value\"]'\n case /^\\[/.test(type):\n var _type$replace$split = type.replace(/\\[|\\]|\"/g, '').split('='),\n _type$replace$split2 = _slicedToArray(_type$replace$split, 2),\n attributeKey = _type$replace$split2[0],\n attributeValue = _type$replace$split2[1];\n\n validate = function validate(node) {\n var hasAttribute = Object.keys(node.attribs).indexOf(attributeKey) > -1;\n if (hasAttribute) {\n // regard optional attributeValue\n if (!attributeValue || node.attribs[attributeKey] === attributeValue) {\n return true;\n }\n }\n return false;\n };\n instruction = function checkAttribute(node, root) {\n if (discover) {\n var NodeList = [];\n traverseDescendants([node], function (descendant) {\n if (validate(descendant)) {\n NodeList.push(descendant);\n }\n });\n return NodeList;\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n break;\n\n // id: '#'\n case /^#/.test(type):\n var id = type.substr(1);\n validate = function validate(node) {\n return node.attribs.id === id;\n };\n instruction = function checkId(node, root) {\n if (discover) {\n var NodeList = [];\n traverseDescendants([node], function (descendant, done) {\n if (validate(descendant)) {\n NodeList.push(descendant);\n done();\n }\n });\n return NodeList;\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n break;\n\n // universal: '*'\n case /\\*/.test(type):\n validate = function validate(node) {\n return true;\n };\n instruction = function checkUniversal(node, root) {\n if (discover) {\n var NodeList = [];\n traverseDescendants([node], function (descendant) {\n return NodeList.push(descendant);\n });\n return NodeList;\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n break;\n\n // tag: '...'\n default:\n validate = function validate(node) {\n return node.name === type;\n };\n instruction = function checkTag(node, root) {\n if (discover) {\n var NodeList = [];\n traverseDescendants([node], function (descendant) {\n if (validate(descendant)) {\n NodeList.push(descendant);\n }\n });\n return NodeList;\n }\n return typeof node === 'function' ? node(validate) : getAncestor(node, root, validate);\n };\n }\n\n if (!pseudo) {\n return instruction;\n }\n\n var rule = pseudo.match(/-(child|type)\\((\\d+)\\)$/);\n var kind = rule[1];\n var index = parseInt(rule[2], 10) - 1;\n\n var validatePseudo = function validatePseudo(node) {\n if (node) {\n var compareSet = node.parent.childTags;\n if (kind === 'type') {\n compareSet = compareSet.filter(validate);\n }\n var nodeIndex = compareSet.findIndex(function (child) {\n return child === node;\n });\n if (nodeIndex === index) {\n return true;\n }\n }\n return false;\n };\n\n return function enhanceInstruction(node) {\n var match = instruction(node);\n if (discover) {\n return match.reduce(function (NodeList, matchedNode) {\n if (validatePseudo(matchedNode)) {\n NodeList.push(matchedNode);\n }\n return NodeList;\n }, []);\n }\n return validatePseudo(match) && match;\n };\n });\n}\n\n/**\n * Walking recursive to invoke callbacks\n *\n * @param {Array.} nodes - [description]\n * @param {Function} handler - [description]\n */\nfunction traverseDescendants(nodes, handler) {\n nodes.forEach(function (node) {\n var progress = true;\n handler(node, function () {\n return progress = false;\n });\n if (node.childTags && progress) {\n traverseDescendants(node.childTags, handler);\n }\n });\n}\n\n/**\n * Bubble up from bottom to top\n *\n * @param {HTMLELement} node - [description]\n * @param {HTMLELement} root - [description]\n * @param {Function} validate - [description]\n * @return {HTMLELement} - [description]\n */\nfunction getAncestor(node, root, validate) {\n while (node.parent) {\n node = node.parent;\n if (validate(node)) {\n return node;\n }\n if (node === root) {\n break;\n }\n }\n return null;\n}\nmodule.exports = exports['default'];\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; /**\n * # Select\n *\n * Construct a unique CSS query selector to access the selected DOM element(s).\n * For longevity it applies different matching and optimization strategies.\n */\n\nexports.getSingleSelector = getSingleSelector;\nexports.getMultiSelector = getMultiSelector;\nexports.default = getQuerySelector;\n\nvar _adapt = __webpack_require__(3);\n\nvar _adapt2 = _interopRequireDefault(_adapt);\n\nvar _match = __webpack_require__(7);\n\nvar _match2 = _interopRequireDefault(_match);\n\nvar _optimize = __webpack_require__(2);\n\nvar _optimize2 = _interopRequireDefault(_optimize);\n\nvar _utilities = __webpack_require__(0);\n\nvar _common = __webpack_require__(1);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Get a selector for the provided element\n *\n * @param {HTMLElement} element - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\nfunction getSingleSelector(element) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n if (element.nodeType === 3) {\n element = element.parentNode;\n }\n\n if (element.nodeType !== 1) {\n throw new Error('Invalid input - only HTMLElements or representations of them are supported! (not \"' + (typeof element === 'undefined' ? 'undefined' : _typeof(element)) + '\")');\n }\n\n var globalModified = (0, _adapt2.default)(element, options);\n\n var selector = (0, _match2.default)(element, options);\n var optimized = (0, _optimize2.default)(selector, element, options);\n\n // debug\n // console.log(`\n // selector: ${selector}\n // optimized: ${optimized}\n // `)\n\n if (globalModified) {\n delete true;\n }\n\n return optimized;\n}\n\n/**\n * Get a selector to match multiple descendants from an ancestor\n *\n * @param {Array.|NodeList} elements - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\nfunction getMultiSelector(elements) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n if (!Array.isArray(elements)) {\n elements = (0, _utilities.convertNodeList)(elements);\n }\n\n if (elements.some(function (element) {\n return element.nodeType !== 1;\n })) {\n throw new Error('Invalid input - only an Array of HTMLElements or representations of them is supported!');\n }\n\n var globalModified = (0, _adapt2.default)(elements[0], options);\n\n var ancestor = (0, _common.getCommonAncestor)(elements, options);\n var ancestorSelector = getSingleSelector(ancestor, options);\n\n // TODO: consider usage of multiple selectors + parent-child relation + check for part redundancy\n var commonSelectors = getCommonSelectors(elements);\n var descendantSelector = commonSelectors[0];\n\n var selector = (0, _optimize2.default)(ancestorSelector + ' ' + descendantSelector, elements, options);\n var selectorMatches = (0, _utilities.convertNodeList)(document.querySelectorAll(selector));\n\n if (!elements.every(function (element) {\n return selectorMatches.some(function (entry) {\n return entry === element;\n });\n })) {\n // TODO: cluster matches to split into similar groups for sub selections\n return console.warn('\\n The selected elements can\\'t be efficiently mapped.\\n Its probably best to use multiple single selectors instead!\\n ', elements);\n }\n\n if (globalModified) {\n delete true;\n }\n\n return selector;\n}\n\n/**\n * Get selectors to describe a set of elements\n *\n * @param {Array.} elements - [description]\n * @return {string} - [description]\n */\nfunction getCommonSelectors(elements) {\n var _getCommonProperties = (0, _common.getCommonProperties)(elements),\n classes = _getCommonProperties.classes,\n attributes = _getCommonProperties.attributes,\n tag = _getCommonProperties.tag;\n\n var selectorPath = [];\n\n if (tag) {\n selectorPath.push(tag);\n }\n\n if (classes) {\n var classSelector = classes.map(function (name) {\n return '.' + name;\n }).join('');\n selectorPath.push(classSelector);\n }\n\n if (attributes) {\n var attributeSelector = Object.keys(attributes).reduce(function (parts, name) {\n parts.push('[' + name + '=\"' + attributes[name] + '\"]');\n return parts;\n }, []).join('');\n selectorPath.push(attributeSelector);\n }\n\n if (selectorPath.length) {\n // TODO: check for parent-child relation\n }\n\n return [selectorPath.join('')];\n}\n\n/**\n * Choose action depending on the input (multiple/single)\n *\n * NOTE: extended detection is used for special cases like the element with \n *\n * @param {HTMLElement|NodeList|Array.} input - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\nexport default function getQuerySelector (input, options = {}) {\n if (input.length && !input.name) {\n return getMultiSelector(input, options)\n }\n return getSingleSelector(input, options)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/select.js","/*! https://mths.be/cssesc v3.0.0 by @mathias */\n'use strict';\n\nvar object = {};\nvar hasOwnProperty = object.hasOwnProperty;\nvar merge = function merge(options, defaults) {\n\tif (!options) {\n\t\treturn defaults;\n\t}\n\tvar result = {};\n\tfor (var key in defaults) {\n\t\t// `if (defaults.hasOwnProperty(key) { … }` is not needed here, since\n\t\t// only recognized option names are used.\n\t\tresult[key] = hasOwnProperty.call(options, key) ? options[key] : defaults[key];\n\t}\n\treturn result;\n};\n\nvar regexAnySingleEscape = /[ -,\\.\\/:-@\\[-\\^`\\{-~]/;\nvar regexSingleEscape = /[ -,\\.\\/:-@\\[\\]\\^`\\{-~]/;\nvar regexAlwaysEscape = /['\"\\\\]/;\nvar regexExcessiveSpaces = /(^|\\\\+)?(\\\\[A-F0-9]{1,6})\\x20(?![a-fA-F0-9\\x20])/g;\n\n// https://mathiasbynens.be/notes/css-escapes#css\nvar cssesc = function cssesc(string, options) {\n\toptions = merge(options, cssesc.options);\n\tif (options.quotes != 'single' && options.quotes != 'double') {\n\t\toptions.quotes = 'single';\n\t}\n\tvar quote = options.quotes == 'double' ? '\"' : '\\'';\n\tvar isIdentifier = options.isIdentifier;\n\n\tvar firstChar = string.charAt(0);\n\tvar output = '';\n\tvar counter = 0;\n\tvar length = string.length;\n\twhile (counter < length) {\n\t\tvar character = string.charAt(counter++);\n\t\tvar codePoint = character.charCodeAt();\n\t\tvar value = void 0;\n\t\t// If it’s not a printable ASCII character…\n\t\tif (codePoint < 0x20 || codePoint > 0x7E) {\n\t\t\tif (codePoint >= 0xD800 && codePoint <= 0xDBFF && counter < length) {\n\t\t\t\t// It’s a high surrogate, and there is a next character.\n\t\t\t\tvar extra = string.charCodeAt(counter++);\n\t\t\t\tif ((extra & 0xFC00) == 0xDC00) {\n\t\t\t\t\t// next character is low surrogate\n\t\t\t\t\tcodePoint = ((codePoint & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000;\n\t\t\t\t} else {\n\t\t\t\t\t// It’s an unmatched surrogate; only append this code unit, in case\n\t\t\t\t\t// the next code unit is the high surrogate of a surrogate pair.\n\t\t\t\t\tcounter--;\n\t\t\t\t}\n\t\t\t}\n\t\t\tvalue = '\\\\' + codePoint.toString(16).toUpperCase() + ' ';\n\t\t} else {\n\t\t\tif (options.escapeEverything) {\n\t\t\t\tif (regexAnySingleEscape.test(character)) {\n\t\t\t\t\tvalue = '\\\\' + character;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = '\\\\' + codePoint.toString(16).toUpperCase() + ' ';\n\t\t\t\t}\n\t\t\t} else if (/[\\t\\n\\f\\r\\x0B]/.test(character)) {\n\t\t\t\tvalue = '\\\\' + codePoint.toString(16).toUpperCase() + ' ';\n\t\t\t} else if (character == '\\\\' || !isIdentifier && (character == '\"' && quote == character || character == '\\'' && quote == character) || isIdentifier && regexSingleEscape.test(character)) {\n\t\t\t\tvalue = '\\\\' + character;\n\t\t\t} else {\n\t\t\t\tvalue = character;\n\t\t\t}\n\t\t}\n\t\toutput += value;\n\t}\n\n\tif (isIdentifier) {\n\t\tif (/^-[-\\d]/.test(output)) {\n\t\t\toutput = '\\\\-' + output.slice(1);\n\t\t} else if (/\\d/.test(firstChar)) {\n\t\t\toutput = '\\\\3' + firstChar + ' ' + output.slice(1);\n\t\t}\n\t}\n\n\t// Remove spaces after `\\HEX` escapes that are not followed by a hex digit,\n\t// since they’re redundant. Note that this is only possible if the escape\n\t// sequence isn’t preceded by an odd number of backslashes.\n\toutput = output.replace(regexExcessiveSpaces, function ($0, $1, $2) {\n\t\tif ($1 && $1.length % 2) {\n\t\t\t// It’s not safe to remove the space, so don’t.\n\t\t\treturn $0;\n\t\t}\n\t\t// Strip the space.\n\t\treturn ($1 || '') + $2;\n\t});\n\n\tif (!isIdentifier && options.wrap) {\n\t\treturn quote + output + quote;\n\t}\n\treturn output;\n};\n\n// Expose default options (so they can be overridden globally).\ncssesc.options = {\n\t'escapeEverything': false,\n\t'isIdentifier': false,\n\t'quotes': 'single',\n\t'wrap': false\n};\n\ncssesc.version = '3.0.0';\n\nmodule.exports = cssesc;\n\n\n\n// WEBPACK FOOTER //\n// ./~/cssesc/cssesc.js","export select, { getSingleSelector, getMultiSelector } from './select'\nexport optimize from './optimize'\nexport * as common from './common'\n\nexport default from './select'\n\n\n\n// WEBPACK FOOTER //\n// ./src/index.js","/**\n * # Match\n *\n * Retrieve selector for a node.\n */\n\nimport { escapeValue } from './utilities'\n\nconst defaultIgnore = {\n attribute (attributeName) {\n return [\n 'style',\n 'data-reactid',\n 'data-react-checksum'\n ].indexOf(attributeName) > -1\n }\n}\n\n/**\n * Get the path of the element\n *\n * @param {HTMLElement} node - [description]\n * @param {Object} options - [description]\n * @return {string} - [description]\n */\nexport default function match (node, options) {\n\n const {\n root = document,\n skip = null,\n priority = ['id', 'class', 'href', 'src'],\n ignore = {}\n } = options\n\n const path = []\n var element = node\n var length = path.length\n var ignoreClass = false\n\n const skipCompare = skip && (Array.isArray(skip) ? skip : [skip]).map((entry) => {\n if (typeof entry !== 'function') {\n return (element) => element === entry\n }\n return entry\n })\n\n const skipChecks = (element) => {\n return skip && skipCompare.some((compare) => compare(element))\n }\n\n Object.keys(ignore).forEach((type) => {\n if (type === 'class') {\n ignoreClass = true\n }\n var predicate = ignore[type]\n if (typeof predicate === 'function') return\n if (typeof predicate === 'number') {\n predicate = predicate.toString()\n }\n if (typeof predicate === 'string') {\n predicate = new RegExp(escapeValue(predicate).replace(/\\\\/g, '\\\\\\\\'))\n }\n if (typeof predicate === 'boolean') {\n predicate = predicate ? /(?:)/ : /.^/\n }\n // check class-/attributename for regex\n ignore[type] = (name, value) => predicate.test(value)\n })\n\n if (ignoreClass) {\n const ignoreAttribute = ignore.attribute\n ignore.attribute = (name, value, defaultPredicate) => {\n return ignore.class(value) || ignoreAttribute && ignoreAttribute(name, value, defaultPredicate)\n }\n }\n\n while (element !== root) {\n if (skipChecks(element) !== true) {\n // ~ global\n if (checkAttributes(priority, element, ignore, path, root)) break\n if (checkTag(element, ignore, path, root)) break\n\n // ~ local\n checkAttributes(priority, element, ignore, path)\n if (path.length === length) {\n checkTag(element, ignore, path)\n }\n\n // define only one part each iteration\n if (path.length === length) {\n checkChilds(priority, element, ignore, path)\n }\n }\n\n element = element.parentNode\n length = path.length\n }\n\n if (element === root) {\n const pattern = findPattern(priority, element, ignore)\n path.unshift(pattern)\n }\n\n return path.join(' ')\n}\n\n/**\n * Extend path with attribute identifier\n *\n * @param {Array.} priority - [description]\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @param {Array.} path - [description]\n * @param {HTMLElement} parent - [description]\n * @return {boolean} - [description]\n */\nfunction checkAttributes (priority, element, ignore, path, parent = element.parentNode) {\n const pattern = findAttributesPattern(priority, element, ignore)\n if (pattern) {\n const matches = parent.querySelectorAll(pattern)\n if (matches.length === 1) {\n path.unshift(pattern)\n return true\n }\n }\n return false\n}\n\n/**\n * Lookup attribute identifier\n *\n * @param {Array.} priority - [description]\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @return {string?} - [description]\n */\nfunction findAttributesPattern (priority, element, ignore) {\n const attributes = element.attributes\n const sortedKeys = Object.keys(attributes).sort((curr, next) => {\n const currPos = priority.indexOf(attributes[curr].name)\n const nextPos = priority.indexOf(attributes[next].name)\n if (nextPos === -1) {\n if (currPos === -1) {\n return 0\n }\n return -1\n }\n if (currPos === -1) {\n return 1\n }\n return currPos - nextPos;\n })\n\n for (var i = 0, l = sortedKeys.length; i < l; i++) {\n const key = sortedKeys[i]\n const attribute = attributes[key]\n const attributeName = attribute.name\n const attributeValue = escapeValue(attribute.value)\n\n const currentIgnore = ignore[attributeName] || ignore.attribute\n const currentDefaultIgnore = defaultIgnore[attributeName] || defaultIgnore.attribute\n if (checkIgnore(currentIgnore, attributeName, attributeValue, currentDefaultIgnore)) {\n continue\n }\n\n var pattern = `[${attributeName}=\"${attributeValue}\"]`\n\n if (attributeName === 'id' && (/^[A-Za-z][-\\d\\w:,.]*$/).test(attributeValue)) {\n pattern = `#${attributeValue}`\n }\n\n if (attributeName === 'class' && (/^[A-Za-z][-\\d\\w]*$/).test(attributeValue)) {\n const className = attributeValue.trim().replace(/\\s+/g, '.')\n pattern = `.${className}`\n }\n\n return pattern\n }\n return null\n}\n\n/**\n * Extend path with tag identifier\n *\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @param {Array.} path - [description]\n * @param {HTMLElement} parent - [description]\n * @return {boolean} - [description]\n */\nfunction checkTag (element, ignore, path, parent = element.parentNode) {\n const pattern = findTagPattern(element, ignore)\n if (pattern) {\n const matches = parent.getElementsByTagName(pattern)\n if (matches.length === 1) {\n path.unshift(pattern)\n return true\n }\n }\n return false\n}\n\n/**\n * Lookup tag identifier\n *\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @return {boolean} - [description]\n */\nfunction findTagPattern (element, ignore) {\n const tagName = element.tagName.toLowerCase()\n if (checkIgnore(ignore.tag, null, tagName)) {\n return null\n }\n return tagName\n}\n\n/**\n * Extend path with specific child identifier\n *\n * NOTE: 'childTags' is a custom property to use as a view filter for tags using 'adapter.js'\n *\n * @param {Array.} priority - [description]\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @param {Array.} path - [description]\n * @return {boolean} - [description]\n */\nfunction checkChilds (priority, element, ignore, path) {\n const parent = element.parentNode\n const children = parent.childTags || parent.children\n for (var i = 0, l = children.length; i < l; i++) {\n const child = children[i]\n if (child === element) {\n const childPattern = findPattern(priority, child, ignore)\n if (!childPattern) {\n return console.warn(`\n Element couldn\\'t be matched through strict ignore pattern!\n `, child, ignore, childPattern)\n }\n const pattern = `> ${childPattern}:nth-child(${i+1})`\n path.unshift(pattern)\n return true\n }\n }\n return false\n}\n\n/**\n * Lookup identifier\n *\n * @param {Array.} priority - [description]\n * @param {HTMLElement} element - [description]\n * @param {Object} ignore - [description]\n * @return {string} - [description]\n */\nfunction findPattern (priority, element, ignore) {\n var pattern = findAttributesPattern(priority, element, ignore)\n if (!pattern) {\n pattern = findTagPattern(element, ignore)\n }\n return pattern\n}\n\n/**\n * Validate with custom and default functions\n *\n * @param {Function} predicate - [description]\n * @param {string?} name - [description]\n * @param {string} value - [description]\n * @param {Function} defaultPredicate - [description]\n * @return {boolean} - [description]\n */\nfunction checkIgnore (predicate, name, value, defaultPredicate) {\n if (!value) {\n return true\n }\n const check = predicate || defaultPredicate\n if (!check) {\n return false\n }\n return check(name, value, defaultPredicate)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/match.js"],"sourceRoot":""} \ No newline at end of file diff --git a/package.json b/package.json index f5b85e5..f48a5b7 100644 --- a/package.json +++ b/package.json @@ -13,6 +13,7 @@ "babel-preset-stage-0": "^6.16.0", "babel-register": "^6.16.3", "cheerio": "^0.22.0", + "cssesc": "^3.0.0", "deep-merge": "^1.0.0", "fs-extra": "^1.0.0", "gulp": "^3.9.1", diff --git a/src/optimize.js b/src/optimize.js index 2d89309..fafde8d 100644 --- a/src/optimize.js +++ b/src/optimize.js @@ -43,7 +43,12 @@ export default function optimize (selector, elements, options = {}) { const postPart = shortened.join(' ') const pattern = `${prePart} ${postPart}` - const matches = document.querySelectorAll(pattern) + let matches = []; + try { + matches = document.querySelectorAll(pattern) + } catch(err) { + // + } if (matches.length !== elements.length) { shortened.unshift(optimizePart(prePart, current, postPart, elements)) } @@ -79,18 +84,33 @@ function optimizePart (prePart, current, postPart, elements) { if (/\[*\]/.test(current)) { const key = current.replace(/=.*$/, ']') var pattern = `${prePart}${key}${postPart}` - var matches = document.querySelectorAll(pattern) + let matches = []; + try { + matches = document.querySelectorAll(pattern) + } catch(err) { + // + } if (compareResults(matches, elements)) { current = key } else { // robustness: replace specific key-value with base tag (heuristic) - const references = document.querySelectorAll(`${prePart}${key}`) + let references = []; + try { + references = document.querySelectorAll(`${prePart}${key}`) + } catch(err) { + // + } for (var i = 0, l = references.length; i < l; i++) { const reference = references[i] if (elements.some((element) => reference.contains(element))) { const description = reference.tagName.toLowerCase() var pattern = `${prePart}${description}${postPart}` - var matches = document.querySelectorAll(pattern) + let matches = []; + try { + matches = document.querySelectorAll(pattern) + } catch(err) { + // + } if (compareResults(matches, elements)) { current = description } @@ -104,7 +124,12 @@ function optimizePart (prePart, current, postPart, elements) { if (/>/.test(current)) { const descendant = current.replace(/>/, '') var pattern = `${prePart}${descendant}${postPart}` - var matches = document.querySelectorAll(pattern) + let matches = []; + try { + matches = document.querySelectorAll(pattern) + } catch(err) { + // + } if (compareResults(matches, elements)) { current = descendant } @@ -115,7 +140,12 @@ function optimizePart (prePart, current, postPart, elements) { // TODO: consider complete coverage of 'nth-of-type' replacement const type = current.replace(/nth-child/g, 'nth-of-type') var pattern = `${prePart}${type}${postPart}` - var matches = document.querySelectorAll(pattern) + let matches = []; + try { + matches = document.querySelectorAll(pattern) + } catch(err) { + // + } if (compareResults(matches, elements)) { current = type } @@ -125,14 +155,23 @@ function optimizePart (prePart, current, postPart, elements) { if (/\.\S+\.\S+/.test(current)) { var names = current.trim().split('.').slice(1) .map((name) => `.${name}`) - .sort((curr, next) => curr.length - next.length) + .sort((curr, next) => curr.length - next.length); while (names.length) { const partial = current.replace(names.shift(), '').trim() + if(partial.charAt(0) === '>' || partial.charAt(partial.length-1) === '>') { + break + } var pattern = `${prePart}${partial}${postPart}`.trim() if (!pattern.length || pattern.charAt(0) === '>' || pattern.charAt(pattern.length-1) === '>') { break } - var matches = document.querySelectorAll(pattern) + let matches = []; + + try { + matches = document.querySelectorAll(pattern) + } catch(err) { + // + } if (compareResults(matches, elements)) { current = partial } @@ -141,7 +180,12 @@ function optimizePart (prePart, current, postPart, elements) { // robustness: degrade complex classname (heuristic) names = current && current.match(/\./g) if (names && names.length > 2) { - const references = document.querySelectorAll(`${prePart}${current}`) + let references = []; + try { + references = document.querySelectorAll(`${prePart}${current}`); + } catch (err) { + // + } for (var i = 0, l = references.length; i < l; i++) { const reference = references[i] if (elements.some((element) => reference.contains(element) )) { @@ -149,7 +193,12 @@ function optimizePart (prePart, current, postPart, elements) { // - check using attributes + regard excludes const description = reference.tagName.toLowerCase() var pattern = `${prePart}${description}${postPart}` - var matches = document.querySelectorAll(pattern) + let matches = []; + try { + matches = document.querySelectorAll(pattern) + } catch(err) { + // + } if (compareResults(matches, elements)) { current = description } diff --git a/src/utilities.js b/src/utilities.js index da1837e..9955d16 100644 --- a/src/utilities.js +++ b/src/utilities.js @@ -4,6 +4,8 @@ * Convenience helpers. */ +const cssesc = require('cssesc'); + /** * Create an array with the DOM nodes of the list * @@ -28,6 +30,5 @@ export function convertNodeList (nodes) { * @return {String} - [description] */ export function escapeValue (value) { - return value && value.replace(/['"`\\/:\?&!#$%^()[\]{|}*+;,.<=>@~]/g, '\\$&') - .replace(/\n/g, '\A') + return value && cssesc(value); }