From b07d76ce1d105da92a19ffc5ff501e2fde234304 Mon Sep 17 00:00:00 2001 From: Sebastian Kupke Date: Tue, 16 Apr 2019 12:16:29 +0200 Subject: [PATCH] Removed sourcmapping URLs in build script. --- dist/iwmlib.3rdparty.js | 10 +++---- gulpfile.js | 3 +++ package-lock.json | 59 ++++++++++++++++++++++++++++++++++++++++- package.json | 1 + 4 files changed, 67 insertions(+), 6 deletions(-) diff --git a/dist/iwmlib.3rdparty.js b/dist/iwmlib.3rdparty.js index adc0901..cc5089e 100644 --- a/dist/iwmlib.3rdparty.js +++ b/dist/iwmlib.3rdparty.js @@ -1477,7 +1477,7 @@ exports.default = _select3.default; /***/ } /******/ ]); }); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap a8e0297cdd416bc0f326","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 a8e0297cdd416bc0f326","/**\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    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 ((/\\b\\d/).test(attributeValue) === false) {\n      if (attributeName === 'id') {\n        pattern = `#${attributeValue}`\n      }\n\n      if (attributeName === 'class') {\n        const className = attributeValue.trim().replace(/\\s+/g, '.')\n        pattern = `.${className}`\n      }\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":""} + /*! Hammer.JS - v2.0.7 - 2016-04-22 * http://hammerjs.github.io/ * @@ -47268,7 +47268,7 @@ global.PIXI = exports; // eslint-disable-line }); -//# sourceMappingURL=pixi.js.map + var e;e||(e=eval("(function() { try { return Module || {} } catch(e) { return {} } })()"));var aa={},k;for(k in e)e.hasOwnProperty(k)&&(aa[k]=e[k]);var ba="object"===typeof window,ca="function"===typeof importScripts,da="object"===typeof process&&"function"===typeof require&&!ba&&!ca,ea=!ba&&!da&&!ca; if(da){e.print||(e.print=function(a){process.stdout.write(a+"\n")});e.printErr||(e.printErr=function(a){process.stderr.write(a+"\n")});var fa=require("fs"),ga=require("path");e.read=function(a,b){a=ga.normalize(a);var c=fa.readFileSync(a);c||a==ga.resolve(a)||(a=path.join(__dirname,"..","src",a),c=fa.readFileSync(a));c&&!b&&(c=c.toString());return c};e.readBinary=function(a){a=e.read(a,!0);a.buffer||(a=new Uint8Array(a));assert(a.buffer);return a};e.load=function(a){ha(read(a))};e.thisProgram||(e.thisProgram= @@ -70522,7 +70522,7 @@ module.exports = global.PIXI.compressedTextures = plugin; }); -//# sourceMappingURL=pixi-compressed-textures.js.map + /*! * pixi-filters - v2.7.1 @@ -70532,7 +70532,7 @@ module.exports = global.PIXI.compressedTextures = plugin; * http://www.opensource.org/licenses/mit-license */ var __filters=function(e,t){"use strict";var n="attribute vec2 aVertexPosition;\nattribute vec2 aTextureCoord;\n\nuniform mat3 projectionMatrix;\n\nvarying vec2 vTextureCoord;\n\nvoid main(void)\n{\n gl_Position = vec4((projectionMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);\n vTextureCoord = aTextureCoord;\n}",r="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\n\nuniform float gamma;\nuniform float contrast;\nuniform float saturation;\nuniform float brightness;\nuniform float red;\nuniform float green;\nuniform float blue;\nuniform float alpha;\n\nvoid main(void)\n{\n vec4 c = texture2D(uSampler, vTextureCoord);\n\n if (c.a > 0.0) {\n c.rgb /= c.a;\n\n vec3 rgb = pow(c.rgb, vec3(1. / gamma));\n rgb = mix(vec3(.5), mix(vec3(dot(vec3(.2125, .7154, .0721), rgb)), rgb, saturation), contrast);\n rgb.r *= red;\n rgb.g *= green;\n rgb.b *= blue;\n c.rgb = rgb * brightness;\n\n c.rgb *= c.a;\n }\n\n gl_FragColor = c * alpha;\n}\n",o=function(e){function t(t){e.call(this,n,r),Object.assign(this,{gamma:1,saturation:1,contrast:1,brightness:1,red:1,green:1,blue:1,alpha:1},t)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.apply=function(e,t,n,r){this.uniforms.gamma=Math.max(this.gamma,1e-4),this.uniforms.saturation=this.saturation,this.uniforms.contrast=this.contrast,this.uniforms.brightness=this.brightness,this.uniforms.red=this.red,this.uniforms.green=this.green,this.uniforms.blue=this.blue,this.uniforms.alpha=this.alpha,e.applyFilter(this,t,n,r)},t}(t.Filter),i=n,l="\nvarying vec2 vTextureCoord;\nuniform sampler2D uSampler;\n\nuniform vec2 uOffset;\n\nvoid main(void)\n{\n vec4 color = vec4(0.0);\n\n // Sample top left pixel\n color += texture2D(uSampler, vec2(vTextureCoord.x - uOffset.x, vTextureCoord.y + uOffset.y));\n\n // Sample top right pixel\n color += texture2D(uSampler, vec2(vTextureCoord.x + uOffset.x, vTextureCoord.y + uOffset.y));\n\n // Sample bottom right pixel\n color += texture2D(uSampler, vec2(vTextureCoord.x + uOffset.x, vTextureCoord.y - uOffset.y));\n\n // Sample bottom left pixel\n color += texture2D(uSampler, vec2(vTextureCoord.x - uOffset.x, vTextureCoord.y - uOffset.y));\n\n // Average\n color *= 0.25;\n\n gl_FragColor = color;\n}",s="\nvarying vec2 vTextureCoord;\nuniform sampler2D uSampler;\n\nuniform vec2 uOffset;\nuniform vec4 filterClamp;\n\nvoid main(void)\n{\n vec4 color = vec4(0.0);\n\n // Sample top left pixel\n color += texture2D(uSampler, clamp(vec2(vTextureCoord.x - uOffset.x, vTextureCoord.y + uOffset.y), filterClamp.xy, filterClamp.zw));\n\n // Sample top right pixel\n color += texture2D(uSampler, clamp(vec2(vTextureCoord.x + uOffset.x, vTextureCoord.y + uOffset.y), filterClamp.xy, filterClamp.zw));\n\n // Sample bottom right pixel\n color += texture2D(uSampler, clamp(vec2(vTextureCoord.x + uOffset.x, vTextureCoord.y - uOffset.y), filterClamp.xy, filterClamp.zw));\n\n // Sample bottom left pixel\n color += texture2D(uSampler, clamp(vec2(vTextureCoord.x - uOffset.x, vTextureCoord.y - uOffset.y), filterClamp.xy, filterClamp.zw));\n\n // Average\n color *= 0.25;\n\n gl_FragColor = color;\n}\n",a=function(e){function n(n,r,o){void 0===n&&(n=4),void 0===r&&(r=3),void 0===o&&(o=!1),e.call(this,i,o?s:l),this.uniforms.uOffset=new Float32Array(2),this._pixelSize=new t.Point,this.pixelSize=1,this._clamp=o,this._kernels=null,Array.isArray(n)?this.kernels=n:(this._blur=n,this.quality=r)}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={kernels:{configurable:!0},clamp:{configurable:!0},pixelSize:{configurable:!0},quality:{configurable:!0},blur:{configurable:!0}};return n.prototype.apply=function(e,t,n,r){var o,i=this.pixelSize.x/t.size.width,l=this.pixelSize.y/t.size.height;if(1===this._quality||0===this._blur)o=this._kernels[0]+.5,this.uniforms.uOffset[0]=o*i,this.uniforms.uOffset[1]=o*l,e.applyFilter(this,t,n,r);else{for(var s,a=e.getRenderTarget(!0),u=t,c=a,f=this._quality-1,h=0;h0)for(var r=e,o=e/t,i=1;i0?(this._kernels=e,this._quality=e.length,this._blur=Math.max.apply(Math,e)):(this._kernels=[0],this._quality=1)},r.clamp.get=function(){return this._clamp},r.pixelSize.set=function(e){"number"==typeof e?(this._pixelSize.x=e,this._pixelSize.y=e):Array.isArray(e)?(this._pixelSize.x=e[0],this._pixelSize.y=e[1]):e instanceof t.Point?(this._pixelSize.x=e.x,this._pixelSize.y=e.y):(this._pixelSize.x=1,this._pixelSize.y=1)},r.pixelSize.get=function(){return this._pixelSize},r.quality.get=function(){return this._quality},r.quality.set=function(e){this._quality=Math.max(1,Math.round(e)),this._generateKernels()},r.blur.get=function(){return this._blur},r.blur.set=function(e){this._blur=e,this._generateKernels()},Object.defineProperties(n.prototype,r),n}(t.Filter),u=n,c="\nuniform sampler2D uSampler;\nvarying vec2 vTextureCoord;\n\nuniform float threshold;\n\nvoid main() {\n vec4 color = texture2D(uSampler, vTextureCoord);\n\n // A simple & fast algorithm for getting brightness.\n // It's inaccuracy , but good enought for this feature.\n float _max = max(max(color.r, color.g), color.b);\n float _min = min(min(color.r, color.g), color.b);\n float brightness = (_max + _min) * 0.5;\n\n if(brightness > threshold) {\n gl_FragColor = color;\n } else {\n gl_FragColor = vec4(0.0, 0.0, 0.0, 0.0);\n }\n}\n",f=function(e){function t(t){void 0===t&&(t=.5),e.call(this,u,c),this.threshold=t}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={threshold:{configurable:!0}};return n.threshold.get=function(){return this.uniforms.threshold},n.threshold.set=function(e){this.uniforms.threshold=e},Object.defineProperties(t.prototype,n),t}(t.Filter),h="uniform sampler2D uSampler;\nvarying vec2 vTextureCoord;\n\nuniform sampler2D bloomTexture;\nuniform float bloomScale;\nuniform float brightness;\n\nvoid main() {\n vec4 color = texture2D(uSampler, vTextureCoord);\n color.rgb *= brightness;\n vec4 bloomColor = vec4(texture2D(bloomTexture, vTextureCoord).rgb, 0.0);\n bloomColor.rgb *= bloomScale;\n gl_FragColor = color + bloomColor;\n}\n",p=function(e){function n(n){e.call(this,u,h),"number"==typeof n&&(n={threshold:n}),n=Object.assign({threshold:.5,bloomScale:1,brightness:1,kernels:null,blur:8,quality:4,pixelSize:1,resolution:t.settings.RESOLUTION},n),this.bloomScale=n.bloomScale,this.brightness=n.brightness;var r=n.kernels,o=n.blur,i=n.quality,l=n.pixelSize,s=n.resolution;this._extractFilter=new f(n.threshold),this._extractFilter.resolution=s,this._blurFilter=r?new a(r):new a(o,i),this.pixelSize=l,this.resolution=s}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={resolution:{configurable:!0},threshold:{configurable:!0},kernels:{configurable:!0},blur:{configurable:!0},quality:{configurable:!0},pixelSize:{configurable:!0}};return n.prototype.apply=function(e,t,n,r,o){var i=e.getRenderTarget(!0);this._extractFilter.apply(e,t,i,!0,o);var l=e.getRenderTarget(!0);this._blurFilter.apply(e,i,l,!0,o),this.uniforms.bloomScale=this.bloomScale,this.uniforms.brightness=this.brightness,this.uniforms.bloomTexture=l,e.applyFilter(this,t,n,r),e.returnRenderTarget(l),e.returnRenderTarget(i)},r.resolution.get=function(){return this._resolution},r.resolution.set=function(e){this._resolution=e,this._extractFilter&&(this._extractFilter.resolution=e),this._blurFilter&&(this._blurFilter.resolution=e)},r.threshold.get=function(){return this._extractFilter.threshold},r.threshold.set=function(e){this._extractFilter.threshold=e},r.kernels.get=function(){return this._blurFilter.kernels},r.kernels.set=function(e){this._blurFilter.kernels=e},r.blur.get=function(){return this._blurFilter.blur},r.blur.set=function(e){this._blurFilter.blur=e},r.quality.get=function(){return this._blurFilter.quality},r.quality.set=function(e){this._blurFilter.quality=e},r.pixelSize.get=function(){return this._blurFilter.pixelSize},r.pixelSize.set=function(e){this._blurFilter.pixelSize=e},Object.defineProperties(n.prototype,r),n}(t.Filter),d=n,m="varying vec2 vTextureCoord;\n\nuniform vec4 filterArea;\nuniform float pixelSize;\nuniform sampler2D uSampler;\n\nvec2 mapCoord( vec2 coord )\n{\n coord *= filterArea.xy;\n coord += filterArea.zw;\n\n return coord;\n}\n\nvec2 unmapCoord( vec2 coord )\n{\n coord -= filterArea.zw;\n coord /= filterArea.xy;\n\n return coord;\n}\n\nvec2 pixelate(vec2 coord, vec2 size)\n{\n return floor( coord / size ) * size;\n}\n\nvec2 getMod(vec2 coord, vec2 size)\n{\n return mod( coord , size) / size;\n}\n\nfloat character(float n, vec2 p)\n{\n p = floor(p*vec2(4.0, -4.0) + 2.5);\n\n if (clamp(p.x, 0.0, 4.0) == p.x)\n {\n if (clamp(p.y, 0.0, 4.0) == p.y)\n {\n if (int(mod(n/exp2(p.x + 5.0*p.y), 2.0)) == 1) return 1.0;\n }\n }\n return 0.0;\n}\n\nvoid main()\n{\n vec2 coord = mapCoord(vTextureCoord);\n\n // get the rounded color..\n vec2 pixCoord = pixelate(coord, vec2(pixelSize));\n pixCoord = unmapCoord(pixCoord);\n\n vec4 color = texture2D(uSampler, pixCoord);\n\n // determine the character to use\n float gray = (color.r + color.g + color.b) / 3.0;\n\n float n = 65536.0; // .\n if (gray > 0.2) n = 65600.0; // :\n if (gray > 0.3) n = 332772.0; // *\n if (gray > 0.4) n = 15255086.0; // o\n if (gray > 0.5) n = 23385164.0; // &\n if (gray > 0.6) n = 15252014.0; // 8\n if (gray > 0.7) n = 13199452.0; // @\n if (gray > 0.8) n = 11512810.0; // #\n\n // get the mod..\n vec2 modd = getMod(coord, vec2(pixelSize));\n\n gl_FragColor = color * character( n, vec2(-1.0) + modd * 2.0);\n\n}\n",g=function(e){function t(t){void 0===t&&(t=8),e.call(this,d,m),this.size=t}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={size:{configurable:!0}};return n.size.get=function(){return this.uniforms.pixelSize},n.size.set=function(e){this.uniforms.pixelSize=e},Object.defineProperties(t.prototype,n),t}(t.Filter),v=n,x="precision mediump float;\n\nvarying vec2 vTextureCoord;\nuniform sampler2D uSampler;\nuniform vec4 filterArea;\n\nuniform float transformX;\nuniform float transformY;\nuniform vec3 lightColor;\nuniform float lightAlpha;\nuniform vec3 shadowColor;\nuniform float shadowAlpha;\n\nvoid main(void) {\n vec2 transform = vec2(1.0 / filterArea) * vec2(transformX, transformY);\n vec4 color = texture2D(uSampler, vTextureCoord);\n float light = texture2D(uSampler, vTextureCoord - transform).a;\n float shadow = texture2D(uSampler, vTextureCoord + transform).a;\n\n color.rgb = mix(color.rgb, lightColor, clamp((color.a - light) * lightAlpha, 0.0, 1.0));\n color.rgb = mix(color.rgb, shadowColor, clamp((color.a - shadow) * shadowAlpha, 0.0, 1.0));\n gl_FragColor = vec4(color.rgb * color.a, color.a);\n}\n",y=function(e){function n(t){void 0===t&&(t={}),e.call(this,v,x),this.uniforms.lightColor=new Float32Array(3),this.uniforms.shadowColor=new Float32Array(3),t=Object.assign({rotation:45,thickness:2,lightColor:16777215,lightAlpha:.7,shadowColor:0,shadowAlpha:.7},t),this.rotation=t.rotation,this.thickness=t.thickness,this.lightColor=t.lightColor,this.lightAlpha=t.lightAlpha,this.shadowColor=t.shadowColor,this.shadowAlpha=t.shadowAlpha}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={rotation:{configurable:!0},thickness:{configurable:!0},lightColor:{configurable:!0},lightAlpha:{configurable:!0},shadowColor:{configurable:!0},shadowAlpha:{configurable:!0}};return n.prototype._updateTransform=function(){this.uniforms.transformX=this._thickness*Math.cos(this._angle),this.uniforms.transformY=this._thickness*Math.sin(this._angle)},r.rotation.get=function(){return this._angle/t.DEG_TO_RAD},r.rotation.set=function(e){this._angle=e*t.DEG_TO_RAD,this._updateTransform()},r.thickness.get=function(){return this._thickness},r.thickness.set=function(e){this._thickness=e,this._updateTransform()},r.lightColor.get=function(){return t.utils.rgb2hex(this.uniforms.lightColor)},r.lightColor.set=function(e){t.utils.hex2rgb(e,this.uniforms.lightColor)},r.lightAlpha.get=function(){return this.uniforms.lightAlpha},r.lightAlpha.set=function(e){this.uniforms.lightAlpha=e},r.shadowColor.get=function(){return t.utils.rgb2hex(this.uniforms.shadowColor)},r.shadowColor.set=function(e){t.utils.hex2rgb(e,this.uniforms.shadowColor)},r.shadowAlpha.get=function(){return this.uniforms.shadowAlpha},r.shadowAlpha.set=function(e){this.uniforms.shadowAlpha=e},Object.defineProperties(n.prototype,r),n}(t.Filter),b=t.filters,_=b.BlurXFilter,C=b.BlurYFilter,S=b.AlphaFilter,F=function(e){function n(n,r,o,i){var l,s;void 0===n&&(n=2),void 0===r&&(r=4),void 0===o&&(o=t.settings.RESOLUTION),void 0===i&&(i=5),e.call(this),"number"==typeof n?(l=n,s=n):n instanceof t.Point?(l=n.x,s=n.y):Array.isArray(n)&&(l=n[0],s=n[1]),this.blurXFilter=new _(l,r,o,i),this.blurYFilter=new C(s,r,o,i),this.blurYFilter.blendMode=t.BLEND_MODES.SCREEN,this.defaultFilter=new S}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={blur:{configurable:!0},blurX:{configurable:!0},blurY:{configurable:!0}};return n.prototype.apply=function(e,t,n){var r=e.getRenderTarget(!0);this.defaultFilter.apply(e,t,n),this.blurXFilter.apply(e,t,r),this.blurYFilter.apply(e,r,n),e.returnRenderTarget(r)},r.blur.get=function(){return this.blurXFilter.blur},r.blur.set=function(e){this.blurXFilter.blur=this.blurYFilter.blur=e},r.blurX.get=function(){return this.blurXFilter.blur},r.blurX.set=function(e){this.blurXFilter.blur=e},r.blurY.get=function(){return this.blurYFilter.blur},r.blurY.set=function(e){this.blurYFilter.blur=e},Object.defineProperties(n.prototype,r),n}(t.Filter),z=n,A="uniform float radius;\nuniform float strength;\nuniform vec2 center;\nuniform sampler2D uSampler;\nvarying vec2 vTextureCoord;\n\nuniform vec4 filterArea;\nuniform vec4 filterClamp;\nuniform vec2 dimensions;\n\nvoid main()\n{\n vec2 coord = vTextureCoord * filterArea.xy;\n coord -= center * dimensions.xy;\n float distance = length(coord);\n if (distance < radius) {\n float percent = distance / radius;\n if (strength > 0.0) {\n coord *= mix(1.0, smoothstep(0.0, radius / distance, percent), strength * 0.75);\n } else {\n coord *= mix(1.0, pow(percent, 1.0 + strength * 0.75) * radius / distance, 1.0 - percent);\n }\n }\n coord += center * dimensions.xy;\n coord /= filterArea.xy;\n vec2 clampedCoord = clamp(coord, filterClamp.xy, filterClamp.zw);\n vec4 color = texture2D(uSampler, clampedCoord);\n if (coord != clampedCoord) {\n color *= max(0.0, 1.0 - length(coord - clampedCoord));\n }\n\n gl_FragColor = color;\n}\n",w=function(e){function t(t,n,r){e.call(this,z,A),this.uniforms.dimensions=new Float32Array(2),this.center=t||[.5,.5],this.radius="number"==typeof n?n:100,this.strength="number"==typeof r?r:1}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={radius:{configurable:!0},strength:{configurable:!0},center:{configurable:!0}};return t.prototype.apply=function(e,t,n,r){this.uniforms.dimensions[0]=t.sourceFrame.width,this.uniforms.dimensions[1]=t.sourceFrame.height,e.applyFilter(this,t,n,r)},n.radius.get=function(){return this.uniforms.radius},n.radius.set=function(e){this.uniforms.radius=e},n.strength.get=function(){return this.uniforms.strength},n.strength.set=function(e){this.uniforms.strength=e},n.center.get=function(){return this.uniforms.center},n.center.set=function(e){this.uniforms.center=e},Object.defineProperties(t.prototype,n),t}(t.Filter),T=n,D="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\nuniform sampler2D colorMap;\nuniform float _mix;\nuniform float _size;\nuniform float _sliceSize;\nuniform float _slicePixelSize;\nuniform float _sliceInnerSize;\nvoid main() {\n vec4 color = texture2D(uSampler, vTextureCoord.xy);\n\n vec4 adjusted;\n if (color.a > 0.0) {\n color.rgb /= color.a;\n float innerWidth = _size - 1.0;\n float zSlice0 = min(floor(color.b * innerWidth), innerWidth);\n float zSlice1 = min(zSlice0 + 1.0, innerWidth);\n float xOffset = _slicePixelSize * 0.5 + color.r * _sliceInnerSize;\n float s0 = xOffset + (zSlice0 * _sliceSize);\n float s1 = xOffset + (zSlice1 * _sliceSize);\n float yOffset = _sliceSize * 0.5 + color.g * (1.0 - _sliceSize);\n vec4 slice0Color = texture2D(colorMap, vec2(s0,yOffset));\n vec4 slice1Color = texture2D(colorMap, vec2(s1,yOffset));\n float zOffset = fract(color.b * innerWidth);\n adjusted = mix(slice0Color, slice1Color, zOffset);\n\n color.rgb *= color.a;\n }\n gl_FragColor = vec4(mix(color, adjusted, _mix).rgb, color.a);\n\n}",O=function(e){function n(t,n,r){void 0===n&&(n=!1),void 0===r&&(r=1),e.call(this,T,D),this._size=0,this._sliceSize=0,this._slicePixelSize=0,this._sliceInnerSize=0,this._scaleMode=null,this._nearest=!1,this.nearest=n,this.mix=r,this.colorMap=t}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={colorSize:{configurable:!0},colorMap:{configurable:!0},nearest:{configurable:!0}};return n.prototype.apply=function(e,t,n,r){this.uniforms._mix=this.mix,e.applyFilter(this,t,n,r)},r.colorSize.get=function(){return this._size},r.colorMap.get=function(){return this._colorMap},r.colorMap.set=function(e){e instanceof t.Texture||(e=t.Texture.from(e)),e&&e.baseTexture&&(e.baseTexture.scaleMode=this._scaleMode,e.baseTexture.mipmap=!1,this._size=e.height,this._sliceSize=1/this._size,this._slicePixelSize=this._sliceSize/this._size,this._sliceInnerSize=this._slicePixelSize*(this._size-1),this.uniforms._size=this._size,this.uniforms._sliceSize=this._sliceSize,this.uniforms._slicePixelSize=this._slicePixelSize,this.uniforms._sliceInnerSize=this._sliceInnerSize,this.uniforms.colorMap=e),this._colorMap=e},r.nearest.get=function(){return this._nearest},r.nearest.set=function(e){this._nearest=e,this._scaleMode=e?t.SCALE_MODES.NEAREST:t.SCALE_MODES.LINEAR;var n=this._colorMap;n&&n.baseTexture&&(n.baseTexture._glTextures={},n.baseTexture.scaleMode=this._scaleMode,n.baseTexture.mipmap=!1,n._updateID++,n.baseTexture.emit("update",n.baseTexture))},n.prototype.updateColorMap=function(){var e=this._colorMap;e&&e.baseTexture&&(e._updateID++,e.baseTexture.emit("update",e.baseTexture),this.colorMap=e)},n.prototype.destroy=function(t){this._colorMap&&this._colorMap.destroy(t),e.prototype.destroy.call(this)},Object.defineProperties(n.prototype,r),n}(t.Filter),P=n,M="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\nuniform vec3 originalColor;\nuniform vec3 newColor;\nuniform float epsilon;\nvoid main(void) {\n vec4 currentColor = texture2D(uSampler, vTextureCoord);\n vec3 colorDiff = originalColor - (currentColor.rgb / max(currentColor.a, 0.0000000001));\n float colorDistance = length(colorDiff);\n float doReplace = step(colorDistance, epsilon);\n gl_FragColor = vec4(mix(currentColor.rgb, (newColor + colorDiff) * currentColor.a, doReplace), currentColor.a);\n}\n",R=function(e){function n(t,n,r){void 0===t&&(t=16711680),void 0===n&&(n=0),void 0===r&&(r=.4),e.call(this,P,M),this.uniforms.originalColor=new Float32Array(3),this.uniforms.newColor=new Float32Array(3),this.originalColor=t,this.newColor=n,this.epsilon=r}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={originalColor:{configurable:!0},newColor:{configurable:!0},epsilon:{configurable:!0}};return r.originalColor.set=function(e){var n=this.uniforms.originalColor;"number"==typeof e?(t.utils.hex2rgb(e,n),this._originalColor=e):(n[0]=e[0],n[1]=e[1],n[2]=e[2],this._originalColor=t.utils.rgb2hex(n))},r.originalColor.get=function(){return this._originalColor},r.newColor.set=function(e){var n=this.uniforms.newColor;"number"==typeof e?(t.utils.hex2rgb(e,n),this._newColor=e):(n[0]=e[0],n[1]=e[1],n[2]=e[2],this._newColor=t.utils.rgb2hex(n))},r.newColor.get=function(){return this._newColor},r.epsilon.set=function(e){this.uniforms.epsilon=e},r.epsilon.get=function(){return this.uniforms.epsilon},Object.defineProperties(n.prototype,r),n}(t.Filter),j=n,L="precision mediump float;\n\nvarying mediump vec2 vTextureCoord;\n\nuniform sampler2D uSampler;\nuniform vec2 texelSize;\nuniform float matrix[9];\n\nvoid main(void)\n{\n vec4 c11 = texture2D(uSampler, vTextureCoord - texelSize); // top left\n vec4 c12 = texture2D(uSampler, vec2(vTextureCoord.x, vTextureCoord.y - texelSize.y)); // top center\n vec4 c13 = texture2D(uSampler, vec2(vTextureCoord.x + texelSize.x, vTextureCoord.y - texelSize.y)); // top right\n\n vec4 c21 = texture2D(uSampler, vec2(vTextureCoord.x - texelSize.x, vTextureCoord.y)); // mid left\n vec4 c22 = texture2D(uSampler, vTextureCoord); // mid center\n vec4 c23 = texture2D(uSampler, vec2(vTextureCoord.x + texelSize.x, vTextureCoord.y)); // mid right\n\n vec4 c31 = texture2D(uSampler, vec2(vTextureCoord.x - texelSize.x, vTextureCoord.y + texelSize.y)); // bottom left\n vec4 c32 = texture2D(uSampler, vec2(vTextureCoord.x, vTextureCoord.y + texelSize.y)); // bottom center\n vec4 c33 = texture2D(uSampler, vTextureCoord + texelSize); // bottom right\n\n gl_FragColor =\n c11 * matrix[0] + c12 * matrix[1] + c13 * matrix[2] +\n c21 * matrix[3] + c22 * matrix[4] + c23 * matrix[5] +\n c31 * matrix[6] + c32 * matrix[7] + c33 * matrix[8];\n\n gl_FragColor.a = c22.a;\n}\n",k=function(e){function t(t,n,r){void 0===n&&(n=200),void 0===r&&(r=200),e.call(this,j,L),this.uniforms.texelSize=new Float32Array(2),this.uniforms.matrix=new Float32Array(9),void 0!==t&&(this.matrix=t),this.width=n,this.height=r}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={matrix:{configurable:!0},width:{configurable:!0},height:{configurable:!0}};return n.matrix.get=function(){return this.uniforms.matrix},n.matrix.set=function(e){var t=this;e.forEach(function(e,n){return t.uniforms.matrix[n]=e})},n.width.get=function(){return 1/this.uniforms.texelSize[0]},n.width.set=function(e){this.uniforms.texelSize[0]=1/e},n.height.get=function(){return 1/this.uniforms.texelSize[1]},n.height.set=function(e){this.uniforms.texelSize[1]=1/e},Object.defineProperties(t.prototype,n),t}(t.Filter),I=n,E="precision mediump float;\n\nvarying vec2 vTextureCoord;\n\nuniform sampler2D uSampler;\n\nvoid main(void)\n{\n float lum = length(texture2D(uSampler, vTextureCoord.xy).rgb);\n\n gl_FragColor = vec4(1.0, 1.0, 1.0, 1.0);\n\n if (lum < 1.00)\n {\n if (mod(gl_FragCoord.x + gl_FragCoord.y, 10.0) == 0.0)\n {\n gl_FragColor = vec4(0.0, 0.0, 0.0, 1.0);\n }\n }\n\n if (lum < 0.75)\n {\n if (mod(gl_FragCoord.x - gl_FragCoord.y, 10.0) == 0.0)\n {\n gl_FragColor = vec4(0.0, 0.0, 0.0, 1.0);\n }\n }\n\n if (lum < 0.50)\n {\n if (mod(gl_FragCoord.x + gl_FragCoord.y - 5.0, 10.0) == 0.0)\n {\n gl_FragColor = vec4(0.0, 0.0, 0.0, 1.0);\n }\n }\n\n if (lum < 0.3)\n {\n if (mod(gl_FragCoord.x - gl_FragCoord.y - 5.0, 10.0) == 0.0)\n {\n gl_FragColor = vec4(0.0, 0.0, 0.0, 1.0);\n }\n }\n}\n",B=function(e){function t(){e.call(this,I,E)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t}(t.Filter),X=n,q="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\n\nuniform vec4 filterArea;\nuniform vec2 dimensions;\n\nconst float SQRT_2 = 1.414213;\n\nconst float light = 1.0;\n\nuniform float curvature;\nuniform float lineWidth;\nuniform float lineContrast;\nuniform bool verticalLine;\nuniform float noise;\nuniform float noiseSize;\n\nuniform float vignetting;\nuniform float vignettingAlpha;\nuniform float vignettingBlur;\n\nuniform float seed;\nuniform float time;\n\nfloat rand(vec2 co) {\n return fract(sin(dot(co.xy, vec2(12.9898, 78.233))) * 43758.5453);\n}\n\nvoid main(void)\n{\n vec2 pixelCoord = vTextureCoord.xy * filterArea.xy;\n vec2 coord = pixelCoord / dimensions;\n\n vec2 dir = vec2(coord - vec2(0.5, 0.5));\n\n float _c = curvature > 0. ? curvature : 1.;\n float k = curvature > 0. ?(length(dir * dir) * 0.25 * _c * _c + 0.935 * _c) : 1.;\n vec2 uv = dir * k;\n\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n vec3 rgb = gl_FragColor.rgb;\n\n\n if (noise > 0.0 && noiseSize > 0.0)\n {\n pixelCoord.x = floor(pixelCoord.x / noiseSize);\n pixelCoord.y = floor(pixelCoord.y / noiseSize);\n float _noise = rand(pixelCoord * noiseSize * seed) - 0.5;\n rgb += _noise * noise;\n }\n\n if (lineWidth > 0.0) {\n float v = (verticalLine ? uv.x * dimensions.x : uv.y * dimensions.y) * min(1.0, 2.0 / lineWidth ) / _c;\n float j = 1. + cos(v * 1.2 - time) * 0.5 * lineContrast;\n rgb *= j;\n float segment = verticalLine ? mod((dir.x + .5) * dimensions.x, 4.) : mod((dir.y + .5) * dimensions.y, 4.);\n rgb *= 0.99 + ceil(segment) * 0.015;\n }\n\n if (vignetting > 0.0)\n {\n float outter = SQRT_2 - vignetting * SQRT_2;\n float darker = clamp((outter - length(dir) * SQRT_2) / ( 0.00001 + vignettingBlur * SQRT_2), 0.0, 1.0);\n rgb *= darker + (1.0 - darker) * (1.0 - vignettingAlpha);\n }\n\n gl_FragColor.rgb = rgb;\n}\n",N=function(e){function t(t){e.call(this,X,q),this.uniforms.dimensions=new Float32Array(2),this.time=0,this.seed=0,Object.assign(this,{curvature:1,lineWidth:1,lineContrast:.25,verticalLine:!1,noise:0,noiseSize:1,seed:0,vignetting:.3,vignettingAlpha:1,vignettingBlur:.3,time:0},t)}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={curvature:{configurable:!0},lineWidth:{configurable:!0},lineContrast:{configurable:!0},verticalLine:{configurable:!0},noise:{configurable:!0},noiseSize:{configurable:!0},vignetting:{configurable:!0},vignettingAlpha:{configurable:!0},vignettingBlur:{configurable:!0}};return t.prototype.apply=function(e,t,n,r){this.uniforms.dimensions[0]=t.sourceFrame.width,this.uniforms.dimensions[1]=t.sourceFrame.height,this.uniforms.seed=this.seed,this.uniforms.time=this.time,e.applyFilter(this,t,n,r)},n.curvature.set=function(e){this.uniforms.curvature=e},n.curvature.get=function(){return this.uniforms.curvature},n.lineWidth.set=function(e){this.uniforms.lineWidth=e},n.lineWidth.get=function(){return this.uniforms.lineWidth},n.lineContrast.set=function(e){this.uniforms.lineContrast=e},n.lineContrast.get=function(){return this.uniforms.lineContrast},n.verticalLine.set=function(e){this.uniforms.verticalLine=e},n.verticalLine.get=function(){return this.uniforms.verticalLine},n.noise.set=function(e){this.uniforms.noise=e},n.noise.get=function(){return this.uniforms.noise},n.noiseSize.set=function(e){this.uniforms.noiseSize=e},n.noiseSize.get=function(){return this.uniforms.noiseSize},n.vignetting.set=function(e){this.uniforms.vignetting=e},n.vignetting.get=function(){return this.uniforms.vignetting},n.vignettingAlpha.set=function(e){this.uniforms.vignettingAlpha=e},n.vignettingAlpha.get=function(){return this.uniforms.vignettingAlpha},n.vignettingBlur.set=function(e){this.uniforms.vignettingBlur=e},n.vignettingBlur.get=function(){return this.uniforms.vignettingBlur},Object.defineProperties(t.prototype,n),t}(t.Filter),W=n,G="precision mediump float;\n\nvarying vec2 vTextureCoord;\nvarying vec4 vColor;\n\nuniform vec4 filterArea;\nuniform sampler2D uSampler;\n\nuniform float angle;\nuniform float scale;\n\nfloat pattern()\n{\n float s = sin(angle), c = cos(angle);\n vec2 tex = vTextureCoord * filterArea.xy;\n vec2 point = vec2(\n c * tex.x - s * tex.y,\n s * tex.x + c * tex.y\n ) * scale;\n return (sin(point.x) * sin(point.y)) * 4.0;\n}\n\nvoid main()\n{\n vec4 color = texture2D(uSampler, vTextureCoord);\n float average = (color.r + color.g + color.b) / 3.0;\n gl_FragColor = vec4(vec3(average * 10.0 - 5.0 + pattern()), color.a);\n}\n",K=function(e){function t(t,n){void 0===t&&(t=1),void 0===n&&(n=5),e.call(this,W,G),this.scale=t,this.angle=n}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={scale:{configurable:!0},angle:{configurable:!0}};return n.scale.get=function(){return this.uniforms.scale},n.scale.set=function(e){this.uniforms.scale=e},n.angle.get=function(){return this.uniforms.angle},n.angle.set=function(e){this.uniforms.angle=e},Object.defineProperties(t.prototype,n),t}(t.Filter),Y=n,Q="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\nuniform float alpha;\nuniform vec3 color;\nvoid main(void){\n vec4 sample = texture2D(uSampler, vTextureCoord);\n\n // Un-premultiply alpha before applying the color\n if (sample.a > 0.0) {\n sample.rgb /= sample.a;\n }\n\n // Premultiply alpha again\n sample.rgb = color.rgb * sample.a;\n\n // alpha user alpha\n sample *= alpha;\n\n gl_FragColor = sample;\n}",U=function(e){function n(n){n&&n.constructor!==Object&&(console.warn("DropShadowFilter now uses options instead of (rotation, distance, blur, color, alpha)"),n={rotation:n},void 0!==arguments[1]&&(n.distance=arguments[1]),void 0!==arguments[2]&&(n.blur=arguments[2]),void 0!==arguments[3]&&(n.color=arguments[3]),void 0!==arguments[4]&&(n.alpha=arguments[4])),n=Object.assign({rotation:45,distance:5,color:0,alpha:.5,shadowOnly:!1,kernels:null,blur:2,quality:3,pixelSize:1,resolution:t.settings.RESOLUTION},n),e.call(this);var r=n.kernels,o=n.blur,i=n.quality,l=n.pixelSize,s=n.resolution;this._tintFilter=new t.Filter(Y,Q),this._tintFilter.uniforms.color=new Float32Array(4),this._tintFilter.resolution=s,this._blurFilter=r?new a(r):new a(o,i),this.pixelSize=l,this.resolution=s,this.targetTransform=new t.Matrix;var u=n.shadowOnly,c=n.rotation,f=n.distance,h=n.alpha,p=n.color;this.shadowOnly=u,this.rotation=c,this.distance=f,this.alpha=h,this.color=p,this._updatePadding()}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={resolution:{configurable:!0},distance:{configurable:!0},rotation:{configurable:!0},alpha:{configurable:!0},color:{configurable:!0},kernels:{configurable:!0},blur:{configurable:!0},quality:{configurable:!0},pixelSize:{configurable:!0}};return n.prototype.apply=function(e,t,n,r){var o=e.getRenderTarget();o.transform=this.targetTransform,this._tintFilter.apply(e,t,o,!0),o.transform=null,this._blurFilter.apply(e,o,n,r),!0!==this.shadowOnly&&e.applyFilter(this,t,n,!1),e.returnRenderTarget(o)},n.prototype._updatePadding=function(){this.padding=this.distance+2*this.blur},n.prototype._updateTargetTransform=function(){this.targetTransform.tx=this.distance*Math.cos(this.angle),this.targetTransform.ty=this.distance*Math.sin(this.angle)},r.resolution.get=function(){return this._resolution},r.resolution.set=function(e){this._resolution=e,this._tintFilter&&(this._tintFilter.resolution=e),this._blurFilter&&(this._blurFilter.resolution=e)},r.distance.get=function(){return this._distance},r.distance.set=function(e){this._distance=e,this._updatePadding(),this._updateTargetTransform()},r.rotation.get=function(){return this.angle/t.DEG_TO_RAD},r.rotation.set=function(e){this.angle=e*t.DEG_TO_RAD,this._updateTargetTransform()},r.alpha.get=function(){return this._tintFilter.uniforms.alpha},r.alpha.set=function(e){this._tintFilter.uniforms.alpha=e},r.color.get=function(){return t.utils.rgb2hex(this._tintFilter.uniforms.color)},r.color.set=function(e){t.utils.hex2rgb(e,this._tintFilter.uniforms.color)},r.kernels.get=function(){return this._blurFilter.kernels},r.kernels.set=function(e){this._blurFilter.kernels=e},r.blur.get=function(){return this._blurFilter.blur},r.blur.set=function(e){this._blurFilter.blur=e,this._updatePadding()},r.quality.get=function(){return this._blurFilter.quality},r.quality.set=function(e){this._blurFilter.quality=e},r.pixelSize.get=function(){return this._blurFilter.pixelSize},r.pixelSize.set=function(e){this._blurFilter.pixelSize=e},Object.defineProperties(n.prototype,r),n}(t.Filter),Z=n,V="precision mediump float;\n\nvarying vec2 vTextureCoord;\n\nuniform sampler2D uSampler;\nuniform float strength;\nuniform vec4 filterArea;\n\n\nvoid main(void)\n{\n\tvec2 onePixel = vec2(1.0 / filterArea);\n\n\tvec4 color;\n\n\tcolor.rgb = vec3(0.5);\n\n\tcolor -= texture2D(uSampler, vTextureCoord - onePixel) * strength;\n\tcolor += texture2D(uSampler, vTextureCoord + onePixel) * strength;\n\n\tcolor.rgb = vec3((color.r + color.g + color.b) / 3.0);\n\n\tfloat alpha = texture2D(uSampler, vTextureCoord).a;\n\n\tgl_FragColor = vec4(color.rgb * alpha, alpha);\n}\n",H=function(e){function t(t){void 0===t&&(t=5),e.call(this,Z,V),this.strength=t}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={strength:{configurable:!0}};return n.strength.get=function(){return this.uniforms.strength},n.strength.set=function(e){this.uniforms.strength=e},Object.defineProperties(t.prototype,n),t}(t.Filter),$=n,J="// precision highp float;\n\nvarying vec2 vTextureCoord;\nuniform sampler2D uSampler;\n\nuniform vec4 filterArea;\nuniform vec4 filterClamp;\nuniform vec2 dimensions;\nuniform float aspect;\n\nuniform sampler2D displacementMap;\nuniform float offset;\nuniform float sinDir;\nuniform float cosDir;\nuniform int fillMode;\n\nuniform float seed;\nuniform vec2 red;\nuniform vec2 green;\nuniform vec2 blue;\n\nconst int TRANSPARENT = 0;\nconst int ORIGINAL = 1;\nconst int LOOP = 2;\nconst int CLAMP = 3;\nconst int MIRROR = 4;\n\nvoid main(void)\n{\n vec2 coord = (vTextureCoord * filterArea.xy) / dimensions;\n\n if (coord.x > 1.0 || coord.y > 1.0) {\n return;\n }\n\n float cx = coord.x - 0.5;\n float cy = (coord.y - 0.5) * aspect;\n float ny = (-sinDir * cx + cosDir * cy) / aspect + 0.5;\n\n // displacementMap: repeat\n // ny = ny > 1.0 ? ny - 1.0 : (ny < 0.0 ? 1.0 + ny : ny);\n\n // displacementMap: mirror\n ny = ny > 1.0 ? 2.0 - ny : (ny < 0.0 ? -ny : ny);\n\n vec4 dc = texture2D(displacementMap, vec2(0.5, ny));\n\n float displacement = (dc.r - dc.g) * (offset / filterArea.x);\n\n coord = vTextureCoord + vec2(cosDir * displacement, sinDir * displacement * aspect);\n\n if (fillMode == CLAMP) {\n coord = clamp(coord, filterClamp.xy, filterClamp.zw);\n } else {\n if( coord.x > filterClamp.z ) {\n if (fillMode == ORIGINAL) {\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n return;\n } else if (fillMode == LOOP) {\n coord.x -= filterClamp.z;\n } else if (fillMode == MIRROR) {\n coord.x = filterClamp.z * 2.0 - coord.x;\n } else {\n gl_FragColor = vec4(0., 0., 0., 0.);\n return;\n }\n } else if( coord.x < filterClamp.x ) {\n if (fillMode == ORIGINAL) {\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n return;\n } else if (fillMode == LOOP) {\n coord.x += filterClamp.z;\n } else if (fillMode == MIRROR) {\n coord.x *= -filterClamp.z;\n } else {\n gl_FragColor = vec4(0., 0., 0., 0.);\n return;\n }\n }\n\n if( coord.y > filterClamp.w ) {\n if (fillMode == ORIGINAL) {\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n return;\n } else if (fillMode == LOOP) {\n coord.y -= filterClamp.w;\n } else if (fillMode == MIRROR) {\n coord.y = filterClamp.w * 2.0 - coord.y;\n } else {\n gl_FragColor = vec4(0., 0., 0., 0.);\n return;\n }\n } else if( coord.y < filterClamp.y ) {\n if (fillMode == ORIGINAL) {\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n return;\n } else if (fillMode == LOOP) {\n coord.y += filterClamp.w;\n } else if (fillMode == MIRROR) {\n coord.y *= -filterClamp.w;\n } else {\n gl_FragColor = vec4(0., 0., 0., 0.);\n return;\n }\n }\n }\n\n gl_FragColor.r = texture2D(uSampler, coord + red * (1.0 - seed * 0.4) / filterArea.xy).r;\n gl_FragColor.g = texture2D(uSampler, coord + green * (1.0 - seed * 0.3) / filterArea.xy).g;\n gl_FragColor.b = texture2D(uSampler, coord + blue * (1.0 - seed * 0.2) / filterArea.xy).b;\n gl_FragColor.a = texture2D(uSampler, coord).a;\n}\n",ee=function(e){function n(n){void 0===n&&(n={}),e.call(this,$,J),this.uniforms.dimensions=new Float32Array(2),n=Object.assign({slices:5,offset:100,direction:0,fillMode:0,average:!1,seed:0,red:[0,0],green:[0,0],blue:[0,0],minSize:8,sampleSize:512},n),this.direction=n.direction,this.red=n.red,this.green=n.green,this.blue=n.blue,this.offset=n.offset,this.fillMode=n.fillMode,this.average=n.average,this.seed=n.seed,this.minSize=n.minSize,this.sampleSize=n.sampleSize,this._canvas=document.createElement("canvas"),this._canvas.width=4,this._canvas.height=this.sampleSize,this.texture=t.Texture.fromCanvas(this._canvas,t.SCALE_MODES.NEAREST),this._slices=0,this.slices=n.slices}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={sizes:{configurable:!0},offsets:{configurable:!0},slices:{configurable:!0},direction:{configurable:!0},red:{configurable:!0},green:{configurable:!0},blue:{configurable:!0}};return n.prototype.apply=function(e,t,n,r){var o=t.sourceFrame.width,i=t.sourceFrame.height;this.uniforms.dimensions[0]=o,this.uniforms.dimensions[1]=i,this.uniforms.aspect=i/o,this.uniforms.seed=this.seed,this.uniforms.offset=this.offset,this.uniforms.fillMode=this.fillMode,e.applyFilter(this,t,n,r)},n.prototype._randomizeSizes=function(){var e=this._sizes,t=this._slices-1,n=this.sampleSize,r=Math.min(this.minSize/n,.9/this._slices);if(this.average){for(var o=this._slices,i=1,l=0;l0;t--){var n=Math.random()*t>>0,r=e[t];e[t]=e[n],e[n]=r}},n.prototype._randomizeOffsets=function(){for(var e=0;e0?e:0,a=e<0?-e:0;r.fillStyle="rgba("+s+", "+a+", 0, 1)",r.fillRect(0,o>>0,t,l+1>>0),o+=l}n.baseTexture.update(),this.uniforms.displacementMap=n},r.sizes.set=function(e){for(var t=Math.min(this._slices,e.length),n=0;nthis._maxColors)throw"Length of replacements ("+o+") exceeds the maximum colors length ("+this._maxColors+")";n[3*o]=-1;for(var i=0;i 0.5) then: 1 - 2 * (1 - dst) * (1 - src)\n return vec3((dst.x <= 0.5) ? (2.0 * src.x * dst.x) : (1.0 - 2.0 * (1.0 - dst.x) * (1.0 - src.x)),\n (dst.y <= 0.5) ? (2.0 * src.y * dst.y) : (1.0 - 2.0 * (1.0 - dst.y) * (1.0 - src.y)),\n (dst.z <= 0.5) ? (2.0 * src.z * dst.z) : (1.0 - 2.0 * (1.0 - dst.z) * (1.0 - src.z)));\n}\n\n\nvoid main()\n{\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n vec3 color = gl_FragColor.rgb;\n\n if (sepia > 0.0)\n {\n float gray = (color.x + color.y + color.z) / 3.0;\n vec3 grayscale = vec3(gray);\n\n color = Overlay(SEPIA_RGB, grayscale);\n\n color = grayscale + sepia * (color - grayscale);\n }\n\n vec2 coord = vTextureCoord * filterArea.xy / dimensions.xy;\n\n if (vignetting > 0.0)\n {\n float outter = SQRT_2 - vignetting * SQRT_2;\n vec2 dir = vec2(vec2(0.5, 0.5) - coord);\n dir.y *= dimensions.y / dimensions.x;\n float darker = clamp((outter - length(dir) * SQRT_2) / ( 0.00001 + vignettingBlur * SQRT_2), 0.0, 1.0);\n color.rgb *= darker + (1.0 - darker) * (1.0 - vignettingAlpha);\n }\n\n if (scratchDensity > seed && scratch != 0.0)\n {\n float phase = seed * 256.0;\n float s = mod(floor(phase), 2.0);\n float dist = 1.0 / scratchDensity;\n float d = distance(coord, vec2(seed * dist, abs(s - seed * dist)));\n if (d < seed * 0.6 + 0.4)\n {\n highp float period = scratchDensity * 10.0;\n\n float xx = coord.x * period + phase;\n float aa = abs(mod(xx, 0.5) * 4.0);\n float bb = mod(floor(xx / 0.5), 2.0);\n float yy = (1.0 - bb) * aa + bb * (2.0 - aa);\n\n float kk = 2.0 * period;\n float dw = scratchWidth / dimensions.x * (0.75 + seed);\n float dh = dw * kk;\n\n float tine = (yy - (2.0 - dh));\n\n if (tine > 0.0) {\n float _sign = sign(scratch);\n\n tine = s * tine / period + scratch + 0.1;\n tine = clamp(tine + 1.0, 0.5 + _sign * 0.5, 1.5 + _sign * 0.5);\n\n color.rgb *= tine;\n }\n }\n }\n\n if (noise > 0.0 && noiseSize > 0.0)\n {\n vec2 pixelCoord = vTextureCoord.xy * filterArea.xy;\n pixelCoord.x = floor(pixelCoord.x / noiseSize);\n pixelCoord.y = floor(pixelCoord.y / noiseSize);\n // vec2 d = pixelCoord * noiseSize * vec2(1024.0 + seed * 512.0, 1024.0 - seed * 512.0);\n // float _noise = snoise(d) * 0.5;\n float _noise = rand(pixelCoord * noiseSize * seed) - 0.5;\n color += _noise * noise;\n }\n\n gl_FragColor.rgb = color;\n}\n",ge=function(e){function t(t,n){void 0===n&&(n=0),e.call(this,de,me),this.uniforms.dimensions=new Float32Array(2),"number"==typeof t?(this.seed=t,t=null):this.seed=n,Object.assign(this,{sepia:.3,noise:.3,noiseSize:1,scratch:.5,scratchDensity:.3,scratchWidth:1,vignetting:.3,vignettingAlpha:1,vignettingBlur:.3},t)}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={sepia:{configurable:!0},noise:{configurable:!0},noiseSize:{configurable:!0},scratch:{configurable:!0},scratchDensity:{configurable:!0},scratchWidth:{configurable:!0},vignetting:{configurable:!0},vignettingAlpha:{configurable:!0},vignettingBlur:{configurable:!0}};return t.prototype.apply=function(e,t,n,r){this.uniforms.dimensions[0]=t.sourceFrame.width,this.uniforms.dimensions[1]=t.sourceFrame.height,this.uniforms.seed=this.seed,e.applyFilter(this,t,n,r)},n.sepia.set=function(e){this.uniforms.sepia=e},n.sepia.get=function(){return this.uniforms.sepia},n.noise.set=function(e){this.uniforms.noise=e},n.noise.get=function(){return this.uniforms.noise},n.noiseSize.set=function(e){this.uniforms.noiseSize=e},n.noiseSize.get=function(){return this.uniforms.noiseSize},n.scratch.set=function(e){this.uniforms.scratch=e},n.scratch.get=function(){return this.uniforms.scratch},n.scratchDensity.set=function(e){this.uniforms.scratchDensity=e},n.scratchDensity.get=function(){return this.uniforms.scratchDensity},n.scratchWidth.set=function(e){this.uniforms.scratchWidth=e},n.scratchWidth.get=function(){return this.uniforms.scratchWidth},n.vignetting.set=function(e){this.uniforms.vignetting=e},n.vignetting.get=function(){return this.uniforms.vignetting},n.vignettingAlpha.set=function(e){this.uniforms.vignettingAlpha=e},n.vignettingAlpha.get=function(){return this.uniforms.vignettingAlpha},n.vignettingBlur.set=function(e){this.uniforms.vignettingBlur=e},n.vignettingBlur.get=function(){return this.uniforms.vignettingBlur},Object.defineProperties(t.prototype,n),t}(t.Filter),ve=n,xe="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\n\nuniform vec2 thickness;\nuniform vec4 outlineColor;\nuniform vec4 filterClamp;\n\nconst float DOUBLE_PI = 3.14159265358979323846264 * 2.;\n\nvoid main(void) {\n vec4 ownColor = texture2D(uSampler, vTextureCoord);\n vec4 curColor;\n float maxAlpha = 0.;\n vec2 displaced;\n for (float angle = 0.; angle <= DOUBLE_PI; angle += ${angleStep}) {\n displaced.x = vTextureCoord.x + thickness.x * cos(angle);\n displaced.y = vTextureCoord.y + thickness.y * sin(angle);\n curColor = texture2D(uSampler, clamp(displaced, filterClamp.xy, filterClamp.zw));\n maxAlpha = max(maxAlpha, curColor.a);\n }\n float resultAlpha = max(maxAlpha, ownColor.a);\n gl_FragColor = vec4((ownColor.rgb + outlineColor.rgb * (1. - ownColor.a)) * resultAlpha, resultAlpha);\n}\n",ye=function(e){function n(t,r,o){void 0===t&&(t=1),void 0===r&&(r=0),void 0===o&&(o=.1);var i=Math.max(o*n.MAX_SAMPLES,n.MIN_SAMPLES),l=(2*Math.PI/i).toFixed(7);e.call(this,ve,xe.replace(/\$\{angleStep\}/,l)),this.uniforms.thickness=new Float32Array([0,0]),this.thickness=t,this.uniforms.outlineColor=new Float32Array([0,0,0,1]),this.color=r,this.quality=o}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={color:{configurable:!0}};return n.prototype.apply=function(e,t,n,r){this.uniforms.thickness[0]=this.thickness/t.size.width,this.uniforms.thickness[1]=this.thickness/t.size.height,e.applyFilter(this,t,n,r)},r.color.get=function(){return t.utils.rgb2hex(this.uniforms.outlineColor)},r.color.set=function(e){t.utils.hex2rgb(e,this.uniforms.outlineColor)},Object.defineProperties(n.prototype,r),n}(t.Filter);ye.MIN_SAMPLES=1,ye.MAX_SAMPLES=100;var be=n,_e="precision mediump float;\n\nvarying vec2 vTextureCoord;\n\nuniform vec2 size;\nuniform sampler2D uSampler;\n\nuniform vec4 filterArea;\n\nvec2 mapCoord( vec2 coord )\n{\n coord *= filterArea.xy;\n coord += filterArea.zw;\n\n return coord;\n}\n\nvec2 unmapCoord( vec2 coord )\n{\n coord -= filterArea.zw;\n coord /= filterArea.xy;\n\n return coord;\n}\n\nvec2 pixelate(vec2 coord, vec2 size)\n{\n\treturn floor( coord / size ) * size;\n}\n\nvoid main(void)\n{\n vec2 coord = mapCoord(vTextureCoord);\n\n coord = pixelate(coord, size);\n\n coord = unmapCoord(coord);\n\n gl_FragColor = texture2D(uSampler, coord);\n}\n",Ce=function(e){function t(t){void 0===t&&(t=10),e.call(this,be,_e),this.size=t}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={size:{configurable:!0}};return n.size.get=function(){return this.uniforms.size},n.size.set=function(e){"number"==typeof e&&(e=[e,e]),this.uniforms.size=e},Object.defineProperties(t.prototype,n),t}(t.Filter),Se=n,Fe="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\nuniform vec4 filterArea;\n\nuniform float uRadian;\nuniform vec2 uCenter;\nuniform float uRadius;\nuniform int uKernelSize;\n\nconst int MAX_KERNEL_SIZE = 2048;\n\nvoid main(void)\n{\n vec4 color = texture2D(uSampler, vTextureCoord);\n\n if (uKernelSize == 0)\n {\n gl_FragColor = color;\n return;\n }\n\n float aspect = filterArea.y / filterArea.x;\n vec2 center = uCenter.xy / filterArea.xy;\n float gradient = uRadius / filterArea.x * 0.3;\n float radius = uRadius / filterArea.x - gradient * 0.5;\n int k = uKernelSize - 1;\n\n vec2 coord = vTextureCoord;\n vec2 dir = vec2(center - coord);\n float dist = length(vec2(dir.x, dir.y * aspect));\n\n float radianStep = uRadian;\n if (radius >= 0.0 && dist > radius) {\n float delta = dist - radius;\n float gap = gradient;\n float scale = 1.0 - abs(delta / gap);\n if (scale <= 0.0) {\n gl_FragColor = color;\n return;\n }\n radianStep *= scale;\n }\n radianStep /= float(k);\n\n float s = sin(radianStep);\n float c = cos(radianStep);\n mat2 rotationMatrix = mat2(vec2(c, -s), vec2(s, c));\n\n for(int i = 0; i < MAX_KERNEL_SIZE - 1; i++) {\n if (i == k) {\n break;\n }\n\n coord -= center;\n coord.y *= aspect;\n coord = rotationMatrix * coord;\n coord.y /= aspect;\n coord += center;\n\n vec4 sample = texture2D(uSampler, coord);\n\n // switch to pre-multiplied alpha to correctly blur transparent images\n // sample.rgb *= sample.a;\n\n color += sample;\n }\n\n gl_FragColor = color / float(uKernelSize);\n}\n",ze=function(e){function t(t,n,r,o){void 0===t&&(t=0),void 0===n&&(n=[0,0]),void 0===r&&(r=5),void 0===o&&(o=-1),e.call(this,Se,Fe),this._angle=0,this.angle=t,this.center=n,this.kernelSize=r,this.radius=o}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={angle:{configurable:!0},center:{configurable:!0},radius:{configurable:!0}};return t.prototype.apply=function(e,t,n,r){this.uniforms.uKernelSize=0!==this._angle?this.kernelSize:0,e.applyFilter(this,t,n,r)},n.angle.set=function(e){this._angle=e,this.uniforms.uRadian=e*Math.PI/180},n.angle.get=function(){return this._angle},n.center.get=function(){return this.uniforms.uCenter},n.center.set=function(e){this.uniforms.uCenter=e},n.radius.get=function(){return this.uniforms.uRadius},n.radius.set=function(e){(e<0||e===1/0)&&(e=-1),this.uniforms.uRadius=e},Object.defineProperties(t.prototype,n),t}(t.Filter),Ae=n,we="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\n\nuniform vec4 filterArea;\nuniform vec4 filterClamp;\nuniform vec2 dimensions;\n\nuniform bool mirror;\nuniform float boundary;\nuniform vec2 amplitude;\nuniform vec2 waveLength;\nuniform vec2 alpha;\nuniform float time;\n\nfloat rand(vec2 co) {\n return fract(sin(dot(co.xy, vec2(12.9898, 78.233))) * 43758.5453);\n}\n\nvoid main(void)\n{\n vec2 pixelCoord = vTextureCoord.xy * filterArea.xy;\n vec2 coord = pixelCoord / dimensions;\n\n if (coord.y < boundary) {\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n return;\n }\n\n float k = (coord.y - boundary) / (1. - boundary + 0.0001);\n float areaY = boundary * dimensions.y / filterArea.y;\n float v = areaY + areaY - vTextureCoord.y;\n float y = mirror ? v : vTextureCoord.y;\n\n float _amplitude = ((amplitude.y - amplitude.x) * k + amplitude.x ) / filterArea.x;\n float _waveLength = ((waveLength.y - waveLength.x) * k + waveLength.x) / filterArea.y;\n float _alpha = (alpha.y - alpha.x) * k + alpha.x;\n\n float x = vTextureCoord.x + cos(v * 6.28 / _waveLength - time) * _amplitude;\n x = clamp(x, filterClamp.x, filterClamp.z);\n\n vec4 color = texture2D(uSampler, vec2(x, y));\n\n gl_FragColor = color * _alpha;\n}\n",Te=function(e){function t(t){e.call(this,Ae,we),this.uniforms.amplitude=new Float32Array(2),this.uniforms.waveLength=new Float32Array(2),this.uniforms.alpha=new Float32Array(2),this.uniforms.dimensions=new Float32Array(2),Object.assign(this,{mirror:!0,boundary:.5,amplitude:[0,20],waveLength:[30,100],alpha:[1,1],time:0},t)}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={mirror:{configurable:!0},boundary:{configurable:!0},amplitude:{configurable:!0},waveLength:{configurable:!0},alpha:{configurable:!0}};return t.prototype.apply=function(e,t,n,r){this.uniforms.dimensions[0]=t.sourceFrame.width,this.uniforms.dimensions[1]=t.sourceFrame.height,this.uniforms.time=this.time,e.applyFilter(this,t,n,r)},n.mirror.set=function(e){this.uniforms.mirror=e},n.mirror.get=function(){return this.uniforms.mirror},n.boundary.set=function(e){this.uniforms.boundary=e},n.boundary.get=function(){return this.uniforms.boundary},n.amplitude.set=function(e){this.uniforms.amplitude[0]=e[0],this.uniforms.amplitude[1]=e[1]},n.amplitude.get=function(){return this.uniforms.amplitude},n.waveLength.set=function(e){this.uniforms.waveLength[0]=e[0],this.uniforms.waveLength[1]=e[1]},n.waveLength.get=function(){return this.uniforms.waveLength},n.alpha.set=function(e){this.uniforms.alpha[0]=e[0],this.uniforms.alpha[1]=e[1]},n.alpha.get=function(){return this.uniforms.alpha},Object.defineProperties(t.prototype,n),t}(t.Filter),De=n,Oe="precision mediump float;\n\nvarying vec2 vTextureCoord;\n\nuniform sampler2D uSampler;\nuniform vec4 filterArea;\nuniform vec2 red;\nuniform vec2 green;\nuniform vec2 blue;\n\nvoid main(void)\n{\n gl_FragColor.r = texture2D(uSampler, vTextureCoord + red/filterArea.xy).r;\n gl_FragColor.g = texture2D(uSampler, vTextureCoord + green/filterArea.xy).g;\n gl_FragColor.b = texture2D(uSampler, vTextureCoord + blue/filterArea.xy).b;\n gl_FragColor.a = texture2D(uSampler, vTextureCoord).a;\n}\n",Pe=function(e){function t(t,n,r){void 0===t&&(t=[-10,0]),void 0===n&&(n=[0,10]),void 0===r&&(r=[0,0]),e.call(this,De,Oe),this.red=t,this.green=n,this.blue=r}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={red:{configurable:!0},green:{configurable:!0},blue:{configurable:!0}};return n.red.get=function(){return this.uniforms.red},n.red.set=function(e){this.uniforms.red=e},n.green.get=function(){return this.uniforms.green},n.green.set=function(e){this.uniforms.green=e},n.blue.get=function(){return this.uniforms.blue},n.blue.set=function(e){this.uniforms.blue=e},Object.defineProperties(t.prototype,n),t}(t.Filter),Me=n,Re="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\nuniform vec4 filterArea;\nuniform vec4 filterClamp;\n\nuniform vec2 center;\n\nuniform float amplitude;\nuniform float wavelength;\n// uniform float power;\nuniform float brightness;\nuniform float speed;\nuniform float radius;\n\nuniform float time;\n\nconst float PI = 3.14159;\n\nvoid main()\n{\n float halfWavelength = wavelength * 0.5 / filterArea.x;\n float maxRadius = radius / filterArea.x;\n float currentRadius = time * speed / filterArea.x;\n\n float fade = 1.0;\n\n if (maxRadius > 0.0) {\n if (currentRadius > maxRadius) {\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n return;\n }\n fade = 1.0 - pow(currentRadius / maxRadius, 2.0);\n }\n\n vec2 dir = vec2(vTextureCoord - center / filterArea.xy);\n dir.y *= filterArea.y / filterArea.x;\n float dist = length(dir);\n\n if (dist <= 0.0 || dist < currentRadius - halfWavelength || dist > currentRadius + halfWavelength) {\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n return;\n }\n\n vec2 diffUV = normalize(dir);\n\n float diff = (dist - currentRadius) / halfWavelength;\n\n float p = 1.0 - pow(abs(diff), 2.0);\n\n // float powDiff = diff * pow(p, 2.0) * ( amplitude * fade );\n float powDiff = 1.25 * sin(diff * PI) * p * ( amplitude * fade );\n\n vec2 offset = diffUV * powDiff / filterArea.xy;\n\n // Do clamp :\n vec2 coord = vTextureCoord + offset;\n vec2 clampedCoord = clamp(coord, filterClamp.xy, filterClamp.zw);\n vec4 color = texture2D(uSampler, clampedCoord);\n if (coord != clampedCoord) {\n color *= max(0.0, 1.0 - length(coord - clampedCoord));\n }\n\n // No clamp :\n // gl_FragColor = texture2D(uSampler, vTextureCoord + offset);\n\n color.rgb *= 1.0 + (brightness - 1.0) * p * fade;\n\n gl_FragColor = color;\n}\n",je=function(e){function t(t,n,r){void 0===t&&(t=[0,0]),void 0===n&&(n={}),void 0===r&&(r=0),e.call(this,Me,Re),this.center=t,Array.isArray(n)&&(console.warn("Deprecated Warning: ShockwaveFilter params Array has been changed to options Object."),n={}),n=Object.assign({amplitude:30,wavelength:160,brightness:1,speed:500,radius:-1},n),this.amplitude=n.amplitude,this.wavelength=n.wavelength,this.brightness=n.brightness,this.speed=n.speed,this.radius=n.radius,this.time=r}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={center:{configurable:!0},amplitude:{configurable:!0},wavelength:{configurable:!0},brightness:{configurable:!0},speed:{configurable:!0},radius:{configurable:!0}};return t.prototype.apply=function(e,t,n,r){this.uniforms.time=this.time,e.applyFilter(this,t,n,r)},n.center.get=function(){return this.uniforms.center},n.center.set=function(e){this.uniforms.center=e},n.amplitude.get=function(){return this.uniforms.amplitude},n.amplitude.set=function(e){this.uniforms.amplitude=e},n.wavelength.get=function(){return this.uniforms.wavelength},n.wavelength.set=function(e){this.uniforms.wavelength=e},n.brightness.get=function(){return this.uniforms.brightness},n.brightness.set=function(e){this.uniforms.brightness=e},n.speed.get=function(){return this.uniforms.speed},n.speed.set=function(e){this.uniforms.speed=e},n.radius.get=function(){return this.uniforms.radius},n.radius.set=function(e){this.uniforms.radius=e},Object.defineProperties(t.prototype,n),t}(t.Filter),Le=n,ke="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\nuniform sampler2D uLightmap;\nuniform vec4 filterArea;\nuniform vec2 dimensions;\nuniform vec4 ambientColor;\nvoid main() {\n vec4 diffuseColor = texture2D(uSampler, vTextureCoord);\n vec2 lightCoord = (vTextureCoord * filterArea.xy) / dimensions;\n vec4 light = texture2D(uLightmap, lightCoord);\n vec3 ambient = ambientColor.rgb * ambientColor.a;\n vec3 intensity = ambient + light.rgb;\n vec3 finalColor = diffuseColor.rgb * intensity;\n gl_FragColor = vec4(finalColor, diffuseColor.a);\n}\n",Ie=function(e){function n(t,n,r){void 0===n&&(n=0),void 0===r&&(r=1),e.call(this,Le,ke),this.uniforms.dimensions=new Float32Array(2),this.uniforms.ambientColor=new Float32Array([0,0,0,r]),this.texture=t,this.color=n}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={texture:{configurable:!0},color:{configurable:!0},alpha:{configurable:!0}};return n.prototype.apply=function(e,t,n,r){this.uniforms.dimensions[0]=t.sourceFrame.width,this.uniforms.dimensions[1]=t.sourceFrame.height,e.applyFilter(this,t,n,r)},r.texture.get=function(){return this.uniforms.uLightmap},r.texture.set=function(e){this.uniforms.uLightmap=e},r.color.set=function(e){var n=this.uniforms.ambientColor;"number"==typeof e?(t.utils.hex2rgb(e,n),this._color=e):(n[0]=e[0],n[1]=e[1],n[2]=e[2],n[3]=e[3],this._color=t.utils.rgb2hex(n))},r.color.get=function(){return this._color},r.alpha.get=function(){return this.uniforms.ambientColor[3]},r.alpha.set=function(e){this.uniforms.ambientColor[3]=e},Object.defineProperties(n.prototype,r),n}(t.Filter),Ee=n,Be="varying vec2 vTextureCoord;\n\nuniform sampler2D uSampler;\nuniform float blur;\nuniform float gradientBlur;\nuniform vec2 start;\nuniform vec2 end;\nuniform vec2 delta;\nuniform vec2 texSize;\n\nfloat random(vec3 scale, float seed)\n{\n return fract(sin(dot(gl_FragCoord.xyz + seed, scale)) * 43758.5453 + seed);\n}\n\nvoid main(void)\n{\n vec4 color = vec4(0.0);\n float total = 0.0;\n\n float offset = random(vec3(12.9898, 78.233, 151.7182), 0.0);\n vec2 normal = normalize(vec2(start.y - end.y, end.x - start.x));\n float radius = smoothstep(0.0, 1.0, abs(dot(vTextureCoord * texSize - start, normal)) / gradientBlur) * blur;\n\n for (float t = -30.0; t <= 30.0; t++)\n {\n float percent = (t + offset - 0.5) / 30.0;\n float weight = 1.0 - abs(percent);\n vec4 sample = texture2D(uSampler, vTextureCoord + delta / texSize * percent * radius);\n sample.rgb *= sample.a;\n color += sample * weight;\n total += weight;\n }\n\n color /= total;\n color.rgb /= color.a + 0.00001;\n\n gl_FragColor = color;\n}\n",Xe=function(e){function n(n,r,o,i){void 0===n&&(n=100),void 0===r&&(r=600),void 0===o&&(o=null),void 0===i&&(i=null),e.call(this,Ee,Be),this.uniforms.blur=n,this.uniforms.gradientBlur=r,this.uniforms.start=o||new t.Point(0,window.innerHeight/2),this.uniforms.end=i||new t.Point(600,window.innerHeight/2),this.uniforms.delta=new t.Point(30,30),this.uniforms.texSize=new t.Point(window.innerWidth,window.innerHeight),this.updateDelta()}e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n;var r={blur:{configurable:!0},gradientBlur:{configurable:!0},start:{configurable:!0},end:{configurable:!0}};return n.prototype.updateDelta=function(){this.uniforms.delta.x=0,this.uniforms.delta.y=0},r.blur.get=function(){return this.uniforms.blur},r.blur.set=function(e){this.uniforms.blur=e},r.gradientBlur.get=function(){return this.uniforms.gradientBlur},r.gradientBlur.set=function(e){this.uniforms.gradientBlur=e},r.start.get=function(){return this.uniforms.start},r.start.set=function(e){this.uniforms.start=e,this.updateDelta()},r.end.get=function(){return this.uniforms.end},r.end.set=function(e){this.uniforms.end=e,this.updateDelta()},Object.defineProperties(n.prototype,r),n}(t.Filter),qe=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.updateDelta=function(){var e=this.uniforms.end.x-this.uniforms.start.x,t=this.uniforms.end.y-this.uniforms.start.y,n=Math.sqrt(e*e+t*t);this.uniforms.delta.x=e/n,this.uniforms.delta.y=t/n},t}(Xe),Ne=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.updateDelta=function(){var e=this.uniforms.end.x-this.uniforms.start.x,t=this.uniforms.end.y-this.uniforms.start.y,n=Math.sqrt(e*e+t*t);this.uniforms.delta.x=-t/n,this.uniforms.delta.y=e/n},t}(Xe),We=function(e){function t(t,n,r,o){void 0===t&&(t=100),void 0===n&&(n=600),void 0===r&&(r=null),void 0===o&&(o=null),e.call(this),this.tiltShiftXFilter=new qe(t,n,r,o),this.tiltShiftYFilter=new Ne(t,n,r,o)}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={blur:{configurable:!0},gradientBlur:{configurable:!0},start:{configurable:!0},end:{configurable:!0}};return t.prototype.apply=function(e,t,n){var r=e.getRenderTarget(!0);this.tiltShiftXFilter.apply(e,t,r),this.tiltShiftYFilter.apply(e,r,n),e.returnRenderTarget(r)},n.blur.get=function(){return this.tiltShiftXFilter.blur},n.blur.set=function(e){this.tiltShiftXFilter.blur=this.tiltShiftYFilter.blur=e},n.gradientBlur.get=function(){return this.tiltShiftXFilter.gradientBlur},n.gradientBlur.set=function(e){this.tiltShiftXFilter.gradientBlur=this.tiltShiftYFilter.gradientBlur=e},n.start.get=function(){return this.tiltShiftXFilter.start},n.start.set=function(e){this.tiltShiftXFilter.start=this.tiltShiftYFilter.start=e},n.end.get=function(){return this.tiltShiftXFilter.end},n.end.set=function(e){this.tiltShiftXFilter.end=this.tiltShiftYFilter.end=e},Object.defineProperties(t.prototype,n),t}(t.Filter),Ge=n,Ke="varying vec2 vTextureCoord;\n\nuniform sampler2D uSampler;\nuniform float radius;\nuniform float angle;\nuniform vec2 offset;\nuniform vec4 filterArea;\n\nvec2 mapCoord( vec2 coord )\n{\n coord *= filterArea.xy;\n coord += filterArea.zw;\n\n return coord;\n}\n\nvec2 unmapCoord( vec2 coord )\n{\n coord -= filterArea.zw;\n coord /= filterArea.xy;\n\n return coord;\n}\n\nvec2 twist(vec2 coord)\n{\n coord -= offset;\n\n float dist = length(coord);\n\n if (dist < radius)\n {\n float ratioDist = (radius - dist) / radius;\n float angleMod = ratioDist * ratioDist * angle;\n float s = sin(angleMod);\n float c = cos(angleMod);\n coord = vec2(coord.x * c - coord.y * s, coord.x * s + coord.y * c);\n }\n\n coord += offset;\n\n return coord;\n}\n\nvoid main(void)\n{\n\n vec2 coord = mapCoord(vTextureCoord);\n\n coord = twist(coord);\n\n coord = unmapCoord(coord);\n\n gl_FragColor = texture2D(uSampler, coord );\n\n}\n",Ye=function(e){function t(t,n,r){void 0===t&&(t=200),void 0===n&&(n=4),void 0===r&&(r=20),e.call(this,Ge,Ke),this.radius=t,this.angle=n,this.padding=r}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={offset:{configurable:!0},radius:{configurable:!0},angle:{configurable:!0}};return n.offset.get=function(){return this.uniforms.offset},n.offset.set=function(e){this.uniforms.offset=e},n.radius.get=function(){return this.uniforms.radius},n.radius.set=function(e){this.uniforms.radius=e},n.angle.get=function(){return this.uniforms.angle},n.angle.set=function(e){this.uniforms.angle=e},Object.defineProperties(t.prototype,n),t}(t.Filter),Qe=n,Ue="varying vec2 vTextureCoord;\nuniform sampler2D uSampler;\nuniform vec4 filterArea;\n\nuniform vec2 uCenter;\nuniform float uStrength;\nuniform float uInnerRadius;\nuniform float uRadius;\n\nconst float MAX_KERNEL_SIZE = 32.0;\n\n// author: http://byteblacksmith.com/improvements-to-the-canonical-one-liner-glsl-rand-for-opengl-es-2-0/\nhighp float rand(vec2 co, float seed) {\n const highp float a = 12.9898, b = 78.233, c = 43758.5453;\n highp float dt = dot(co + seed, vec2(a, b)), sn = mod(dt, 3.14159);\n return fract(sin(sn) * c + seed);\n}\n\nvoid main() {\n\n float minGradient = uInnerRadius * 0.3;\n float innerRadius = (uInnerRadius + minGradient * 0.5) / filterArea.x;\n\n float gradient = uRadius * 0.3;\n float radius = (uRadius - gradient * 0.5) / filterArea.x;\n\n float countLimit = MAX_KERNEL_SIZE;\n\n vec2 dir = vec2(uCenter.xy / filterArea.xy - vTextureCoord);\n float dist = length(vec2(dir.x, dir.y * filterArea.y / filterArea.x));\n\n float strength = uStrength;\n\n float delta = 0.0;\n float gap;\n if (dist < innerRadius) {\n delta = innerRadius - dist;\n gap = minGradient;\n } else if (radius >= 0.0 && dist > radius) { // radius < 0 means it's infinity\n delta = dist - radius;\n gap = gradient;\n }\n\n if (delta > 0.0) {\n float normalCount = gap / filterArea.x;\n delta = (normalCount - delta) / normalCount;\n countLimit *= delta;\n strength *= delta;\n if (countLimit < 1.0)\n {\n gl_FragColor = texture2D(uSampler, vTextureCoord);\n return;\n }\n }\n\n // randomize the lookup values to hide the fixed number of samples\n float offset = rand(vTextureCoord, 0.0);\n\n float total = 0.0;\n vec4 color = vec4(0.0);\n\n dir *= strength;\n\n for (float t = 0.0; t < MAX_KERNEL_SIZE; t++) {\n float percent = (t + offset) / MAX_KERNEL_SIZE;\n float weight = 4.0 * (percent - percent * percent);\n vec2 p = vTextureCoord + dir * percent;\n vec4 sample = texture2D(uSampler, p);\n\n // switch to pre-multiplied alpha to correctly blur transparent images\n // sample.rgb *= sample.a;\n\n color += sample * weight;\n total += weight;\n\n if (t > countLimit){\n break;\n }\n }\n\n color /= total;\n // switch back from pre-multiplied alpha\n // color.rgb /= color.a + 0.00001;\n\n gl_FragColor = color;\n}\n",Ze=function(e){function t(t,n,r,o){void 0===t&&(t=.1),void 0===n&&(n=[0,0]),void 0===r&&(r=0),void 0===o&&(o=-1),e.call(this,Qe,Ue),this.center=n,this.strength=t,this.innerRadius=r,this.radius=o}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var n={center:{configurable:!0},strength:{configurable:!0},innerRadius:{configurable:!0},radius:{configurable:!0}};return n.center.get=function(){return this.uniforms.uCenter},n.center.set=function(e){this.uniforms.uCenter=e},n.strength.get=function(){return this.uniforms.uStrength},n.strength.set=function(e){this.uniforms.uStrength=e},n.innerRadius.get=function(){return this.uniforms.uInnerRadius},n.innerRadius.set=function(e){this.uniforms.uInnerRadius=e},n.radius.get=function(){return this.uniforms.uRadius},n.radius.set=function(e){(e<0||e===1/0)&&(e=-1),this.uniforms.uRadius=e},Object.defineProperties(t.prototype,n),t}(t.Filter);return e.AdjustmentFilter=o,e.AdvancedBloomFilter=p,e.AsciiFilter=g,e.BevelFilter=y,e.BloomFilter=F,e.BulgePinchFilter=w,e.ColorMapFilter=O,e.ColorReplaceFilter=R,e.ConvolutionFilter=k,e.CrossHatchFilter=B,e.CRTFilter=N,e.DotFilter=K,e.DropShadowFilter=U,e.EmbossFilter=H,e.GlitchFilter=ee,e.GlowFilter=re,e.GodrayFilter=se,e.KawaseBlurFilter=a,e.MotionBlurFilter=ce,e.MultiColorReplaceFilter=pe,e.OldFilmFilter=ge,e.OutlineFilter=ye,e.PixelateFilter=Ce,e.RadialBlurFilter=ze,e.ReflectionFilter=Te,e.RGBSplitFilter=Pe,e.ShockwaveFilter=je,e.SimpleLightmapFilter=Ie,e.TiltShiftFilter=We,e.TiltShiftAxisFilter=Xe,e.TiltShiftXFilter=qe,e.TiltShiftYFilter=Ne,e.TwistFilter=Ye,e.ZoomBlurFilter=Ze,e}({},PIXI);Object.assign(PIXI.filters,this?this.__filters:__filters); -//# sourceMappingURL=pixi-filters.js.map + /*! * pixi-particles - v4.1.0 @@ -72564,7 +72564,7 @@ this.PIXI = this.PIXI || {}; exports.PropertyNode = PropertyNode; }(this.PIXI.particles = this.PIXI.particles || {}, PIXI)); -//# sourceMappingURL=pixi-particles.js.map + var pixi_projection; (function (pixi_projection) { diff --git a/gulpfile.js b/gulpfile.js index 19206d9..57823f9 100644 --- a/gulpfile.js +++ b/gulpfile.js @@ -2,6 +2,7 @@ const {src, dest, parallel} = require('gulp'); const uglify = require('gulp-uglify'); const rename = require('gulp-rename'); const concat = require('gulp-concat'); +const replace = require('gulp-replace'); function vendors() { return src([ @@ -19,6 +20,7 @@ function vendors() { './lib/3rdparty/convertPointFromPageToNode.js', ], {sourcemaps: false}) .pipe(concat('iwmlib.3rdparty.js')) + .pipe(replace(/^\/\/# sourceMappingURL=.*$/gmi, '')) .pipe(dest('dist', {sourcemaps: false})) .pipe(rename({extname: '.min.js'})) .pipe(uglify()) @@ -32,6 +34,7 @@ function preload() { './lib/3rdparty/convertPointFromPageToNode.js', ], {sourcemaps: false}) .pipe(concat('iwmlib.3rdparty.preload.js')) + .pipe(replace(/^\/\/# sourceMappingURL=.*$/gmi, '')) .pipe(dest('dist', {sourcemaps: false})) .pipe(rename({extname: '.min.js'})) .pipe(uglify()) diff --git a/package-lock.json b/package-lock.json index 7690ffc..ef55432 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "iwmlib", - "version": "1.3.0", + "version": "1.0.4", "lockfileVersion": 1, "requires": true, "dependencies": { @@ -485,6 +485,12 @@ "integrity": "sha512-EgmjVLMn22z7eGGv3kcnHwSnJXmFHjISTY9E/S5lIcTD3Oxw05QTcBLNkJFzcb3cNueUdF/IN4U+d78V0zO8Hw==", "dev": true }, + "binaryextensions": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/binaryextensions/-/binaryextensions-2.1.2.tgz", + "integrity": "sha512-xVNN69YGDghOqCCtA6FI7avYrr02mTJjOgB0/f1VPD3pJC8QEvjTKWc4epDx8AqxxA75NI0QpVM2gPJXUbE4Tg==", + "dev": true + }, "bit-twiddle": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/bit-twiddle/-/bit-twiddle-1.0.2.tgz", @@ -987,6 +993,12 @@ "resolved": "https://registry.npmjs.org/earcut/-/earcut-2.1.5.tgz", "integrity": "sha512-QFWC7ywTVLtvRAJTVp8ugsuuGQ5mVqNmJ1cRYeLrSHgP3nycr2RHTJob9OtM0v8ujuoKN0NY1a93J/omeTL1PA==" }, + "editions": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/editions/-/editions-1.3.4.tgz", + "integrity": "sha512-gzao+mxnYDzIysXKMQi/+M1mjy/rjestjg6OPoYTtI+3Izp23oiGZitsl9lPDPiTGXbcSIk1iJWhliSaglxnUg==", + "dev": true + }, "end-of-stream": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", @@ -1049,6 +1061,12 @@ "es6-symbol": "^3.1.1" } }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true + }, "escodegen": { "version": "1.3.3", "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.3.3.tgz", @@ -2334,6 +2352,17 @@ "integrity": "sha512-swzbIGb/arEoFK89tPY58vg3Ok1bw+d35PfUNwWqdo7KM4jkmuGA78JiDNqR+JeZFaeeHnRg9N7aihX3YPmsyg==", "dev": true }, + "gulp-replace": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/gulp-replace/-/gulp-replace-1.0.0.tgz", + "integrity": "sha512-lgdmrFSI1SdhNMXZQbrC75MOl1UjYWlOWNbNRnz+F/KHmgxt3l6XstBoAYIdadwETFyG/6i+vWUSCawdC3pqOw==", + "dev": true, + "requires": { + "istextorbinary": "2.2.1", + "readable-stream": "^2.0.1", + "replacestream": "^4.0.0" + } + }, "gulp-uglify": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/gulp-uglify/-/gulp-uglify-3.0.2.tgz", @@ -2687,6 +2716,17 @@ "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", "dev": true }, + "istextorbinary": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/istextorbinary/-/istextorbinary-2.2.1.tgz", + "integrity": "sha512-TS+hoFl8Z5FAFMK38nhBkdLt44CclNRgDHWeMgsV8ko3nDlr/9UI2Sf839sW7enijf8oKsZYXRvM8g0it9Zmcw==", + "dev": true, + "requires": { + "binaryextensions": "2", + "editions": "^1.3.3", + "textextensions": "2" + } + }, "json-stable-stringify-without-jsonify": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", @@ -3566,6 +3606,17 @@ "remove-trailing-separator": "^1.1.0" } }, + "replacestream": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/replacestream/-/replacestream-4.0.3.tgz", + "integrity": "sha512-AC0FiLS352pBBiZhd4VXB1Ab/lh0lEgpP+GGvZqbQh8a5cmXVoTe5EX/YeTFArnp4SRGTHh1qCHu9lGs1qG8sA==", + "dev": true, + "requires": { + "escape-string-regexp": "^1.0.3", + "object-assign": "^4.0.1", + "readable-stream": "^2.0.2" + } + }, "require-directory": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", @@ -4052,6 +4103,12 @@ "integrity": "sha1-KtNxaWKUmPylvIQkMJbTzeDsOjQ=", "dev": true }, + "textextensions": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/textextensions/-/textextensions-2.4.0.tgz", + "integrity": "sha512-qftQXnX1DzpSV8EddtHIT0eDDEiBF8ywhFYR2lI9xrGtxqKN+CvLXhACeCIGbCpQfxxERbrkZEFb8cZcDKbVZA==", + "dev": true + }, "through2": { "version": "2.0.5", "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", diff --git a/package.json b/package.json index 629ad91..9d29799 100644 --- a/package.json +++ b/package.json @@ -24,6 +24,7 @@ "gulp": "^4.0.0", "gulp-concat": "^2.6.1", "gulp-rename": "^1.4.0", + "gulp-replace": "^1.0.0", "gulp-uglify": "^3.0.2" }, "dependencies": {