(function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(); else if(typeof define === 'function' && define.amd) define([], factory); else if(typeof exports === 'object') exports["Quagga"] = factory(); else root["Quagga"] = factory(); })(window, function() { return /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) { /******/ return installedModules[moduleId].exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ i: moduleId, /******/ l: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Flag the module as loaded /******/ module.l = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = modules; /******/ /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ __webpack_require__.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ __webpack_require__.t = function(value, mode) { /******/ if(mode & 1) value = __webpack_require__(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ __webpack_require__.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = function(module) { /******/ var getter = module && module.__esModule ? /******/ function getDefault() { return module['default']; } : /******/ function getModuleExports() { return module; }; /******/ __webpack_require__.d(getter, 'a', getter); /******/ return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // __webpack_public_path__ /******/ __webpack_require__.p = "/"; /******/ /******/ /******/ // Load entry module and return exports /******/ return __webpack_require__(__webpack_require__.s = 67); /******/ }) /************************************************************************/ /******/ ([ /* 0 */ /***/ (function(module, exports, __webpack_require__) { var toPropertyKey = __webpack_require__(52); function _defineProperty(e, r, t) { return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } module.exports = _defineProperty, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 1 */ /***/ (function(module, exports) { function _getPrototypeOf(t) { return module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, module.exports.__esModule = true, module.exports["default"] = module.exports, _getPrototypeOf(t); } module.exports = _getPrototypeOf, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 2 */ /***/ (function(module, exports) { function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } module.exports = _classCallCheck, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 3 */ /***/ (function(module, exports, __webpack_require__) { var toPropertyKey = __webpack_require__(52); function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, toPropertyKey(o.key), o); } } function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } module.exports = _createClass, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 4 */ /***/ (function(module, exports, __webpack_require__) { var _typeof = __webpack_require__(8)["default"]; var assertThisInitialized = __webpack_require__(140); function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return assertThisInitialized(t); } module.exports = _possibleConstructorReturn, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 5 */ /***/ (function(module, exports, __webpack_require__) { var setPrototypeOf = __webpack_require__(32); function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && setPrototypeOf(t, e); } module.exports = _inherits, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 6 */ /***/ (function(module, exports, __webpack_require__) { // TODO(Babel 8): Remove this file. var runtime = __webpack_require__(136)(); module.exports = runtime; // Copied from https://github.com/facebook/regenerator/blob/main/packages/runtime/runtime.js#L736= try { regeneratorRuntime = runtime; } catch (accidentalStrictMode) { if (typeof globalThis === "object") { globalThis.regeneratorRuntime = runtime; } else { Function("r", "regeneratorRuntime = r")(runtime); } } /***/ }), /* 7 */ /***/ (function(module, exports) { function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } module.exports = _asyncToGenerator, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 8 */ /***/ (function(module, exports) { function _typeof(o) { "@babel/helpers - typeof"; return module.exports = _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, module.exports.__esModule = true, module.exports["default"] = module.exports, _typeof(o); } module.exports = _typeof, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 9 */ /***/ (function(module, exports) { /** * Checks if `value` is the * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types) * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) * * @static * @memberOf _ * @since 0.1.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is an object, else `false`. * @example * * _.isObject({}); * // => true * * _.isObject([1, 2, 3]); * // => true * * _.isObject(_.noop); * // => true * * _.isObject(null); * // => false */ function isObject(value) { var type = typeof value; return value != null && (type == 'object' || type == 'function'); } module.exports = isObject; /***/ }), /* 10 */ /***/ (function(module, exports, __webpack_require__) { var superPropBase = __webpack_require__(141); function _get() { return module.exports = _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) { var p = superPropBase(e, t); if (p) { var n = Object.getOwnPropertyDescriptor(p, t); return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value; } }, module.exports.__esModule = true, module.exports["default"] = module.exports, _get.apply(null, arguments); } module.exports = _get, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 11 */ /***/ (function(module, exports) { /** * Checks if `value` is classified as an `Array` object. * * @static * @memberOf _ * @since 0.1.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is an array, else `false`. * @example * * _.isArray([1, 2, 3]); * // => true * * _.isArray(document.body.children); * // => false * * _.isArray('abc'); * // => false * * _.isArray(_.noop); * // => false */ var isArray = Array.isArray; module.exports = isArray; /***/ }), /* 12 */ /***/ (function(module, exports, __webpack_require__) { var baseMerge = __webpack_require__(68), createAssigner = __webpack_require__(124); /** * This method is like `_.assign` except that it recursively merges own and * inherited enumerable string keyed properties of source objects into the * destination object. Source properties that resolve to `undefined` are * skipped if a destination value exists. Array and plain object properties * are merged recursively. Other objects and value types are overridden by * assignment. Source objects are applied from left to right. Subsequent * sources overwrite property assignments of previous sources. * * **Note:** This method mutates `object`. * * @static * @memberOf _ * @since 0.5.0 * @category Object * @param {Object} object The destination object. * @param {...Object} [sources] The source objects. * @returns {Object} Returns `object`. * @example * * var object = { * 'a': [{ 'b': 2 }, { 'd': 4 }] * }; * * var other = { * 'a': [{ 'c': 3 }, { 'e': 5 }] * }; * * _.merge(object, other); * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] } */ var merge = createAssigner(function(object, source, srcIndex) { baseMerge(object, source, srcIndex); }); module.exports = merge; /***/ }), /* 13 */ /***/ (function(module, exports, __webpack_require__) { var freeGlobal = __webpack_require__(36); /** Detect free variable `self`. */ var freeSelf = typeof self == 'object' && self && self.Object === Object && self; /** Used as a reference to the global object. */ var root = freeGlobal || freeSelf || Function('return this')(); module.exports = root; /***/ }), /* 14 */ /***/ (function(module, exports) { /** * Checks if `value` is object-like. A value is object-like if it's not `null` * and has a `typeof` result of "object". * * @static * @memberOf _ * @since 4.0.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is object-like, else `false`. * @example * * _.isObjectLike({}); * // => true * * _.isObjectLike([1, 2, 3]); * // => true * * _.isObjectLike(_.noop); * // => false * * _.isObjectLike(null); * // => false */ function isObjectLike(value) { return value != null && typeof value == 'object'; } module.exports = isObjectLike; /***/ }), /* 15 */ /***/ (function(module, exports, __webpack_require__) { var Symbol = __webpack_require__(19), getRawTag = __webpack_require__(82), objectToString = __webpack_require__(83); /** `Object#toString` result references. */ var nullTag = '[object Null]', undefinedTag = '[object Undefined]'; /** Built-in value references. */ var symToStringTag = Symbol ? Symbol.toStringTag : undefined; /** * The base implementation of `getTag` without fallbacks for buggy environments. * * @private * @param {*} value The value to query. * @returns {string} Returns the `toStringTag`. */ function baseGetTag(value) { if (value == null) { return value === undefined ? undefinedTag : nullTag; } return (symToStringTag && symToStringTag in Object(value)) ? getRawTag(value) : objectToString(value); } module.exports = baseGetTag; /***/ }), /* 16 */ /***/ (function(module, exports, __webpack_require__) { var listCacheClear = __webpack_require__(70), listCacheDelete = __webpack_require__(71), listCacheGet = __webpack_require__(72), listCacheHas = __webpack_require__(73), listCacheSet = __webpack_require__(74); /** * Creates an list cache object. * * @private * @constructor * @param {Array} [entries] The key-value pairs to cache. */ function ListCache(entries) { var index = -1, length = entries == null ? 0 : entries.length; this.clear(); while (++index < length) { var entry = entries[index]; this.set(entry[0], entry[1]); } } // Add methods to `ListCache`. ListCache.prototype.clear = listCacheClear; ListCache.prototype['delete'] = listCacheDelete; ListCache.prototype.get = listCacheGet; ListCache.prototype.has = listCacheHas; ListCache.prototype.set = listCacheSet; module.exports = ListCache; /***/ }), /* 17 */ /***/ (function(module, exports, __webpack_require__) { var eq = __webpack_require__(18); /** * Gets the index at which the `key` is found in `array` of key-value pairs. * * @private * @param {Array} array The array to inspect. * @param {*} key The key to search for. * @returns {number} Returns the index of the matched value, else `-1`. */ function assocIndexOf(array, key) { var length = array.length; while (length--) { if (eq(array[length][0], key)) { return length; } } return -1; } module.exports = assocIndexOf; /***/ }), /* 18 */ /***/ (function(module, exports) { /** * Performs a * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) * comparison between two values to determine if they are equivalent. * * @static * @memberOf _ * @since 4.0.0 * @category Lang * @param {*} value The value to compare. * @param {*} other The other value to compare. * @returns {boolean} Returns `true` if the values are equivalent, else `false`. * @example * * var object = { 'a': 1 }; * var other = { 'a': 1 }; * * _.eq(object, object); * // => true * * _.eq(object, other); * // => false * * _.eq('a', 'a'); * // => true * * _.eq('a', Object('a')); * // => false * * _.eq(NaN, NaN); * // => true */ function eq(value, other) { return value === other || (value !== value && other !== other); } module.exports = eq; /***/ }), /* 19 */ /***/ (function(module, exports, __webpack_require__) { var root = __webpack_require__(13); /** Built-in value references. */ var Symbol = root.Symbol; module.exports = Symbol; /***/ }), /* 20 */ /***/ (function(module, exports, __webpack_require__) { var getNative = __webpack_require__(26); /* Built-in method references that are verified to be native. */ var nativeCreate = getNative(Object, 'create'); module.exports = nativeCreate; /***/ }), /* 21 */ /***/ (function(module, exports, __webpack_require__) { var isKeyable = __webpack_require__(96); /** * Gets the data for `map`. * * @private * @param {Object} map The map to query. * @param {string} key The reference key. * @returns {*} Returns the map data. */ function getMapData(map, key) { var data = map.__data__; return isKeyable(key) ? data[typeof key == 'string' ? 'string' : 'hash'] : data.map; } module.exports = getMapData; /***/ }), /* 22 */ /***/ (function(module, exports, __webpack_require__) { var baseIsArguments = __webpack_require__(111), isObjectLike = __webpack_require__(14); /** Used for built-in method references. */ var objectProto = Object.prototype; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** Built-in value references. */ var propertyIsEnumerable = objectProto.propertyIsEnumerable; /** * Checks if `value` is likely an `arguments` object. * * @static * @memberOf _ * @since 0.1.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is an `arguments` object, * else `false`. * @example * * _.isArguments(function() { return arguments; }()); * // => true * * _.isArguments([1, 2, 3]); * // => false */ var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) { return isObjectLike(value) && hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee'); }; module.exports = isArguments; /***/ }), /* 23 */ /***/ (function(module, exports) { /** Used as references for various `Number` constants. */ var MAX_SAFE_INTEGER = 9007199254740991; /** Used to detect unsigned integer values. */ var reIsUint = /^(?:0|[1-9]\d*)$/; /** * Checks if `value` is a valid array-like index. * * @private * @param {*} value The value to check. * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. * @returns {boolean} Returns `true` if `value` is a valid index, else `false`. */ function isIndex(value, length) { var type = typeof value; length = length == null ? MAX_SAFE_INTEGER : length; return !!length && (type == 'number' || (type != 'symbol' && reIsUint.test(value))) && (value > -1 && value % 1 == 0 && value < length); } module.exports = isIndex; /***/ }), /* 24 */ /***/ (function(module, exports, __webpack_require__) { var isArray = __webpack_require__(11), isKey = __webpack_require__(148), stringToPath = __webpack_require__(149), toString = __webpack_require__(152); /** * Casts `value` to a path array if it's not one. * * @private * @param {*} value The value to inspect. * @param {Object} [object] The object to query keys on. * @returns {Array} Returns the cast property path array. */ function castPath(value, object) { if (isArray(value)) { return value; } return isKey(value, object) ? [value] : stringToPath(toString(value)); } module.exports = castPath; /***/ }), /* 25 */ /***/ (function(module, exports, __webpack_require__) { var arrayWithoutHoles = __webpack_require__(142); var iterableToArray = __webpack_require__(143); var unsupportedIterableToArray = __webpack_require__(50); var nonIterableSpread = __webpack_require__(144); function _toConsumableArray(r) { return arrayWithoutHoles(r) || iterableToArray(r) || unsupportedIterableToArray(r) || nonIterableSpread(); } module.exports = _toConsumableArray, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 26 */ /***/ (function(module, exports, __webpack_require__) { var baseIsNative = __webpack_require__(80), getValue = __webpack_require__(87); /** * Gets the native function at `key` of `object`. * * @private * @param {Object} object The object to query. * @param {string} key The key of the method to get. * @returns {*} Returns the function if it's native, else `undefined`. */ function getNative(object, key) { var value = getValue(object, key); return baseIsNative(value) ? value : undefined; } module.exports = getNative; /***/ }), /* 27 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(15), isObject = __webpack_require__(9); /** `Object#toString` result references. */ var asyncTag = '[object AsyncFunction]', funcTag = '[object Function]', genTag = '[object GeneratorFunction]', proxyTag = '[object Proxy]'; /** * Checks if `value` is classified as a `Function` object. * * @static * @memberOf _ * @since 0.1.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a function, else `false`. * @example * * _.isFunction(_); * // => true * * _.isFunction(/abc/); * // => false */ function isFunction(value) { if (!isObject(value)) { return false; } // The use of `Object#toString` avoids issues with the `typeof` operator // in Safari 9 which returns 'object' for typed arrays and other constructors. var tag = baseGetTag(value); return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag; } module.exports = isFunction; /***/ }), /* 28 */ /***/ (function(module, exports, __webpack_require__) { var defineProperty = __webpack_require__(39); /** * The base implementation of `assignValue` and `assignMergeValue` without * value checks. * * @private * @param {Object} object The object to modify. * @param {string} key The key of the property to assign. * @param {*} value The value to assign. */ function baseAssignValue(object, key, value) { if (key == '__proto__' && defineProperty) { defineProperty(object, key, { 'configurable': true, 'enumerable': true, 'value': value, 'writable': true }); } else { object[key] = value; } } module.exports = baseAssignValue; /***/ }), /* 29 */ /***/ (function(module, exports) { module.exports = function(module) { if (!module.webpackPolyfill) { module.deprecate = function() {}; module.paths = []; // module.parent = undefined by default if (!module.children) module.children = []; Object.defineProperty(module, "loaded", { enumerable: true, get: function() { return module.l; } }); Object.defineProperty(module, "id", { enumerable: true, get: function() { return module.i; } }); module.webpackPolyfill = 1; } return module; }; /***/ }), /* 30 */ /***/ (function(module, exports, __webpack_require__) { var isFunction = __webpack_require__(27), isLength = __webpack_require__(31); /** * Checks if `value` is array-like. A value is considered array-like if it's * not a function and has a `value.length` that's an integer greater than or * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`. * * @static * @memberOf _ * @since 4.0.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is array-like, else `false`. * @example * * _.isArrayLike([1, 2, 3]); * // => true * * _.isArrayLike(document.body.children); * // => true * * _.isArrayLike('abc'); * // => true * * _.isArrayLike(_.noop); * // => false */ function isArrayLike(value) { return value != null && isLength(value.length) && !isFunction(value); } module.exports = isArrayLike; /***/ }), /* 31 */ /***/ (function(module, exports) { /** Used as references for various `Number` constants. */ var MAX_SAFE_INTEGER = 9007199254740991; /** * Checks if `value` is a valid array-like length. * * **Note:** This method is loosely based on * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength). * * @static * @memberOf _ * @since 4.0.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. * @example * * _.isLength(3); * // => true * * _.isLength(Number.MIN_VALUE); * // => false * * _.isLength(Infinity); * // => false * * _.isLength('3'); * // => false */ function isLength(value) { return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; } module.exports = isLength; /***/ }), /* 32 */ /***/ (function(module, exports) { function _setPrototypeOf(t, e) { return module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, module.exports.__esModule = true, module.exports["default"] = module.exports, _setPrototypeOf(t, e); } module.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 33 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(15), isObjectLike = __webpack_require__(14); /** `Object#toString` result references. */ var symbolTag = '[object Symbol]'; /** * Checks if `value` is classified as a `Symbol` primitive or object. * * @static * @memberOf _ * @since 4.0.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a symbol, else `false`. * @example * * _.isSymbol(Symbol.iterator); * // => true * * _.isSymbol('abc'); * // => false */ function isSymbol(value) { return typeof value == 'symbol' || (isObjectLike(value) && baseGetTag(value) == symbolTag); } module.exports = isSymbol; /***/ }), /* 34 */ /***/ (function(module, exports, __webpack_require__) { var isSymbol = __webpack_require__(33); /** Used as references for various `Number` constants. */ var INFINITY = 1 / 0; /** * Converts `value` to a string key if it's not a string or symbol. * * @private * @param {*} value The value to inspect. * @returns {string|symbol} Returns the key. */ function toKey(value) { if (typeof value == 'string' || isSymbol(value)) { return value; } var result = (value + ''); return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; } module.exports = toKey; /***/ }), /* 35 */ /***/ (function(module, exports, __webpack_require__) { var getNative = __webpack_require__(26), root = __webpack_require__(13); /* Built-in method references that are verified to be native. */ var Map = getNative(root, 'Map'); module.exports = Map; /***/ }), /* 36 */ /***/ (function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(global) {/** Detect free variable `global` from Node.js. */ var freeGlobal = typeof global == 'object' && global && global.Object === Object && global; module.exports = freeGlobal; /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(81))) /***/ }), /* 37 */ /***/ (function(module, exports, __webpack_require__) { var mapCacheClear = __webpack_require__(88), mapCacheDelete = __webpack_require__(95), mapCacheGet = __webpack_require__(97), mapCacheHas = __webpack_require__(98), mapCacheSet = __webpack_require__(99); /** * Creates a map cache object to store key-value pairs. * * @private * @constructor * @param {Array} [entries] The key-value pairs to cache. */ function MapCache(entries) { var index = -1, length = entries == null ? 0 : entries.length; this.clear(); while (++index < length) { var entry = entries[index]; this.set(entry[0], entry[1]); } } // Add methods to `MapCache`. MapCache.prototype.clear = mapCacheClear; MapCache.prototype['delete'] = mapCacheDelete; MapCache.prototype.get = mapCacheGet; MapCache.prototype.has = mapCacheHas; MapCache.prototype.set = mapCacheSet; module.exports = MapCache; /***/ }), /* 38 */ /***/ (function(module, exports, __webpack_require__) { var baseAssignValue = __webpack_require__(28), eq = __webpack_require__(18); /** * This function is like `assignValue` except that it doesn't assign * `undefined` values. * * @private * @param {Object} object The object to modify. * @param {string} key The key of the property to assign. * @param {*} value The value to assign. */ function assignMergeValue(object, key, value) { if ((value !== undefined && !eq(object[key], value)) || (value === undefined && !(key in object))) { baseAssignValue(object, key, value); } } module.exports = assignMergeValue; /***/ }), /* 39 */ /***/ (function(module, exports, __webpack_require__) { var getNative = __webpack_require__(26); var defineProperty = (function() { try { var func = getNative(Object, 'defineProperty'); func({}, '', {}); return func; } catch (e) {} }()); module.exports = defineProperty; /***/ }), /* 40 */ /***/ (function(module, exports, __webpack_require__) { var overArg = __webpack_require__(110); /** Built-in value references. */ var getPrototype = overArg(Object.getPrototypeOf, Object); module.exports = getPrototype; /***/ }), /* 41 */ /***/ (function(module, exports) { /** Used for built-in method references. */ var objectProto = Object.prototype; /** * Checks if `value` is likely a prototype object. * * @private * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a prototype, else `false`. */ function isPrototype(value) { var Ctor = value && value.constructor, proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto; return value === proto; } module.exports = isPrototype; /***/ }), /* 42 */ /***/ (function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(13), stubFalse = __webpack_require__(113); /** Detect free variable `exports`. */ var freeExports = true && exports && !exports.nodeType && exports; /** Detect free variable `module`. */ var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; /** Detect the popular CommonJS extension `module.exports`. */ var moduleExports = freeModule && freeModule.exports === freeExports; /** Built-in value references. */ var Buffer = moduleExports ? root.Buffer : undefined; /* Built-in method references for those with the same name as other `lodash` methods. */ var nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined; /** * Checks if `value` is a buffer. * * @static * @memberOf _ * @since 4.3.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a buffer, else `false`. * @example * * _.isBuffer(new Buffer(2)); * // => true * * _.isBuffer(new Uint8Array(2)); * // => false */ var isBuffer = nativeIsBuffer || stubFalse; module.exports = isBuffer; /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(29)(module))) /***/ }), /* 43 */ /***/ (function(module, exports, __webpack_require__) { var baseIsTypedArray = __webpack_require__(115), baseUnary = __webpack_require__(116), nodeUtil = __webpack_require__(117); /* Node.js helper references. */ var nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray; /** * Checks if `value` is classified as a typed array. * * @static * @memberOf _ * @since 3.0.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. * @example * * _.isTypedArray(new Uint8Array); * // => true * * _.isTypedArray([]); * // => false */ var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray; module.exports = isTypedArray; /***/ }), /* 44 */ /***/ (function(module, exports) { /** * Gets the value at `key`, unless `key` is "__proto__" or "constructor". * * @private * @param {Object} object The object to query. * @param {string} key The key of the property to get. * @returns {*} Returns the property value. */ function safeGet(object, key) { if (key === 'constructor' && typeof object[key] === 'function') { return; } if (key == '__proto__') { return; } return object[key]; } module.exports = safeGet; /***/ }), /* 45 */ /***/ (function(module, exports, __webpack_require__) { var baseAssignValue = __webpack_require__(28), eq = __webpack_require__(18); /** Used for built-in method references. */ var objectProto = Object.prototype; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** * Assigns `value` to `key` of `object` if the existing value is not equivalent * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) * for equality comparisons. * * @private * @param {Object} object The object to modify. * @param {string} key The key of the property to assign. * @param {*} value The value to assign. */ function assignValue(object, key, value) { var objValue = object[key]; if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) || (value === undefined && !(key in object))) { baseAssignValue(object, key, value); } } module.exports = assignValue; /***/ }), /* 46 */ /***/ (function(module, exports, __webpack_require__) { var arrayLikeKeys = __webpack_require__(120), baseKeysIn = __webpack_require__(122), isArrayLike = __webpack_require__(30); /** * Creates an array of the own and inherited enumerable property names of `object`. * * **Note:** Non-object values are coerced to objects. * * @static * @memberOf _ * @since 3.0.0 * @category Object * @param {Object} object The object to query. * @returns {Array} Returns the array of property names. * @example * * function Foo() { * this.a = 1; * this.b = 2; * } * * Foo.prototype.c = 3; * * _.keysIn(new Foo); * // => ['a', 'b', 'c'] (iteration order is not guaranteed) */ function keysIn(object) { return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object); } module.exports = keysIn; /***/ }), /* 47 */ /***/ (function(module, exports) { /** * This method returns the first argument it receives. * * @static * @since 0.1.0 * @memberOf _ * @category Util * @param {*} value Any value. * @returns {*} Returns `value`. * @example * * var object = { 'a': 1 }; * * console.log(_.identity(object) === object); * // => true */ function identity(value) { return value; } module.exports = identity; /***/ }), /* 48 */ /***/ (function(module, exports, __webpack_require__) { var apply = __webpack_require__(126); /* Built-in method references for those with the same name as other `lodash` methods. */ var nativeMax = Math.max; /** * A specialized version of `baseRest` which transforms the rest array. * * @private * @param {Function} func The function to apply a rest parameter to. * @param {number} [start=func.length-1] The start position of the rest parameter. * @param {Function} transform The rest array transform. * @returns {Function} Returns the new function. */ function overRest(func, start, transform) { start = nativeMax(start === undefined ? (func.length - 1) : start, 0); return function() { var args = arguments, index = -1, length = nativeMax(args.length - start, 0), array = Array(length); while (++index < length) { array[index] = args[start + index]; } index = -1; var otherArgs = Array(start + 1); while (++index < start) { otherArgs[index] = args[index]; } otherArgs[start] = transform(array); return apply(func, this, otherArgs); }; } module.exports = overRest; /***/ }), /* 49 */ /***/ (function(module, exports, __webpack_require__) { var baseSetToString = __webpack_require__(127), shortOut = __webpack_require__(129); /** * Sets the `toString` method of `func` to return `string`. * * @private * @param {Function} func The function to modify. * @param {Function} string The `toString` result. * @returns {Function} Returns `func`. */ var setToString = shortOut(baseSetToString); module.exports = setToString; /***/ }), /* 50 */ /***/ (function(module, exports, __webpack_require__) { var arrayLikeToArray = __webpack_require__(51); function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? arrayLikeToArray(r, a) : void 0; } } module.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 51 */ /***/ (function(module, exports) { function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } module.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 52 */ /***/ (function(module, exports, __webpack_require__) { var _typeof = __webpack_require__(8)["default"]; var toPrimitive = __webpack_require__(135); function toPropertyKey(t) { var i = toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } module.exports = toPropertyKey, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 53 */ /***/ (function(module, exports) { function _OverloadYield(e, d) { this.v = e, this.k = d; } module.exports = _OverloadYield, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 54 */ /***/ (function(module, exports, __webpack_require__) { var regeneratorDefine = __webpack_require__(55); function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return regeneratorDefine(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (regeneratorDefine(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, regeneratorDefine(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, regeneratorDefine(u, "constructor", GeneratorFunctionPrototype), regeneratorDefine(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", regeneratorDefine(GeneratorFunctionPrototype, o, "GeneratorFunction"), regeneratorDefine(u), regeneratorDefine(u, o, "Generator"), regeneratorDefine(u, n, function () { return this; }), regeneratorDefine(u, "toString", function () { return "[object Generator]"; }), (module.exports = _regenerator = function _regenerator() { return { w: i, m: f }; }, module.exports.__esModule = true, module.exports["default"] = module.exports)(); } module.exports = _regenerator, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 55 */ /***/ (function(module, exports) { function _regeneratorDefine(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } module.exports = _regeneratorDefine = function regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, module.exports.__esModule = true, module.exports["default"] = module.exports, _regeneratorDefine(e, r, n, t); } module.exports = _regeneratorDefine, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 56 */ /***/ (function(module, exports, __webpack_require__) { var regenerator = __webpack_require__(54); var regeneratorAsyncIterator = __webpack_require__(57); function _regeneratorAsyncGen(r, e, t, o, n) { return new regeneratorAsyncIterator(regenerator().w(r, e, t, o), n || Promise); } module.exports = _regeneratorAsyncGen, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 57 */ /***/ (function(module, exports, __webpack_require__) { var OverloadYield = __webpack_require__(53); var regeneratorDefine = __webpack_require__(55); function AsyncIterator(t, e) { function n(r, o, i, f) { try { var c = t[r](o), u = c.value; return u instanceof OverloadYield ? e.resolve(u.v).then(function (t) { n("next", t, i, f); }, function (t) { n("throw", t, i, f); }) : e.resolve(u).then(function (t) { c.value = t, i(c); }, function (t) { return n("throw", t, i, f); }); } catch (t) { f(t); } } var r; this.next || (regeneratorDefine(AsyncIterator.prototype), regeneratorDefine(AsyncIterator.prototype, "function" == typeof Symbol && Symbol.asyncIterator || "@asyncIterator", function () { return this; })), regeneratorDefine(this, "_invoke", function (t, o, i) { function f() { return new e(function (e, r) { n(t, i, e, r); }); } return r = r ? r.then(f, f) : f(); }, !0); } module.exports = AsyncIterator, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 58 */ /***/ (function(module, exports, __webpack_require__) { var arrayWithHoles = __webpack_require__(132); var iterableToArrayLimit = __webpack_require__(133); var unsupportedIterableToArray = __webpack_require__(50); var nonIterableRest = __webpack_require__(134); function _slicedToArray(r, e) { return arrayWithHoles(r) || iterableToArrayLimit(r, e) || unsupportedIterableToArray(r, e) || nonIterableRest(); } module.exports = _slicedToArray, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 59 */ /***/ (function(module, exports, __webpack_require__) { var basePick = __webpack_require__(145), flatRest = __webpack_require__(159); /** * Creates an object composed of the picked `object` properties. * * @static * @since 0.1.0 * @memberOf _ * @category Object * @param {Object} object The source object. * @param {...(string|string[])} [paths] The property paths to pick. * @returns {Object} Returns the new object. * @example * * var object = { 'a': 1, 'b': '2', 'c': 3 }; * * _.pick(object, ['a', 'c']); * // => { 'a': 1, 'c': 3 } */ var pick = flatRest(function(object, paths) { return object == null ? {} : basePick(object, paths); }); module.exports = pick; /***/ }), /* 60 */ /***/ (function(module, exports, __webpack_require__) { var getPrototypeOf = __webpack_require__(1); var setPrototypeOf = __webpack_require__(32); var isNativeFunction = __webpack_require__(164); var construct = __webpack_require__(165); function _wrapNativeSuper(t) { var r = "function" == typeof Map ? new Map() : void 0; return module.exports = _wrapNativeSuper = function _wrapNativeSuper(t) { if (null === t || !isNativeFunction(t)) return t; if ("function" != typeof t) throw new TypeError("Super expression must either be null or a function"); if (void 0 !== r) { if (r.has(t)) return r.get(t); r.set(t, Wrapper); } function Wrapper() { return construct(t, arguments, getPrototypeOf(this).constructor); } return Wrapper.prototype = Object.create(t.prototype, { constructor: { value: Wrapper, enumerable: !1, writable: !0, configurable: !0 } }), setPrototypeOf(Wrapper, t); }, module.exports.__esModule = true, module.exports["default"] = module.exports, _wrapNativeSuper(t); } module.exports = _wrapNativeSuper, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 61 */, /* 62 */, /* 63 */, /* 64 */, /* 65 */, /* 66 */, /* 67 */ /***/ (function(module, exports, __webpack_require__) { module.exports = __webpack_require__(167); /***/ }), /* 68 */ /***/ (function(module, exports, __webpack_require__) { var Stack = __webpack_require__(69), assignMergeValue = __webpack_require__(38), baseFor = __webpack_require__(100), baseMergeDeep = __webpack_require__(102), isObject = __webpack_require__(9), keysIn = __webpack_require__(46), safeGet = __webpack_require__(44); /** * The base implementation of `_.merge` without support for multiple sources. * * @private * @param {Object} object The destination object. * @param {Object} source The source object. * @param {number} srcIndex The index of `source`. * @param {Function} [customizer] The function to customize merged values. * @param {Object} [stack] Tracks traversed source values and their merged * counterparts. */ function baseMerge(object, source, srcIndex, customizer, stack) { if (object === source) { return; } baseFor(source, function(srcValue, key) { stack || (stack = new Stack); if (isObject(srcValue)) { baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack); } else { var newValue = customizer ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack) : undefined; if (newValue === undefined) { newValue = srcValue; } assignMergeValue(object, key, newValue); } }, keysIn); } module.exports = baseMerge; /***/ }), /* 69 */ /***/ (function(module, exports, __webpack_require__) { var ListCache = __webpack_require__(16), stackClear = __webpack_require__(75), stackDelete = __webpack_require__(76), stackGet = __webpack_require__(77), stackHas = __webpack_require__(78), stackSet = __webpack_require__(79); /** * Creates a stack cache object to store key-value pairs. * * @private * @constructor * @param {Array} [entries] The key-value pairs to cache. */ function Stack(entries) { var data = this.__data__ = new ListCache(entries); this.size = data.size; } // Add methods to `Stack`. Stack.prototype.clear = stackClear; Stack.prototype['delete'] = stackDelete; Stack.prototype.get = stackGet; Stack.prototype.has = stackHas; Stack.prototype.set = stackSet; module.exports = Stack; /***/ }), /* 70 */ /***/ (function(module, exports) { /** * Removes all key-value entries from the list cache. * * @private * @name clear * @memberOf ListCache */ function listCacheClear() { this.__data__ = []; this.size = 0; } module.exports = listCacheClear; /***/ }), /* 71 */ /***/ (function(module, exports, __webpack_require__) { var assocIndexOf = __webpack_require__(17); /** Used for built-in method references. */ var arrayProto = Array.prototype; /** Built-in value references. */ var splice = arrayProto.splice; /** * Removes `key` and its value from the list cache. * * @private * @name delete * @memberOf ListCache * @param {string} key The key of the value to remove. * @returns {boolean} Returns `true` if the entry was removed, else `false`. */ function listCacheDelete(key) { var data = this.__data__, index = assocIndexOf(data, key); if (index < 0) { return false; } var lastIndex = data.length - 1; if (index == lastIndex) { data.pop(); } else { splice.call(data, index, 1); } --this.size; return true; } module.exports = listCacheDelete; /***/ }), /* 72 */ /***/ (function(module, exports, __webpack_require__) { var assocIndexOf = __webpack_require__(17); /** * Gets the list cache value for `key`. * * @private * @name get * @memberOf ListCache * @param {string} key The key of the value to get. * @returns {*} Returns the entry value. */ function listCacheGet(key) { var data = this.__data__, index = assocIndexOf(data, key); return index < 0 ? undefined : data[index][1]; } module.exports = listCacheGet; /***/ }), /* 73 */ /***/ (function(module, exports, __webpack_require__) { var assocIndexOf = __webpack_require__(17); /** * Checks if a list cache value for `key` exists. * * @private * @name has * @memberOf ListCache * @param {string} key The key of the entry to check. * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. */ function listCacheHas(key) { return assocIndexOf(this.__data__, key) > -1; } module.exports = listCacheHas; /***/ }), /* 74 */ /***/ (function(module, exports, __webpack_require__) { var assocIndexOf = __webpack_require__(17); /** * Sets the list cache `key` to `value`. * * @private * @name set * @memberOf ListCache * @param {string} key The key of the value to set. * @param {*} value The value to set. * @returns {Object} Returns the list cache instance. */ function listCacheSet(key, value) { var data = this.__data__, index = assocIndexOf(data, key); if (index < 0) { ++this.size; data.push([key, value]); } else { data[index][1] = value; } return this; } module.exports = listCacheSet; /***/ }), /* 75 */ /***/ (function(module, exports, __webpack_require__) { var ListCache = __webpack_require__(16); /** * Removes all key-value entries from the stack. * * @private * @name clear * @memberOf Stack */ function stackClear() { this.__data__ = new ListCache; this.size = 0; } module.exports = stackClear; /***/ }), /* 76 */ /***/ (function(module, exports) { /** * Removes `key` and its value from the stack. * * @private * @name delete * @memberOf Stack * @param {string} key The key of the value to remove. * @returns {boolean} Returns `true` if the entry was removed, else `false`. */ function stackDelete(key) { var data = this.__data__, result = data['delete'](key); this.size = data.size; return result; } module.exports = stackDelete; /***/ }), /* 77 */ /***/ (function(module, exports) { /** * Gets the stack value for `key`. * * @private * @name get * @memberOf Stack * @param {string} key The key of the value to get. * @returns {*} Returns the entry value. */ function stackGet(key) { return this.__data__.get(key); } module.exports = stackGet; /***/ }), /* 78 */ /***/ (function(module, exports) { /** * Checks if a stack value for `key` exists. * * @private * @name has * @memberOf Stack * @param {string} key The key of the entry to check. * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. */ function stackHas(key) { return this.__data__.has(key); } module.exports = stackHas; /***/ }), /* 79 */ /***/ (function(module, exports, __webpack_require__) { var ListCache = __webpack_require__(16), Map = __webpack_require__(35), MapCache = __webpack_require__(37); /** Used as the size to enable large array optimizations. */ var LARGE_ARRAY_SIZE = 200; /** * Sets the stack `key` to `value`. * * @private * @name set * @memberOf Stack * @param {string} key The key of the value to set. * @param {*} value The value to set. * @returns {Object} Returns the stack cache instance. */ function stackSet(key, value) { var data = this.__data__; if (data instanceof ListCache) { var pairs = data.__data__; if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) { pairs.push([key, value]); this.size = ++data.size; return this; } data = this.__data__ = new MapCache(pairs); } data.set(key, value); this.size = data.size; return this; } module.exports = stackSet; /***/ }), /* 80 */ /***/ (function(module, exports, __webpack_require__) { var isFunction = __webpack_require__(27), isMasked = __webpack_require__(84), isObject = __webpack_require__(9), toSource = __webpack_require__(86); /** * Used to match `RegExp` * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns). */ var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; /** Used to detect host constructors (Safari). */ var reIsHostCtor = /^\[object .+?Constructor\]$/; /** Used for built-in method references. */ var funcProto = Function.prototype, objectProto = Object.prototype; /** Used to resolve the decompiled source of functions. */ var funcToString = funcProto.toString; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** Used to detect if a method is native. */ var reIsNative = RegExp('^' + funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&') .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' ); /** * The base implementation of `_.isNative` without bad shim checks. * * @private * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a native function, * else `false`. */ function baseIsNative(value) { if (!isObject(value) || isMasked(value)) { return false; } var pattern = isFunction(value) ? reIsNative : reIsHostCtor; return pattern.test(toSource(value)); } module.exports = baseIsNative; /***/ }), /* 81 */ /***/ (function(module, exports) { var g; // This works in non-strict mode g = (function() { return this; })(); try { // This works if eval is allowed (see CSP) g = g || new Function("return this")(); } catch (e) { // This works if the window reference is available if (typeof window === "object") g = window; } // g can still be undefined, but nothing to do about it... // We return undefined, instead of nothing here, so it's // easier to handle this case. if(!global) { ...} module.exports = g; /***/ }), /* 82 */ /***/ (function(module, exports, __webpack_require__) { var Symbol = __webpack_require__(19); /** Used for built-in method references. */ var objectProto = Object.prototype; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** * Used to resolve the * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) * of values. */ var nativeObjectToString = objectProto.toString; /** Built-in value references. */ var symToStringTag = Symbol ? Symbol.toStringTag : undefined; /** * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values. * * @private * @param {*} value The value to query. * @returns {string} Returns the raw `toStringTag`. */ function getRawTag(value) { var isOwn = hasOwnProperty.call(value, symToStringTag), tag = value[symToStringTag]; try { value[symToStringTag] = undefined; var unmasked = true; } catch (e) {} var result = nativeObjectToString.call(value); if (unmasked) { if (isOwn) { value[symToStringTag] = tag; } else { delete value[symToStringTag]; } } return result; } module.exports = getRawTag; /***/ }), /* 83 */ /***/ (function(module, exports) { /** Used for built-in method references. */ var objectProto = Object.prototype; /** * Used to resolve the * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) * of values. */ var nativeObjectToString = objectProto.toString; /** * Converts `value` to a string using `Object.prototype.toString`. * * @private * @param {*} value The value to convert. * @returns {string} Returns the converted string. */ function objectToString(value) { return nativeObjectToString.call(value); } module.exports = objectToString; /***/ }), /* 84 */ /***/ (function(module, exports, __webpack_require__) { var coreJsData = __webpack_require__(85); /** Used to detect methods masquerading as native. */ var maskSrcKey = (function() { var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || ''); return uid ? ('Symbol(src)_1.' + uid) : ''; }()); /** * Checks if `func` has its source masked. * * @private * @param {Function} func The function to check. * @returns {boolean} Returns `true` if `func` is masked, else `false`. */ function isMasked(func) { return !!maskSrcKey && (maskSrcKey in func); } module.exports = isMasked; /***/ }), /* 85 */ /***/ (function(module, exports, __webpack_require__) { var root = __webpack_require__(13); /** Used to detect overreaching core-js shims. */ var coreJsData = root['__core-js_shared__']; module.exports = coreJsData; /***/ }), /* 86 */ /***/ (function(module, exports) { /** Used for built-in method references. */ var funcProto = Function.prototype; /** Used to resolve the decompiled source of functions. */ var funcToString = funcProto.toString; /** * Converts `func` to its source code. * * @private * @param {Function} func The function to convert. * @returns {string} Returns the source code. */ function toSource(func) { if (func != null) { try { return funcToString.call(func); } catch (e) {} try { return (func + ''); } catch (e) {} } return ''; } module.exports = toSource; /***/ }), /* 87 */ /***/ (function(module, exports) { /** * Gets the value at `key` of `object`. * * @private * @param {Object} [object] The object to query. * @param {string} key The key of the property to get. * @returns {*} Returns the property value. */ function getValue(object, key) { return object == null ? undefined : object[key]; } module.exports = getValue; /***/ }), /* 88 */ /***/ (function(module, exports, __webpack_require__) { var Hash = __webpack_require__(89), ListCache = __webpack_require__(16), Map = __webpack_require__(35); /** * Removes all key-value entries from the map. * * @private * @name clear * @memberOf MapCache */ function mapCacheClear() { this.size = 0; this.__data__ = { 'hash': new Hash, 'map': new (Map || ListCache), 'string': new Hash }; } module.exports = mapCacheClear; /***/ }), /* 89 */ /***/ (function(module, exports, __webpack_require__) { var hashClear = __webpack_require__(90), hashDelete = __webpack_require__(91), hashGet = __webpack_require__(92), hashHas = __webpack_require__(93), hashSet = __webpack_require__(94); /** * Creates a hash object. * * @private * @constructor * @param {Array} [entries] The key-value pairs to cache. */ function Hash(entries) { var index = -1, length = entries == null ? 0 : entries.length; this.clear(); while (++index < length) { var entry = entries[index]; this.set(entry[0], entry[1]); } } // Add methods to `Hash`. Hash.prototype.clear = hashClear; Hash.prototype['delete'] = hashDelete; Hash.prototype.get = hashGet; Hash.prototype.has = hashHas; Hash.prototype.set = hashSet; module.exports = Hash; /***/ }), /* 90 */ /***/ (function(module, exports, __webpack_require__) { var nativeCreate = __webpack_require__(20); /** * Removes all key-value entries from the hash. * * @private * @name clear * @memberOf Hash */ function hashClear() { this.__data__ = nativeCreate ? nativeCreate(null) : {}; this.size = 0; } module.exports = hashClear; /***/ }), /* 91 */ /***/ (function(module, exports) { /** * Removes `key` and its value from the hash. * * @private * @name delete * @memberOf Hash * @param {Object} hash The hash to modify. * @param {string} key The key of the value to remove. * @returns {boolean} Returns `true` if the entry was removed, else `false`. */ function hashDelete(key) { var result = this.has(key) && delete this.__data__[key]; this.size -= result ? 1 : 0; return result; } module.exports = hashDelete; /***/ }), /* 92 */ /***/ (function(module, exports, __webpack_require__) { var nativeCreate = __webpack_require__(20); /** Used to stand-in for `undefined` hash values. */ var HASH_UNDEFINED = '__lodash_hash_undefined__'; /** Used for built-in method references. */ var objectProto = Object.prototype; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** * Gets the hash value for `key`. * * @private * @name get * @memberOf Hash * @param {string} key The key of the value to get. * @returns {*} Returns the entry value. */ function hashGet(key) { var data = this.__data__; if (nativeCreate) { var result = data[key]; return result === HASH_UNDEFINED ? undefined : result; } return hasOwnProperty.call(data, key) ? data[key] : undefined; } module.exports = hashGet; /***/ }), /* 93 */ /***/ (function(module, exports, __webpack_require__) { var nativeCreate = __webpack_require__(20); /** Used for built-in method references. */ var objectProto = Object.prototype; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** * Checks if a hash value for `key` exists. * * @private * @name has * @memberOf Hash * @param {string} key The key of the entry to check. * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. */ function hashHas(key) { var data = this.__data__; return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key); } module.exports = hashHas; /***/ }), /* 94 */ /***/ (function(module, exports, __webpack_require__) { var nativeCreate = __webpack_require__(20); /** Used to stand-in for `undefined` hash values. */ var HASH_UNDEFINED = '__lodash_hash_undefined__'; /** * Sets the hash `key` to `value`. * * @private * @name set * @memberOf Hash * @param {string} key The key of the value to set. * @param {*} value The value to set. * @returns {Object} Returns the hash instance. */ function hashSet(key, value) { var data = this.__data__; this.size += this.has(key) ? 0 : 1; data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value; return this; } module.exports = hashSet; /***/ }), /* 95 */ /***/ (function(module, exports, __webpack_require__) { var getMapData = __webpack_require__(21); /** * Removes `key` and its value from the map. * * @private * @name delete * @memberOf MapCache * @param {string} key The key of the value to remove. * @returns {boolean} Returns `true` if the entry was removed, else `false`. */ function mapCacheDelete(key) { var result = getMapData(this, key)['delete'](key); this.size -= result ? 1 : 0; return result; } module.exports = mapCacheDelete; /***/ }), /* 96 */ /***/ (function(module, exports) { /** * Checks if `value` is suitable for use as unique object key. * * @private * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is suitable, else `false`. */ function isKeyable(value) { var type = typeof value; return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean') ? (value !== '__proto__') : (value === null); } module.exports = isKeyable; /***/ }), /* 97 */ /***/ (function(module, exports, __webpack_require__) { var getMapData = __webpack_require__(21); /** * Gets the map value for `key`. * * @private * @name get * @memberOf MapCache * @param {string} key The key of the value to get. * @returns {*} Returns the entry value. */ function mapCacheGet(key) { return getMapData(this, key).get(key); } module.exports = mapCacheGet; /***/ }), /* 98 */ /***/ (function(module, exports, __webpack_require__) { var getMapData = __webpack_require__(21); /** * Checks if a map value for `key` exists. * * @private * @name has * @memberOf MapCache * @param {string} key The key of the entry to check. * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. */ function mapCacheHas(key) { return getMapData(this, key).has(key); } module.exports = mapCacheHas; /***/ }), /* 99 */ /***/ (function(module, exports, __webpack_require__) { var getMapData = __webpack_require__(21); /** * Sets the map `key` to `value`. * * @private * @name set * @memberOf MapCache * @param {string} key The key of the value to set. * @param {*} value The value to set. * @returns {Object} Returns the map cache instance. */ function mapCacheSet(key, value) { var data = getMapData(this, key), size = data.size; data.set(key, value); this.size += data.size == size ? 0 : 1; return this; } module.exports = mapCacheSet; /***/ }), /* 100 */ /***/ (function(module, exports, __webpack_require__) { var createBaseFor = __webpack_require__(101); /** * The base implementation of `baseForOwn` which iterates over `object` * properties returned by `keysFunc` and invokes `iteratee` for each property. * Iteratee functions may exit iteration early by explicitly returning `false`. * * @private * @param {Object} object The object to iterate over. * @param {Function} iteratee The function invoked per iteration. * @param {Function} keysFunc The function to get the keys of `object`. * @returns {Object} Returns `object`. */ var baseFor = createBaseFor(); module.exports = baseFor; /***/ }), /* 101 */ /***/ (function(module, exports) { /** * Creates a base function for methods like `_.forIn` and `_.forOwn`. * * @private * @param {boolean} [fromRight] Specify iterating from right to left. * @returns {Function} Returns the new base function. */ function createBaseFor(fromRight) { return function(object, iteratee, keysFunc) { var index = -1, iterable = Object(object), props = keysFunc(object), length = props.length; while (length--) { var key = props[fromRight ? length : ++index]; if (iteratee(iterable[key], key, iterable) === false) { break; } } return object; }; } module.exports = createBaseFor; /***/ }), /* 102 */ /***/ (function(module, exports, __webpack_require__) { var assignMergeValue = __webpack_require__(38), cloneBuffer = __webpack_require__(103), cloneTypedArray = __webpack_require__(104), copyArray = __webpack_require__(107), initCloneObject = __webpack_require__(108), isArguments = __webpack_require__(22), isArray = __webpack_require__(11), isArrayLikeObject = __webpack_require__(112), isBuffer = __webpack_require__(42), isFunction = __webpack_require__(27), isObject = __webpack_require__(9), isPlainObject = __webpack_require__(114), isTypedArray = __webpack_require__(43), safeGet = __webpack_require__(44), toPlainObject = __webpack_require__(118); /** * A specialized version of `baseMerge` for arrays and objects which performs * deep merges and tracks traversed objects enabling objects with circular * references to be merged. * * @private * @param {Object} object The destination object. * @param {Object} source The source object. * @param {string} key The key of the value to merge. * @param {number} srcIndex The index of `source`. * @param {Function} mergeFunc The function to merge values. * @param {Function} [customizer] The function to customize assigned values. * @param {Object} [stack] Tracks traversed source values and their merged * counterparts. */ function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) { var objValue = safeGet(object, key), srcValue = safeGet(source, key), stacked = stack.get(srcValue); if (stacked) { assignMergeValue(object, key, stacked); return; } var newValue = customizer ? customizer(objValue, srcValue, (key + ''), object, source, stack) : undefined; var isCommon = newValue === undefined; if (isCommon) { var isArr = isArray(srcValue), isBuff = !isArr && isBuffer(srcValue), isTyped = !isArr && !isBuff && isTypedArray(srcValue); newValue = srcValue; if (isArr || isBuff || isTyped) { if (isArray(objValue)) { newValue = objValue; } else if (isArrayLikeObject(objValue)) { newValue = copyArray(objValue); } else if (isBuff) { isCommon = false; newValue = cloneBuffer(srcValue, true); } else if (isTyped) { isCommon = false; newValue = cloneTypedArray(srcValue, true); } else { newValue = []; } } else if (isPlainObject(srcValue) || isArguments(srcValue)) { newValue = objValue; if (isArguments(objValue)) { newValue = toPlainObject(objValue); } else if (!isObject(objValue) || isFunction(objValue)) { newValue = initCloneObject(srcValue); } } else { isCommon = false; } } if (isCommon) { // Recursively merge objects and arrays (susceptible to call stack limits). stack.set(srcValue, newValue); mergeFunc(newValue, srcValue, srcIndex, customizer, stack); stack['delete'](srcValue); } assignMergeValue(object, key, newValue); } module.exports = baseMergeDeep; /***/ }), /* 103 */ /***/ (function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(13); /** Detect free variable `exports`. */ var freeExports = true && exports && !exports.nodeType && exports; /** Detect free variable `module`. */ var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; /** Detect the popular CommonJS extension `module.exports`. */ var moduleExports = freeModule && freeModule.exports === freeExports; /** Built-in value references. */ var Buffer = moduleExports ? root.Buffer : undefined, allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined; /** * Creates a clone of `buffer`. * * @private * @param {Buffer} buffer The buffer to clone. * @param {boolean} [isDeep] Specify a deep clone. * @returns {Buffer} Returns the cloned buffer. */ function cloneBuffer(buffer, isDeep) { if (isDeep) { return buffer.slice(); } var length = buffer.length, result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length); buffer.copy(result); return result; } module.exports = cloneBuffer; /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(29)(module))) /***/ }), /* 104 */ /***/ (function(module, exports, __webpack_require__) { var cloneArrayBuffer = __webpack_require__(105); /** * Creates a clone of `typedArray`. * * @private * @param {Object} typedArray The typed array to clone. * @param {boolean} [isDeep] Specify a deep clone. * @returns {Object} Returns the cloned typed array. */ function cloneTypedArray(typedArray, isDeep) { var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer; return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length); } module.exports = cloneTypedArray; /***/ }), /* 105 */ /***/ (function(module, exports, __webpack_require__) { var Uint8Array = __webpack_require__(106); /** * Creates a clone of `arrayBuffer`. * * @private * @param {ArrayBuffer} arrayBuffer The array buffer to clone. * @returns {ArrayBuffer} Returns the cloned array buffer. */ function cloneArrayBuffer(arrayBuffer) { var result = new arrayBuffer.constructor(arrayBuffer.byteLength); new Uint8Array(result).set(new Uint8Array(arrayBuffer)); return result; } module.exports = cloneArrayBuffer; /***/ }), /* 106 */ /***/ (function(module, exports, __webpack_require__) { var root = __webpack_require__(13); /** Built-in value references. */ var Uint8Array = root.Uint8Array; module.exports = Uint8Array; /***/ }), /* 107 */ /***/ (function(module, exports) { /** * Copies the values of `source` to `array`. * * @private * @param {Array} source The array to copy values from. * @param {Array} [array=[]] The array to copy values to. * @returns {Array} Returns `array`. */ function copyArray(source, array) { var index = -1, length = source.length; array || (array = Array(length)); while (++index < length) { array[index] = source[index]; } return array; } module.exports = copyArray; /***/ }), /* 108 */ /***/ (function(module, exports, __webpack_require__) { var baseCreate = __webpack_require__(109), getPrototype = __webpack_require__(40), isPrototype = __webpack_require__(41); /** * Initializes an object clone. * * @private * @param {Object} object The object to clone. * @returns {Object} Returns the initialized clone. */ function initCloneObject(object) { return (typeof object.constructor == 'function' && !isPrototype(object)) ? baseCreate(getPrototype(object)) : {}; } module.exports = initCloneObject; /***/ }), /* 109 */ /***/ (function(module, exports, __webpack_require__) { var isObject = __webpack_require__(9); /** Built-in value references. */ var objectCreate = Object.create; /** * The base implementation of `_.create` without support for assigning * properties to the created object. * * @private * @param {Object} proto The object to inherit from. * @returns {Object} Returns the new object. */ var baseCreate = (function() { function object() {} return function(proto) { if (!isObject(proto)) { return {}; } if (objectCreate) { return objectCreate(proto); } object.prototype = proto; var result = new object; object.prototype = undefined; return result; }; }()); module.exports = baseCreate; /***/ }), /* 110 */ /***/ (function(module, exports) { /** * Creates a unary function that invokes `func` with its argument transformed. * * @private * @param {Function} func The function to wrap. * @param {Function} transform The argument transform. * @returns {Function} Returns the new function. */ function overArg(func, transform) { return function(arg) { return func(transform(arg)); }; } module.exports = overArg; /***/ }), /* 111 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(15), isObjectLike = __webpack_require__(14); /** `Object#toString` result references. */ var argsTag = '[object Arguments]'; /** * The base implementation of `_.isArguments`. * * @private * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is an `arguments` object, */ function baseIsArguments(value) { return isObjectLike(value) && baseGetTag(value) == argsTag; } module.exports = baseIsArguments; /***/ }), /* 112 */ /***/ (function(module, exports, __webpack_require__) { var isArrayLike = __webpack_require__(30), isObjectLike = __webpack_require__(14); /** * This method is like `_.isArrayLike` except that it also checks if `value` * is an object. * * @static * @memberOf _ * @since 4.0.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is an array-like object, * else `false`. * @example * * _.isArrayLikeObject([1, 2, 3]); * // => true * * _.isArrayLikeObject(document.body.children); * // => true * * _.isArrayLikeObject('abc'); * // => false * * _.isArrayLikeObject(_.noop); * // => false */ function isArrayLikeObject(value) { return isObjectLike(value) && isArrayLike(value); } module.exports = isArrayLikeObject; /***/ }), /* 113 */ /***/ (function(module, exports) { /** * This method returns `false`. * * @static * @memberOf _ * @since 4.13.0 * @category Util * @returns {boolean} Returns `false`. * @example * * _.times(2, _.stubFalse); * // => [false, false] */ function stubFalse() { return false; } module.exports = stubFalse; /***/ }), /* 114 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(15), getPrototype = __webpack_require__(40), isObjectLike = __webpack_require__(14); /** `Object#toString` result references. */ var objectTag = '[object Object]'; /** Used for built-in method references. */ var funcProto = Function.prototype, objectProto = Object.prototype; /** Used to resolve the decompiled source of functions. */ var funcToString = funcProto.toString; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** Used to infer the `Object` constructor. */ var objectCtorString = funcToString.call(Object); /** * Checks if `value` is a plain object, that is, an object created by the * `Object` constructor or one with a `[[Prototype]]` of `null`. * * @static * @memberOf _ * @since 0.8.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a plain object, else `false`. * @example * * function Foo() { * this.a = 1; * } * * _.isPlainObject(new Foo); * // => false * * _.isPlainObject([1, 2, 3]); * // => false * * _.isPlainObject({ 'x': 0, 'y': 0 }); * // => true * * _.isPlainObject(Object.create(null)); * // => true */ function isPlainObject(value) { if (!isObjectLike(value) || baseGetTag(value) != objectTag) { return false; } var proto = getPrototype(value); if (proto === null) { return true; } var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor; return typeof Ctor == 'function' && Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString; } module.exports = isPlainObject; /***/ }), /* 115 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(15), isLength = __webpack_require__(31), isObjectLike = __webpack_require__(14); /** `Object#toString` result references. */ var argsTag = '[object Arguments]', arrayTag = '[object Array]', boolTag = '[object Boolean]', dateTag = '[object Date]', errorTag = '[object Error]', funcTag = '[object Function]', mapTag = '[object Map]', numberTag = '[object Number]', objectTag = '[object Object]', regexpTag = '[object RegExp]', setTag = '[object Set]', stringTag = '[object String]', weakMapTag = '[object WeakMap]'; var arrayBufferTag = '[object ArrayBuffer]', dataViewTag = '[object DataView]', float32Tag = '[object Float32Array]', float64Tag = '[object Float64Array]', int8Tag = '[object Int8Array]', int16Tag = '[object Int16Array]', int32Tag = '[object Int32Array]', uint8Tag = '[object Uint8Array]', uint8ClampedTag = '[object Uint8ClampedArray]', uint16Tag = '[object Uint16Array]', uint32Tag = '[object Uint32Array]'; /** Used to identify `toStringTag` values of typed arrays. */ var typedArrayTags = {}; typedArrayTags[float32Tag] = typedArrayTags[float64Tag] = typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = typedArrayTags[uint32Tag] = true; typedArrayTags[argsTag] = typedArrayTags[arrayTag] = typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = typedArrayTags[dataViewTag] = typedArrayTags[dateTag] = typedArrayTags[errorTag] = typedArrayTags[funcTag] = typedArrayTags[mapTag] = typedArrayTags[numberTag] = typedArrayTags[objectTag] = typedArrayTags[regexpTag] = typedArrayTags[setTag] = typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false; /** * The base implementation of `_.isTypedArray` without Node.js optimizations. * * @private * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. */ function baseIsTypedArray(value) { return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[baseGetTag(value)]; } module.exports = baseIsTypedArray; /***/ }), /* 116 */ /***/ (function(module, exports) { /** * The base implementation of `_.unary` without support for storing metadata. * * @private * @param {Function} func The function to cap arguments for. * @returns {Function} Returns the new capped function. */ function baseUnary(func) { return function(value) { return func(value); }; } module.exports = baseUnary; /***/ }), /* 117 */ /***/ (function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(module) {var freeGlobal = __webpack_require__(36); /** Detect free variable `exports`. */ var freeExports = true && exports && !exports.nodeType && exports; /** Detect free variable `module`. */ var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; /** Detect the popular CommonJS extension `module.exports`. */ var moduleExports = freeModule && freeModule.exports === freeExports; /** Detect free variable `process` from Node.js. */ var freeProcess = moduleExports && freeGlobal.process; /** Used to access faster Node.js helpers. */ var nodeUtil = (function() { try { // Use `util.types` for Node.js 10+. var types = freeModule && freeModule.require && freeModule.require('util').types; if (types) { return types; } // Legacy `process.binding('util')` for Node.js < 10. return freeProcess && freeProcess.binding && freeProcess.binding('util'); } catch (e) {} }()); module.exports = nodeUtil; /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(29)(module))) /***/ }), /* 118 */ /***/ (function(module, exports, __webpack_require__) { var copyObject = __webpack_require__(119), keysIn = __webpack_require__(46); /** * Converts `value` to a plain object flattening inherited enumerable string * keyed properties of `value` to own properties of the plain object. * * @static * @memberOf _ * @since 3.0.0 * @category Lang * @param {*} value The value to convert. * @returns {Object} Returns the converted plain object. * @example * * function Foo() { * this.b = 2; * } * * Foo.prototype.c = 3; * * _.assign({ 'a': 1 }, new Foo); * // => { 'a': 1, 'b': 2 } * * _.assign({ 'a': 1 }, _.toPlainObject(new Foo)); * // => { 'a': 1, 'b': 2, 'c': 3 } */ function toPlainObject(value) { return copyObject(value, keysIn(value)); } module.exports = toPlainObject; /***/ }), /* 119 */ /***/ (function(module, exports, __webpack_require__) { var assignValue = __webpack_require__(45), baseAssignValue = __webpack_require__(28); /** * Copies properties of `source` to `object`. * * @private * @param {Object} source The object to copy properties from. * @param {Array} props The property identifiers to copy. * @param {Object} [object={}] The object to copy properties to. * @param {Function} [customizer] The function to customize copied values. * @returns {Object} Returns `object`. */ function copyObject(source, props, object, customizer) { var isNew = !object; object || (object = {}); var index = -1, length = props.length; while (++index < length) { var key = props[index]; var newValue = customizer ? customizer(object[key], source[key], key, object, source) : undefined; if (newValue === undefined) { newValue = source[key]; } if (isNew) { baseAssignValue(object, key, newValue); } else { assignValue(object, key, newValue); } } return object; } module.exports = copyObject; /***/ }), /* 120 */ /***/ (function(module, exports, __webpack_require__) { var baseTimes = __webpack_require__(121), isArguments = __webpack_require__(22), isArray = __webpack_require__(11), isBuffer = __webpack_require__(42), isIndex = __webpack_require__(23), isTypedArray = __webpack_require__(43); /** Used for built-in method references. */ var objectProto = Object.prototype; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** * Creates an array of the enumerable property names of the array-like `value`. * * @private * @param {*} value The value to query. * @param {boolean} inherited Specify returning inherited property names. * @returns {Array} Returns the array of property names. */ function arrayLikeKeys(value, inherited) { var isArr = isArray(value), isArg = !isArr && isArguments(value), isBuff = !isArr && !isArg && isBuffer(value), isType = !isArr && !isArg && !isBuff && isTypedArray(value), skipIndexes = isArr || isArg || isBuff || isType, result = skipIndexes ? baseTimes(value.length, String) : [], length = result.length; for (var key in value) { if ((inherited || hasOwnProperty.call(value, key)) && !(skipIndexes && ( // Safari 9 has enumerable `arguments.length` in strict mode. key == 'length' || // Node.js 0.10 has enumerable non-index properties on buffers. (isBuff && (key == 'offset' || key == 'parent')) || // PhantomJS 2 has enumerable non-index properties on typed arrays. (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) || // Skip index properties. isIndex(key, length) ))) { result.push(key); } } return result; } module.exports = arrayLikeKeys; /***/ }), /* 121 */ /***/ (function(module, exports) { /** * The base implementation of `_.times` without support for iteratee shorthands * or max array length checks. * * @private * @param {number} n The number of times to invoke `iteratee`. * @param {Function} iteratee The function invoked per iteration. * @returns {Array} Returns the array of results. */ function baseTimes(n, iteratee) { var index = -1, result = Array(n); while (++index < n) { result[index] = iteratee(index); } return result; } module.exports = baseTimes; /***/ }), /* 122 */ /***/ (function(module, exports, __webpack_require__) { var isObject = __webpack_require__(9), isPrototype = __webpack_require__(41), nativeKeysIn = __webpack_require__(123); /** Used for built-in method references. */ var objectProto = Object.prototype; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; /** * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense. * * @private * @param {Object} object The object to query. * @returns {Array} Returns the array of property names. */ function baseKeysIn(object) { if (!isObject(object)) { return nativeKeysIn(object); } var isProto = isPrototype(object), result = []; for (var key in object) { if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { result.push(key); } } return result; } module.exports = baseKeysIn; /***/ }), /* 123 */ /***/ (function(module, exports) { /** * This function is like * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) * except that it includes inherited enumerable properties. * * @private * @param {Object} object The object to query. * @returns {Array} Returns the array of property names. */ function nativeKeysIn(object) { var result = []; if (object != null) { for (var key in Object(object)) { result.push(key); } } return result; } module.exports = nativeKeysIn; /***/ }), /* 124 */ /***/ (function(module, exports, __webpack_require__) { var baseRest = __webpack_require__(125), isIterateeCall = __webpack_require__(130); /** * Creates a function like `_.assign`. * * @private * @param {Function} assigner The function to assign values. * @returns {Function} Returns the new assigner function. */ function createAssigner(assigner) { return baseRest(function(object, sources) { var index = -1, length = sources.length, customizer = length > 1 ? sources[length - 1] : undefined, guard = length > 2 ? sources[2] : undefined; customizer = (assigner.length > 3 && typeof customizer == 'function') ? (length--, customizer) : undefined; if (guard && isIterateeCall(sources[0], sources[1], guard)) { customizer = length < 3 ? undefined : customizer; length = 1; } object = Object(object); while (++index < length) { var source = sources[index]; if (source) { assigner(object, source, index, customizer); } } return object; }); } module.exports = createAssigner; /***/ }), /* 125 */ /***/ (function(module, exports, __webpack_require__) { var identity = __webpack_require__(47), overRest = __webpack_require__(48), setToString = __webpack_require__(49); /** * The base implementation of `_.rest` which doesn't validate or coerce arguments. * * @private * @param {Function} func The function to apply a rest parameter to. * @param {number} [start=func.length-1] The start position of the rest parameter. * @returns {Function} Returns the new function. */ function baseRest(func, start) { return setToString(overRest(func, start, identity), func + ''); } module.exports = baseRest; /***/ }), /* 126 */ /***/ (function(module, exports) { /** * A faster alternative to `Function#apply`, this function invokes `func` * with the `this` binding of `thisArg` and the arguments of `args`. * * @private * @param {Function} func The function to invoke. * @param {*} thisArg The `this` binding of `func`. * @param {Array} args The arguments to invoke `func` with. * @returns {*} Returns the result of `func`. */ function apply(func, thisArg, args) { switch (args.length) { case 0: return func.call(thisArg); case 1: return func.call(thisArg, args[0]); case 2: return func.call(thisArg, args[0], args[1]); case 3: return func.call(thisArg, args[0], args[1], args[2]); } return func.apply(thisArg, args); } module.exports = apply; /***/ }), /* 127 */ /***/ (function(module, exports, __webpack_require__) { var constant = __webpack_require__(128), defineProperty = __webpack_require__(39), identity = __webpack_require__(47); /** * The base implementation of `setToString` without support for hot loop shorting. * * @private * @param {Function} func The function to modify. * @param {Function} string The `toString` result. * @returns {Function} Returns `func`. */ var baseSetToString = !defineProperty ? identity : function(func, string) { return defineProperty(func, 'toString', { 'configurable': true, 'enumerable': false, 'value': constant(string), 'writable': true }); }; module.exports = baseSetToString; /***/ }), /* 128 */ /***/ (function(module, exports) { /** * Creates a function that returns `value`. * * @static * @memberOf _ * @since 2.4.0 * @category Util * @param {*} value The value to return from the new function. * @returns {Function} Returns the new constant function. * @example * * var objects = _.times(2, _.constant({ 'a': 1 })); * * console.log(objects); * // => [{ 'a': 1 }, { 'a': 1 }] * * console.log(objects[0] === objects[1]); * // => true */ function constant(value) { return function() { return value; }; } module.exports = constant; /***/ }), /* 129 */ /***/ (function(module, exports) { /** Used to detect hot functions by number of calls within a span of milliseconds. */ var HOT_COUNT = 800, HOT_SPAN = 16; /* Built-in method references for those with the same name as other `lodash` methods. */ var nativeNow = Date.now; /** * Creates a function that'll short out and invoke `identity` instead * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN` * milliseconds. * * @private * @param {Function} func The function to restrict. * @returns {Function} Returns the new shortable function. */ function shortOut(func) { var count = 0, lastCalled = 0; return function() { var stamp = nativeNow(), remaining = HOT_SPAN - (stamp - lastCalled); lastCalled = stamp; if (remaining > 0) { if (++count >= HOT_COUNT) { return arguments[0]; } } else { count = 0; } return func.apply(undefined, arguments); }; } module.exports = shortOut; /***/ }), /* 130 */ /***/ (function(module, exports, __webpack_require__) { var eq = __webpack_require__(18), isArrayLike = __webpack_require__(30), isIndex = __webpack_require__(23), isObject = __webpack_require__(9); /** * Checks if the given arguments are from an iteratee call. * * @private * @param {*} value The potential iteratee value argument. * @param {*} index The potential iteratee index or key argument. * @param {*} object The potential iteratee object argument. * @returns {boolean} Returns `true` if the arguments are from an iteratee call, * else `false`. */ function isIterateeCall(value, index, object) { if (!isObject(object)) { return false; } var type = typeof index; if (type == 'number' ? (isArrayLike(object) && isIndex(index, object.length)) : (type == 'string' && index in object) ) { return eq(object[index], value); } return false; } module.exports = isIterateeCall; /***/ }), /* 131 */ /***/ (function(module, exports) { /* * typedefs.js * Normalizes browser-specific prefixes and provide some basic polyfills */ if (typeof window !== 'undefined') { if (!window.requestAnimationFrame) { window.requestAnimationFrame = function () { return window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (/* function FrameRequestCallback */callback) { window.setTimeout(callback, 1000 / 60); }; }(); } } if (typeof Math.imul !== 'function') { /* eslint-disable no-bitwise */ Math.imul = function (a, b) { var ah = a >>> 16 & 0xffff; var al = a & 0xffff; var bh = b >>> 16 & 0xffff; var bl = b & 0xffff; // the shift by 0 fixes the sign on the high part // the final |0 converts the unsigned value into a signed value return al * bl + (ah * bl + al * bh << 16 >>> 0) | 0; }; /* eslint-enable no-bitwise */ } if (typeof Object.assign !== 'function') { Object.assign = function (target) { // .length of function is 2 'use strict'; if (target === null) { // TypeError if undefined or null throw new TypeError('Cannot convert undefined or null to object'); } var to = Object(target); for (var index = 1; index < arguments.length; index++) { // eslint-disable-next-line prefer-rest-params var nextSource = arguments[index]; if (nextSource !== null) { // Skip over if undefined or null // eslint-disable-next-line no-restricted-syntax for (var nextKey in nextSource) { // Avoid bugs when hasOwnProperty is shadowed if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) { to[nextKey] = nextSource[nextKey]; } } } } return to; }; } /***/ }), /* 132 */ /***/ (function(module, exports) { function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } module.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 133 */ /***/ (function(module, exports) { function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } module.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 134 */ /***/ (function(module, exports) { function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } module.exports = _nonIterableRest, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 135 */ /***/ (function(module, exports, __webpack_require__) { var _typeof = __webpack_require__(8)["default"]; function toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } module.exports = toPrimitive, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 136 */ /***/ (function(module, exports, __webpack_require__) { var OverloadYield = __webpack_require__(53); var regenerator = __webpack_require__(54); var regeneratorAsync = __webpack_require__(137); var regeneratorAsyncGen = __webpack_require__(56); var regeneratorAsyncIterator = __webpack_require__(57); var regeneratorKeys = __webpack_require__(138); var regeneratorValues = __webpack_require__(139); function _regeneratorRuntime() { "use strict"; var r = regenerator(), e = r.m(_regeneratorRuntime), t = (Object.getPrototypeOf ? Object.getPrototypeOf(e) : e.__proto__).constructor; function n(r) { var e = "function" == typeof r && r.constructor; return !!e && (e === t || "GeneratorFunction" === (e.displayName || e.name)); } var o = { "throw": 1, "return": 2, "break": 3, "continue": 3 }; function a(r) { var e, t; return function (n) { e || (e = { stop: function stop() { return t(n.a, 2); }, "catch": function _catch() { return n.v; }, abrupt: function abrupt(r, e) { return t(n.a, o[r], e); }, delegateYield: function delegateYield(r, o, a) { return e.resultName = o, t(n.d, regeneratorValues(r), a); }, finish: function finish(r) { return t(n.f, r); } }, t = function t(r, _t, o) { n.p = e.prev, n.n = e.next; try { return r(_t, o); } finally { e.next = n.n; } }), e.resultName && (e[e.resultName] = n.v, e.resultName = void 0), e.sent = n.v, e.next = n.n; try { return r.call(this, e); } finally { n.p = e.prev, n.n = e.next; } }; } return (module.exports = _regeneratorRuntime = function _regeneratorRuntime() { return { wrap: function wrap(e, t, n, o) { return r.w(a(e), t, n, o && o.reverse()); }, isGeneratorFunction: n, mark: r.m, awrap: function awrap(r, e) { return new OverloadYield(r, e); }, AsyncIterator: regeneratorAsyncIterator, async: function async(r, e, t, o, u) { return (n(e) ? regeneratorAsyncGen : regeneratorAsync)(a(r), e, t, o, u); }, keys: regeneratorKeys, values: regeneratorValues }; }, module.exports.__esModule = true, module.exports["default"] = module.exports)(); } module.exports = _regeneratorRuntime, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 137 */ /***/ (function(module, exports, __webpack_require__) { var regeneratorAsyncGen = __webpack_require__(56); function _regeneratorAsync(n, e, r, t, o) { var a = regeneratorAsyncGen(n, e, r, t, o); return a.next().then(function (n) { return n.done ? n.value : a.next(); }); } module.exports = _regeneratorAsync, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 138 */ /***/ (function(module, exports) { function _regeneratorKeys(e) { var n = Object(e), r = []; for (var t in n) r.unshift(t); return function e() { for (; r.length;) if ((t = r.pop()) in n) return e.value = t, e.done = !1, e; return e.done = !0, e; }; } module.exports = _regeneratorKeys, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 139 */ /***/ (function(module, exports, __webpack_require__) { var _typeof = __webpack_require__(8)["default"]; function _regeneratorValues(e) { if (null != e) { var t = e["function" == typeof Symbol && Symbol.iterator || "@@iterator"], r = 0; if (t) return t.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) return { next: function next() { return e && r >= e.length && (e = void 0), { value: e && e[r++], done: !e }; } }; } throw new TypeError(_typeof(e) + " is not iterable"); } module.exports = _regeneratorValues, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 140 */ /***/ (function(module, exports) { function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } module.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 141 */ /***/ (function(module, exports, __webpack_require__) { var getPrototypeOf = __webpack_require__(1); function _superPropBase(t, o) { for (; !{}.hasOwnProperty.call(t, o) && null !== (t = getPrototypeOf(t));); return t; } module.exports = _superPropBase, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 142 */ /***/ (function(module, exports, __webpack_require__) { var arrayLikeToArray = __webpack_require__(51); function _arrayWithoutHoles(r) { if (Array.isArray(r)) return arrayLikeToArray(r); } module.exports = _arrayWithoutHoles, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 143 */ /***/ (function(module, exports) { function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } module.exports = _iterableToArray, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 144 */ /***/ (function(module, exports) { function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } module.exports = _nonIterableSpread, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 145 */ /***/ (function(module, exports, __webpack_require__) { var basePickBy = __webpack_require__(146), hasIn = __webpack_require__(156); /** * The base implementation of `_.pick` without support for individual * property identifiers. * * @private * @param {Object} object The source object. * @param {string[]} paths The property paths to pick. * @returns {Object} Returns the new object. */ function basePick(object, paths) { return basePickBy(object, paths, function(value, path) { return hasIn(object, path); }); } module.exports = basePick; /***/ }), /* 146 */ /***/ (function(module, exports, __webpack_require__) { var baseGet = __webpack_require__(147), baseSet = __webpack_require__(155), castPath = __webpack_require__(24); /** * The base implementation of `_.pickBy` without support for iteratee shorthands. * * @private * @param {Object} object The source object. * @param {string[]} paths The property paths to pick. * @param {Function} predicate The function invoked per property. * @returns {Object} Returns the new object. */ function basePickBy(object, paths, predicate) { var index = -1, length = paths.length, result = {}; while (++index < length) { var path = paths[index], value = baseGet(object, path); if (predicate(value, path)) { baseSet(result, castPath(path, object), value); } } return result; } module.exports = basePickBy; /***/ }), /* 147 */ /***/ (function(module, exports, __webpack_require__) { var castPath = __webpack_require__(24), toKey = __webpack_require__(34); /** * The base implementation of `_.get` without support for default values. * * @private * @param {Object} object The object to query. * @param {Array|string} path The path of the property to get. * @returns {*} Returns the resolved value. */ function baseGet(object, path) { path = castPath(path, object); var index = 0, length = path.length; while (object != null && index < length) { object = object[toKey(path[index++])]; } return (index && index == length) ? object : undefined; } module.exports = baseGet; /***/ }), /* 148 */ /***/ (function(module, exports, __webpack_require__) { var isArray = __webpack_require__(11), isSymbol = __webpack_require__(33); /** Used to match property names within property paths. */ var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, reIsPlainProp = /^\w*$/; /** * Checks if `value` is a property name and not a property path. * * @private * @param {*} value The value to check. * @param {Object} [object] The object to query keys on. * @returns {boolean} Returns `true` if `value` is a property name, else `false`. */ function isKey(value, object) { if (isArray(value)) { return false; } var type = typeof value; if (type == 'number' || type == 'symbol' || type == 'boolean' || value == null || isSymbol(value)) { return true; } return reIsPlainProp.test(value) || !reIsDeepProp.test(value) || (object != null && value in Object(object)); } module.exports = isKey; /***/ }), /* 149 */ /***/ (function(module, exports, __webpack_require__) { var memoizeCapped = __webpack_require__(150); /** Used to match property names within property paths. */ var rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; /** Used to match backslashes in property paths. */ var reEscapeChar = /\\(\\)?/g; /** * Converts `string` to a property path array. * * @private * @param {string} string The string to convert. * @returns {Array} Returns the property path array. */ var stringToPath = memoizeCapped(function(string) { var result = []; if (string.charCodeAt(0) === 46 /* . */) { result.push(''); } string.replace(rePropName, function(match, number, quote, subString) { result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match)); }); return result; }); module.exports = stringToPath; /***/ }), /* 150 */ /***/ (function(module, exports, __webpack_require__) { var memoize = __webpack_require__(151); /** Used as the maximum memoize cache size. */ var MAX_MEMOIZE_SIZE = 500; /** * A specialized version of `_.memoize` which clears the memoized function's * cache when it exceeds `MAX_MEMOIZE_SIZE`. * * @private * @param {Function} func The function to have its output memoized. * @returns {Function} Returns the new memoized function. */ function memoizeCapped(func) { var result = memoize(func, function(key) { if (cache.size === MAX_MEMOIZE_SIZE) { cache.clear(); } return key; }); var cache = result.cache; return result; } module.exports = memoizeCapped; /***/ }), /* 151 */ /***/ (function(module, exports, __webpack_require__) { var MapCache = __webpack_require__(37); /** Error message constants. */ var FUNC_ERROR_TEXT = 'Expected a function'; /** * Creates a function that memoizes the result of `func`. If `resolver` is * provided, it determines the cache key for storing the result based on the * arguments provided to the memoized function. By default, the first argument * provided to the memoized function is used as the map cache key. The `func` * is invoked with the `this` binding of the memoized function. * * **Note:** The cache is exposed as the `cache` property on the memoized * function. Its creation may be customized by replacing the `_.memoize.Cache` * constructor with one whose instances implement the * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object) * method interface of `clear`, `delete`, `get`, `has`, and `set`. * * @static * @memberOf _ * @since 0.1.0 * @category Function * @param {Function} func The function to have its output memoized. * @param {Function} [resolver] The function to resolve the cache key. * @returns {Function} Returns the new memoized function. * @example * * var object = { 'a': 1, 'b': 2 }; * var other = { 'c': 3, 'd': 4 }; * * var values = _.memoize(_.values); * values(object); * // => [1, 2] * * values(other); * // => [3, 4] * * object.a = 2; * values(object); * // => [1, 2] * * // Modify the result cache. * values.cache.set(object, ['a', 'b']); * values(object); * // => ['a', 'b'] * * // Replace `_.memoize.Cache`. * _.memoize.Cache = WeakMap; */ function memoize(func, resolver) { if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) { throw new TypeError(FUNC_ERROR_TEXT); } var memoized = function() { var args = arguments, key = resolver ? resolver.apply(this, args) : args[0], cache = memoized.cache; if (cache.has(key)) { return cache.get(key); } var result = func.apply(this, args); memoized.cache = cache.set(key, result) || cache; return result; }; memoized.cache = new (memoize.Cache || MapCache); return memoized; } // Expose `MapCache`. memoize.Cache = MapCache; module.exports = memoize; /***/ }), /* 152 */ /***/ (function(module, exports, __webpack_require__) { var baseToString = __webpack_require__(153); /** * Converts `value` to a string. An empty string is returned for `null` * and `undefined` values. The sign of `-0` is preserved. * * @static * @memberOf _ * @since 4.0.0 * @category Lang * @param {*} value The value to convert. * @returns {string} Returns the converted string. * @example * * _.toString(null); * // => '' * * _.toString(-0); * // => '-0' * * _.toString([1, 2, 3]); * // => '1,2,3' */ function toString(value) { return value == null ? '' : baseToString(value); } module.exports = toString; /***/ }), /* 153 */ /***/ (function(module, exports, __webpack_require__) { var Symbol = __webpack_require__(19), arrayMap = __webpack_require__(154), isArray = __webpack_require__(11), isSymbol = __webpack_require__(33); /** Used as references for various `Number` constants. */ var INFINITY = 1 / 0; /** Used to convert symbols to primitives and strings. */ var symbolProto = Symbol ? Symbol.prototype : undefined, symbolToString = symbolProto ? symbolProto.toString : undefined; /** * The base implementation of `_.toString` which doesn't convert nullish * values to empty strings. * * @private * @param {*} value The value to process. * @returns {string} Returns the string. */ function baseToString(value) { // Exit early for strings to avoid a performance hit in some environments. if (typeof value == 'string') { return value; } if (isArray(value)) { // Recursively convert values (susceptible to call stack limits). return arrayMap(value, baseToString) + ''; } if (isSymbol(value)) { return symbolToString ? symbolToString.call(value) : ''; } var result = (value + ''); return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; } module.exports = baseToString; /***/ }), /* 154 */ /***/ (function(module, exports) { /** * A specialized version of `_.map` for arrays without support for iteratee * shorthands. * * @private * @param {Array} [array] The array to iterate over. * @param {Function} iteratee The function invoked per iteration. * @returns {Array} Returns the new mapped array. */ function arrayMap(array, iteratee) { var index = -1, length = array == null ? 0 : array.length, result = Array(length); while (++index < length) { result[index] = iteratee(array[index], index, array); } return result; } module.exports = arrayMap; /***/ }), /* 155 */ /***/ (function(module, exports, __webpack_require__) { var assignValue = __webpack_require__(45), castPath = __webpack_require__(24), isIndex = __webpack_require__(23), isObject = __webpack_require__(9), toKey = __webpack_require__(34); /** * The base implementation of `_.set`. * * @private * @param {Object} object The object to modify. * @param {Array|string} path The path of the property to set. * @param {*} value The value to set. * @param {Function} [customizer] The function to customize path creation. * @returns {Object} Returns `object`. */ function baseSet(object, path, value, customizer) { if (!isObject(object)) { return object; } path = castPath(path, object); var index = -1, length = path.length, lastIndex = length - 1, nested = object; while (nested != null && ++index < length) { var key = toKey(path[index]), newValue = value; if (key === '__proto__' || key === 'constructor' || key === 'prototype') { return object; } if (index != lastIndex) { var objValue = nested[key]; newValue = customizer ? customizer(objValue, key, nested) : undefined; if (newValue === undefined) { newValue = isObject(objValue) ? objValue : (isIndex(path[index + 1]) ? [] : {}); } } assignValue(nested, key, newValue); nested = nested[key]; } return object; } module.exports = baseSet; /***/ }), /* 156 */ /***/ (function(module, exports, __webpack_require__) { var baseHasIn = __webpack_require__(157), hasPath = __webpack_require__(158); /** * Checks if `path` is a direct or inherited property of `object`. * * @static * @memberOf _ * @since 4.0.0 * @category Object * @param {Object} object The object to query. * @param {Array|string} path The path to check. * @returns {boolean} Returns `true` if `path` exists, else `false`. * @example * * var object = _.create({ 'a': _.create({ 'b': 2 }) }); * * _.hasIn(object, 'a'); * // => true * * _.hasIn(object, 'a.b'); * // => true * * _.hasIn(object, ['a', 'b']); * // => true * * _.hasIn(object, 'b'); * // => false */ function hasIn(object, path) { return object != null && hasPath(object, path, baseHasIn); } module.exports = hasIn; /***/ }), /* 157 */ /***/ (function(module, exports) { /** * The base implementation of `_.hasIn` without support for deep paths. * * @private * @param {Object} [object] The object to query. * @param {Array|string} key The key to check. * @returns {boolean} Returns `true` if `key` exists, else `false`. */ function baseHasIn(object, key) { return object != null && key in Object(object); } module.exports = baseHasIn; /***/ }), /* 158 */ /***/ (function(module, exports, __webpack_require__) { var castPath = __webpack_require__(24), isArguments = __webpack_require__(22), isArray = __webpack_require__(11), isIndex = __webpack_require__(23), isLength = __webpack_require__(31), toKey = __webpack_require__(34); /** * Checks if `path` exists on `object`. * * @private * @param {Object} object The object to query. * @param {Array|string} path The path to check. * @param {Function} hasFunc The function to check properties. * @returns {boolean} Returns `true` if `path` exists, else `false`. */ function hasPath(object, path, hasFunc) { path = castPath(path, object); var index = -1, length = path.length, result = false; while (++index < length) { var key = toKey(path[index]); if (!(result = object != null && hasFunc(object, key))) { break; } object = object[key]; } if (result || ++index != length) { return result; } length = object == null ? 0 : object.length; return !!length && isLength(length) && isIndex(key, length) && (isArray(object) || isArguments(object)); } module.exports = hasPath; /***/ }), /* 159 */ /***/ (function(module, exports, __webpack_require__) { var flatten = __webpack_require__(160), overRest = __webpack_require__(48), setToString = __webpack_require__(49); /** * A specialized version of `baseRest` which flattens the rest array. * * @private * @param {Function} func The function to apply a rest parameter to. * @returns {Function} Returns the new function. */ function flatRest(func) { return setToString(overRest(func, undefined, flatten), func + ''); } module.exports = flatRest; /***/ }), /* 160 */ /***/ (function(module, exports, __webpack_require__) { var baseFlatten = __webpack_require__(161); /** * Flattens `array` a single level deep. * * @static * @memberOf _ * @since 0.1.0 * @category Array * @param {Array} array The array to flatten. * @returns {Array} Returns the new flattened array. * @example * * _.flatten([1, [2, [3, [4]], 5]]); * // => [1, 2, [3, [4]], 5] */ function flatten(array) { var length = array == null ? 0 : array.length; return length ? baseFlatten(array, 1) : []; } module.exports = flatten; /***/ }), /* 161 */ /***/ (function(module, exports, __webpack_require__) { var arrayPush = __webpack_require__(162), isFlattenable = __webpack_require__(163); /** * The base implementation of `_.flatten` with support for restricting flattening. * * @private * @param {Array} array The array to flatten. * @param {number} depth The maximum recursion depth. * @param {boolean} [predicate=isFlattenable] The function invoked per iteration. * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks. * @param {Array} [result=[]] The initial result value. * @returns {Array} Returns the new flattened array. */ function baseFlatten(array, depth, predicate, isStrict, result) { var index = -1, length = array.length; predicate || (predicate = isFlattenable); result || (result = []); while (++index < length) { var value = array[index]; if (depth > 0 && predicate(value)) { if (depth > 1) { // Recursively flatten arrays (susceptible to call stack limits). baseFlatten(value, depth - 1, predicate, isStrict, result); } else { arrayPush(result, value); } } else if (!isStrict) { result[result.length] = value; } } return result; } module.exports = baseFlatten; /***/ }), /* 162 */ /***/ (function(module, exports) { /** * Appends the elements of `values` to `array`. * * @private * @param {Array} array The array to modify. * @param {Array} values The values to append. * @returns {Array} Returns `array`. */ function arrayPush(array, values) { var index = -1, length = values.length, offset = array.length; while (++index < length) { array[offset + index] = values[index]; } return array; } module.exports = arrayPush; /***/ }), /* 163 */ /***/ (function(module, exports, __webpack_require__) { var Symbol = __webpack_require__(19), isArguments = __webpack_require__(22), isArray = __webpack_require__(11); /** Built-in value references. */ var spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined; /** * Checks if `value` is a flattenable `arguments` object or array. * * @private * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is flattenable, else `false`. */ function isFlattenable(value) { return isArray(value) || isArguments(value) || !!(spreadableSymbol && value && value[spreadableSymbol]); } module.exports = isFlattenable; /***/ }), /* 164 */ /***/ (function(module, exports) { function _isNativeFunction(t) { try { return -1 !== Function.toString.call(t).indexOf("[native code]"); } catch (n) { return "function" == typeof t; } } module.exports = _isNativeFunction, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 165 */ /***/ (function(module, exports, __webpack_require__) { var isNativeReflectConstruct = __webpack_require__(166); var setPrototypeOf = __webpack_require__(32); function _construct(t, e, r) { if (isNativeReflectConstruct()) return Reflect.construct.apply(null, arguments); var o = [null]; o.push.apply(o, e); var p = new (t.bind.apply(t, o))(); return r && setPrototypeOf(p, r.prototype), p; } module.exports = _construct, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 166 */ /***/ (function(module, exports) { function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (module.exports = _isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; }, module.exports.__esModule = true, module.exports["default"] = module.exports)(); } module.exports = _isNativeReflectConstruct, module.exports.__esModule = true, module.exports["default"] = module.exports; /***/ }), /* 167 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; // ESM COMPAT FLAG __webpack_require__.r(__webpack_exports__); // EXPORTS __webpack_require__.d(__webpack_exports__, "BarcodeDecoder", function() { return /* reexport */ barcode_decoder; }); __webpack_require__.d(__webpack_exports__, "Readers", function() { return /* reexport */ reader_namespaceObject; }); __webpack_require__.d(__webpack_exports__, "CameraAccess", function() { return /* reexport */ camera_access; }); __webpack_require__.d(__webpack_exports__, "ImageDebug", function() { return /* reexport */ image_debug; }); __webpack_require__.d(__webpack_exports__, "ImageWrapper", function() { return /* reexport */ image_wrapper; }); __webpack_require__.d(__webpack_exports__, "ResultCollector", function() { return /* reexport */ result_collector; }); // NAMESPACE OBJECT: ./node_modules/gl-matrix/esm/mat2.js var mat2_namespaceObject = {}; __webpack_require__.r(mat2_namespaceObject); __webpack_require__.d(mat2_namespaceObject, "create", function() { return mat2_create; }); __webpack_require__.d(mat2_namespaceObject, "clone", function() { return clone; }); __webpack_require__.d(mat2_namespaceObject, "copy", function() { return copy; }); __webpack_require__.d(mat2_namespaceObject, "identity", function() { return identity; }); __webpack_require__.d(mat2_namespaceObject, "fromValues", function() { return fromValues; }); __webpack_require__.d(mat2_namespaceObject, "set", function() { return set; }); __webpack_require__.d(mat2_namespaceObject, "transpose", function() { return transpose; }); __webpack_require__.d(mat2_namespaceObject, "invert", function() { return invert; }); __webpack_require__.d(mat2_namespaceObject, "adjoint", function() { return adjoint; }); __webpack_require__.d(mat2_namespaceObject, "determinant", function() { return determinant; }); __webpack_require__.d(mat2_namespaceObject, "multiply", function() { return multiply; }); __webpack_require__.d(mat2_namespaceObject, "rotate", function() { return rotate; }); __webpack_require__.d(mat2_namespaceObject, "scale", function() { return mat2_scale; }); __webpack_require__.d(mat2_namespaceObject, "fromRotation", function() { return fromRotation; }); __webpack_require__.d(mat2_namespaceObject, "fromScaling", function() { return fromScaling; }); __webpack_require__.d(mat2_namespaceObject, "str", function() { return str; }); __webpack_require__.d(mat2_namespaceObject, "frob", function() { return frob; }); __webpack_require__.d(mat2_namespaceObject, "LDU", function() { return LDU; }); __webpack_require__.d(mat2_namespaceObject, "add", function() { return add; }); __webpack_require__.d(mat2_namespaceObject, "subtract", function() { return subtract; }); __webpack_require__.d(mat2_namespaceObject, "exactEquals", function() { return exactEquals; }); __webpack_require__.d(mat2_namespaceObject, "equals", function() { return mat2_equals; }); __webpack_require__.d(mat2_namespaceObject, "multiplyScalar", function() { return multiplyScalar; }); __webpack_require__.d(mat2_namespaceObject, "multiplyScalarAndAdd", function() { return multiplyScalarAndAdd; }); __webpack_require__.d(mat2_namespaceObject, "mul", function() { return mul; }); __webpack_require__.d(mat2_namespaceObject, "sub", function() { return sub; }); // NAMESPACE OBJECT: ./node_modules/gl-matrix/esm/vec2.js var vec2_namespaceObject = {}; __webpack_require__.r(vec2_namespaceObject); __webpack_require__.d(vec2_namespaceObject, "create", function() { return vec2_create; }); __webpack_require__.d(vec2_namespaceObject, "clone", function() { return vec2_clone; }); __webpack_require__.d(vec2_namespaceObject, "fromValues", function() { return vec2_fromValues; }); __webpack_require__.d(vec2_namespaceObject, "copy", function() { return vec2_copy; }); __webpack_require__.d(vec2_namespaceObject, "set", function() { return vec2_set; }); __webpack_require__.d(vec2_namespaceObject, "add", function() { return vec2_add; }); __webpack_require__.d(vec2_namespaceObject, "subtract", function() { return vec2_subtract; }); __webpack_require__.d(vec2_namespaceObject, "multiply", function() { return vec2_multiply; }); __webpack_require__.d(vec2_namespaceObject, "divide", function() { return divide; }); __webpack_require__.d(vec2_namespaceObject, "ceil", function() { return ceil; }); __webpack_require__.d(vec2_namespaceObject, "floor", function() { return floor; }); __webpack_require__.d(vec2_namespaceObject, "min", function() { return min; }); __webpack_require__.d(vec2_namespaceObject, "max", function() { return vec2_max; }); __webpack_require__.d(vec2_namespaceObject, "round", function() { return vec2_round; }); __webpack_require__.d(vec2_namespaceObject, "scale", function() { return vec2_scale; }); __webpack_require__.d(vec2_namespaceObject, "scaleAndAdd", function() { return scaleAndAdd; }); __webpack_require__.d(vec2_namespaceObject, "distance", function() { return distance; }); __webpack_require__.d(vec2_namespaceObject, "squaredDistance", function() { return squaredDistance; }); __webpack_require__.d(vec2_namespaceObject, "length", function() { return vec2_length; }); __webpack_require__.d(vec2_namespaceObject, "squaredLength", function() { return squaredLength; }); __webpack_require__.d(vec2_namespaceObject, "negate", function() { return negate; }); __webpack_require__.d(vec2_namespaceObject, "inverse", function() { return inverse; }); __webpack_require__.d(vec2_namespaceObject, "normalize", function() { return normalize; }); __webpack_require__.d(vec2_namespaceObject, "dot", function() { return dot; }); __webpack_require__.d(vec2_namespaceObject, "cross", function() { return cross; }); __webpack_require__.d(vec2_namespaceObject, "lerp", function() { return lerp; }); __webpack_require__.d(vec2_namespaceObject, "random", function() { return random; }); __webpack_require__.d(vec2_namespaceObject, "transformMat2", function() { return transformMat2; }); __webpack_require__.d(vec2_namespaceObject, "transformMat2d", function() { return transformMat2d; }); __webpack_require__.d(vec2_namespaceObject, "transformMat3", function() { return transformMat3; }); __webpack_require__.d(vec2_namespaceObject, "transformMat4", function() { return transformMat4; }); __webpack_require__.d(vec2_namespaceObject, "rotate", function() { return vec2_rotate; }); __webpack_require__.d(vec2_namespaceObject, "angle", function() { return angle; }); __webpack_require__.d(vec2_namespaceObject, "signedAngle", function() { return signedAngle; }); __webpack_require__.d(vec2_namespaceObject, "zero", function() { return zero; }); __webpack_require__.d(vec2_namespaceObject, "str", function() { return vec2_str; }); __webpack_require__.d(vec2_namespaceObject, "exactEquals", function() { return vec2_exactEquals; }); __webpack_require__.d(vec2_namespaceObject, "equals", function() { return vec2_equals; }); __webpack_require__.d(vec2_namespaceObject, "len", function() { return len; }); __webpack_require__.d(vec2_namespaceObject, "sub", function() { return vec2_sub; }); __webpack_require__.d(vec2_namespaceObject, "mul", function() { return vec2_mul; }); __webpack_require__.d(vec2_namespaceObject, "div", function() { return div; }); __webpack_require__.d(vec2_namespaceObject, "dist", function() { return dist; }); __webpack_require__.d(vec2_namespaceObject, "sqrDist", function() { return sqrDist; }); __webpack_require__.d(vec2_namespaceObject, "sqrLen", function() { return sqrLen; }); __webpack_require__.d(vec2_namespaceObject, "forEach", function() { return forEach; }); // NAMESPACE OBJECT: ./node_modules/gl-matrix/esm/vec3.js var vec3_namespaceObject = {}; __webpack_require__.r(vec3_namespaceObject); __webpack_require__.d(vec3_namespaceObject, "create", function() { return vec3_create; }); __webpack_require__.d(vec3_namespaceObject, "clone", function() { return vec3_clone; }); __webpack_require__.d(vec3_namespaceObject, "length", function() { return vec3_length; }); __webpack_require__.d(vec3_namespaceObject, "fromValues", function() { return vec3_fromValues; }); __webpack_require__.d(vec3_namespaceObject, "copy", function() { return vec3_copy; }); __webpack_require__.d(vec3_namespaceObject, "set", function() { return vec3_set; }); __webpack_require__.d(vec3_namespaceObject, "add", function() { return vec3_add; }); __webpack_require__.d(vec3_namespaceObject, "subtract", function() { return vec3_subtract; }); __webpack_require__.d(vec3_namespaceObject, "multiply", function() { return vec3_multiply; }); __webpack_require__.d(vec3_namespaceObject, "divide", function() { return vec3_divide; }); __webpack_require__.d(vec3_namespaceObject, "ceil", function() { return vec3_ceil; }); __webpack_require__.d(vec3_namespaceObject, "floor", function() { return vec3_floor; }); __webpack_require__.d(vec3_namespaceObject, "min", function() { return vec3_min; }); __webpack_require__.d(vec3_namespaceObject, "max", function() { return vec3_max; }); __webpack_require__.d(vec3_namespaceObject, "round", function() { return vec3_round; }); __webpack_require__.d(vec3_namespaceObject, "scale", function() { return vec3_scale; }); __webpack_require__.d(vec3_namespaceObject, "scaleAndAdd", function() { return vec3_scaleAndAdd; }); __webpack_require__.d(vec3_namespaceObject, "distance", function() { return vec3_distance; }); __webpack_require__.d(vec3_namespaceObject, "squaredDistance", function() { return vec3_squaredDistance; }); __webpack_require__.d(vec3_namespaceObject, "squaredLength", function() { return vec3_squaredLength; }); __webpack_require__.d(vec3_namespaceObject, "negate", function() { return vec3_negate; }); __webpack_require__.d(vec3_namespaceObject, "inverse", function() { return vec3_inverse; }); __webpack_require__.d(vec3_namespaceObject, "normalize", function() { return vec3_normalize; }); __webpack_require__.d(vec3_namespaceObject, "dot", function() { return vec3_dot; }); __webpack_require__.d(vec3_namespaceObject, "cross", function() { return vec3_cross; }); __webpack_require__.d(vec3_namespaceObject, "lerp", function() { return vec3_lerp; }); __webpack_require__.d(vec3_namespaceObject, "slerp", function() { return slerp; }); __webpack_require__.d(vec3_namespaceObject, "hermite", function() { return hermite; }); __webpack_require__.d(vec3_namespaceObject, "bezier", function() { return bezier; }); __webpack_require__.d(vec3_namespaceObject, "random", function() { return vec3_random; }); __webpack_require__.d(vec3_namespaceObject, "transformMat4", function() { return vec3_transformMat4; }); __webpack_require__.d(vec3_namespaceObject, "transformMat3", function() { return vec3_transformMat3; }); __webpack_require__.d(vec3_namespaceObject, "transformQuat", function() { return transformQuat; }); __webpack_require__.d(vec3_namespaceObject, "rotateX", function() { return rotateX; }); __webpack_require__.d(vec3_namespaceObject, "rotateY", function() { return rotateY; }); __webpack_require__.d(vec3_namespaceObject, "rotateZ", function() { return rotateZ; }); __webpack_require__.d(vec3_namespaceObject, "angle", function() { return vec3_angle; }); __webpack_require__.d(vec3_namespaceObject, "zero", function() { return vec3_zero; }); __webpack_require__.d(vec3_namespaceObject, "str", function() { return vec3_str; }); __webpack_require__.d(vec3_namespaceObject, "exactEquals", function() { return vec3_exactEquals; }); __webpack_require__.d(vec3_namespaceObject, "equals", function() { return vec3_equals; }); __webpack_require__.d(vec3_namespaceObject, "sub", function() { return vec3_sub; }); __webpack_require__.d(vec3_namespaceObject, "mul", function() { return vec3_mul; }); __webpack_require__.d(vec3_namespaceObject, "div", function() { return vec3_div; }); __webpack_require__.d(vec3_namespaceObject, "dist", function() { return vec3_dist; }); __webpack_require__.d(vec3_namespaceObject, "sqrDist", function() { return vec3_sqrDist; }); __webpack_require__.d(vec3_namespaceObject, "len", function() { return vec3_len; }); __webpack_require__.d(vec3_namespaceObject, "sqrLen", function() { return vec3_sqrLen; }); __webpack_require__.d(vec3_namespaceObject, "forEach", function() { return vec3_forEach; }); // NAMESPACE OBJECT: ./src/reader/index.ts var reader_namespaceObject = {}; __webpack_require__.r(reader_namespaceObject); __webpack_require__.d(reader_namespaceObject, "BarcodeReader", function() { return barcode_reader; }); __webpack_require__.d(reader_namespaceObject, "TwoOfFiveReader", function() { return _2of5_reader; }); __webpack_require__.d(reader_namespaceObject, "NewCodabarReader", function() { return codabar_reader; }); __webpack_require__.d(reader_namespaceObject, "Code128Reader", function() { return code_128_reader; }); __webpack_require__.d(reader_namespaceObject, "Code32Reader", function() { return code_32_reader; }); __webpack_require__.d(reader_namespaceObject, "Code39Reader", function() { return code_39_reader; }); __webpack_require__.d(reader_namespaceObject, "Code39VINReader", function() { return code_39_vin_reader; }); __webpack_require__.d(reader_namespaceObject, "Code93Reader", function() { return code_93_reader; }); __webpack_require__.d(reader_namespaceObject, "EAN2Reader", function() { return ean_2_reader; }); __webpack_require__.d(reader_namespaceObject, "EAN5Reader", function() { return ean_5_reader; }); __webpack_require__.d(reader_namespaceObject, "EAN8Reader", function() { return ean_8_reader; }); __webpack_require__.d(reader_namespaceObject, "EANReader", function() { return ean_reader; }); __webpack_require__.d(reader_namespaceObject, "I2of5Reader", function() { return i2of5_reader; }); __webpack_require__.d(reader_namespaceObject, "UPCEReader", function() { return upc_e_reader; }); __webpack_require__.d(reader_namespaceObject, "UPCReader", function() { return upc_reader; }); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/typeof.js var helpers_typeof = __webpack_require__(8); var typeof_default = /*#__PURE__*/__webpack_require__.n(helpers_typeof); // EXTERNAL MODULE: ./node_modules/lodash/merge.js var merge = __webpack_require__(12); var merge_default = /*#__PURE__*/__webpack_require__.n(merge); // EXTERNAL MODULE: ./src/common/typedefs.js var typedefs = __webpack_require__(131); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/slicedToArray.js var slicedToArray = __webpack_require__(58); var slicedToArray_default = /*#__PURE__*/__webpack_require__.n(slicedToArray); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/classCallCheck.js var classCallCheck = __webpack_require__(2); var classCallCheck_default = /*#__PURE__*/__webpack_require__.n(classCallCheck); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/createClass.js var createClass = __webpack_require__(3); var createClass_default = /*#__PURE__*/__webpack_require__.n(createClass); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/defineProperty.js var defineProperty = __webpack_require__(0); var defineProperty_default = /*#__PURE__*/__webpack_require__.n(defineProperty); // CONCATENATED MODULE: ./node_modules/gl-matrix/esm/common.js /** * Common utilities * @module glMatrix */ // Configuration Constants var EPSILON = 0.000001; var ARRAY_TYPE = typeof Float32Array !== "undefined" ? Float32Array : Array; var RANDOM = Math.random; var ANGLE_ORDER = "zyx"; /** * Symmetric round * see https://www.npmjs.com/package/round-half-up-symmetric#user-content-detailed-background * * @param {Number} a value to round */ function round(a) { if (a >= 0) return Math.round(a); return a % 0.5 === 0 ? Math.floor(a) : Math.round(a); } /** * Sets the type of array used when creating new vectors and matrices * * @param {Float32ArrayConstructor | ArrayConstructor} type Array type, such as Float32Array or Array */ function setMatrixArrayType(type) { ARRAY_TYPE = type; } var degree = Math.PI / 180; var radian = 180 / Math.PI; /** * Convert Degree To Radian * * @param {Number} a Angle in Degrees */ function toRadian(a) { return a * degree; } /** * Convert Radian To Degree * * @param {Number} a Angle in Radians */ function toDegree(a) { return a * radian; } /** * Tests whether or not the arguments have approximately the same value, within an absolute * or relative tolerance of glMatrix.EPSILON (an absolute tolerance is used for values less * than or equal to 1.0, and a relative tolerance is used for larger values) * * @param {Number} a The first number to test. * @param {Number} b The second number to test. * @param {Number} tolerance Absolute or relative tolerance (default glMatrix.EPSILON) * @returns {Boolean} True if the numbers are approximately equal, false otherwise. */ function equals(a, b) { var tolerance = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : EPSILON; return Math.abs(a - b) <= tolerance * Math.max(1, Math.abs(a), Math.abs(b)); } // CONCATENATED MODULE: ./node_modules/gl-matrix/esm/mat2.js /** * 2x2 Matrix * @module mat2 */ /** * Creates a new identity mat2 * * @returns {mat2} a new 2x2 matrix */ function mat2_create() { var out = new ARRAY_TYPE(4); if (ARRAY_TYPE != Float32Array) { out[1] = 0; out[2] = 0; } out[0] = 1; out[3] = 1; return out; } /** * Creates a new mat2 initialized with values from an existing matrix * * @param {ReadonlyMat2} a matrix to clone * @returns {mat2} a new 2x2 matrix */ function clone(a) { var out = new ARRAY_TYPE(4); out[0] = a[0]; out[1] = a[1]; out[2] = a[2]; out[3] = a[3]; return out; } /** * Copy the values from one mat2 to another * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the source matrix * @returns {mat2} out */ function copy(out, a) { out[0] = a[0]; out[1] = a[1]; out[2] = a[2]; out[3] = a[3]; return out; } /** * Set a mat2 to the identity matrix * * @param {mat2} out the receiving matrix * @returns {mat2} out */ function identity(out) { out[0] = 1; out[1] = 0; out[2] = 0; out[3] = 1; return out; } /** * Create a new mat2 with the given values * * @param {Number} m00 Component in column 0, row 0 position (index 0) * @param {Number} m01 Component in column 0, row 1 position (index 1) * @param {Number} m10 Component in column 1, row 0 position (index 2) * @param {Number} m11 Component in column 1, row 1 position (index 3) * @returns {mat2} out A new 2x2 matrix */ function fromValues(m00, m01, m10, m11) { var out = new ARRAY_TYPE(4); out[0] = m00; out[1] = m01; out[2] = m10; out[3] = m11; return out; } /** * Set the components of a mat2 to the given values * * @param {mat2} out the receiving matrix * @param {Number} m00 Component in column 0, row 0 position (index 0) * @param {Number} m01 Component in column 0, row 1 position (index 1) * @param {Number} m10 Component in column 1, row 0 position (index 2) * @param {Number} m11 Component in column 1, row 1 position (index 3) * @returns {mat2} out */ function set(out, m00, m01, m10, m11) { out[0] = m00; out[1] = m01; out[2] = m10; out[3] = m11; return out; } /** * Transpose the values of a mat2 * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the source matrix * @returns {mat2} out */ function transpose(out, a) { // If we are transposing ourselves we can skip a few steps but have to cache // some values if (out === a) { var a1 = a[1]; out[1] = a[2]; out[2] = a1; } else { out[0] = a[0]; out[1] = a[2]; out[2] = a[1]; out[3] = a[3]; } return out; } /** * Inverts a mat2 * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the source matrix * @returns {mat2 | null} out, or null if source matrix is not invertible */ function invert(out, a) { var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3]; // Calculate the determinant var det = a0 * a3 - a2 * a1; if (!det) { return null; } det = 1.0 / det; out[0] = a3 * det; out[1] = -a1 * det; out[2] = -a2 * det; out[3] = a0 * det; return out; } /** * Calculates the adjugate of a mat2 * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the source matrix * @returns {mat2} out */ function adjoint(out, a) { // Caching this value is necessary if out == a var a0 = a[0]; out[0] = a[3]; out[1] = -a[1]; out[2] = -a[2]; out[3] = a0; return out; } /** * Calculates the determinant of a mat2 * * @param {ReadonlyMat2} a the source matrix * @returns {Number} determinant of a */ function determinant(a) { return a[0] * a[3] - a[2] * a[1]; } /** * Multiplies two mat2's * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the first operand * @param {ReadonlyMat2} b the second operand * @returns {mat2} out */ function multiply(out, a, b) { var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3]; var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3]; out[0] = a0 * b0 + a2 * b1; out[1] = a1 * b0 + a3 * b1; out[2] = a0 * b2 + a2 * b3; out[3] = a1 * b2 + a3 * b3; return out; } /** * Rotates a mat2 by the given angle * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the matrix to rotate * @param {Number} rad the angle to rotate the matrix by * @returns {mat2} out */ function rotate(out, a, rad) { var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3]; var s = Math.sin(rad); var c = Math.cos(rad); out[0] = a0 * c + a2 * s; out[1] = a1 * c + a3 * s; out[2] = a0 * -s + a2 * c; out[3] = a1 * -s + a3 * c; return out; } /** * Scales the mat2 by the dimensions in the given vec2 * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the matrix to rotate * @param {ReadonlyVec2} v the vec2 to scale the matrix by * @returns {mat2} out **/ function mat2_scale(out, a, v) { var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3]; var v0 = v[0], v1 = v[1]; out[0] = a0 * v0; out[1] = a1 * v0; out[2] = a2 * v1; out[3] = a3 * v1; return out; } /** * Creates a matrix from a given angle * This is equivalent to (but much faster than): * * mat2.identity(dest); * mat2.rotate(dest, dest, rad); * * @param {mat2} out mat2 receiving operation result * @param {Number} rad the angle to rotate the matrix by * @returns {mat2} out */ function fromRotation(out, rad) { var s = Math.sin(rad); var c = Math.cos(rad); out[0] = c; out[1] = s; out[2] = -s; out[3] = c; return out; } /** * Creates a matrix from a vector scaling * This is equivalent to (but much faster than): * * mat2.identity(dest); * mat2.scale(dest, dest, vec); * * @param {mat2} out mat2 receiving operation result * @param {ReadonlyVec2} v Scaling vector * @returns {mat2} out */ function fromScaling(out, v) { out[0] = v[0]; out[1] = 0; out[2] = 0; out[3] = v[1]; return out; } /** * Returns a string representation of a mat2 * * @param {ReadonlyMat2} a matrix to represent as a string * @returns {String} string representation of the matrix */ function str(a) { return "mat2(" + a[0] + ", " + a[1] + ", " + a[2] + ", " + a[3] + ")"; } /** * Returns Frobenius norm of a mat2 * * @param {ReadonlyMat2} a the matrix to calculate Frobenius norm of * @returns {Number} Frobenius norm */ function frob(a) { return Math.sqrt(a[0] * a[0] + a[1] * a[1] + a[2] * a[2] + a[3] * a[3]); } /** * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix * @param {ReadonlyMat2} L the lower triangular matrix * @param {ReadonlyMat2} D the diagonal matrix * @param {ReadonlyMat2} U the upper triangular matrix * @param {ReadonlyMat2} a the input matrix to factorize */ function LDU(L, D, U, a) { L[2] = a[2] / a[0]; U[0] = a[0]; U[1] = a[1]; U[3] = a[3] - L[2] * U[1]; return [L, D, U]; } /** * Adds two mat2's * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the first operand * @param {ReadonlyMat2} b the second operand * @returns {mat2} out */ function add(out, a, b) { out[0] = a[0] + b[0]; out[1] = a[1] + b[1]; out[2] = a[2] + b[2]; out[3] = a[3] + b[3]; return out; } /** * Subtracts matrix b from matrix a * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the first operand * @param {ReadonlyMat2} b the second operand * @returns {mat2} out */ function subtract(out, a, b) { out[0] = a[0] - b[0]; out[1] = a[1] - b[1]; out[2] = a[2] - b[2]; out[3] = a[3] - b[3]; return out; } /** * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===) * * @param {ReadonlyMat2} a The first matrix. * @param {ReadonlyMat2} b The second matrix. * @returns {Boolean} True if the matrices are equal, false otherwise. */ function exactEquals(a, b) { return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3]; } /** * Returns whether or not the matrices have approximately the same elements in the same position. * * @param {ReadonlyMat2} a The first matrix. * @param {ReadonlyMat2} b The second matrix. * @returns {Boolean} True if the matrices are equal, false otherwise. */ function mat2_equals(a, b) { var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3]; var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3]; return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)); } /** * Multiply each element of the matrix by a scalar. * * @param {mat2} out the receiving matrix * @param {ReadonlyMat2} a the matrix to scale * @param {Number} b amount to scale the matrix's elements by * @returns {mat2} out */ function multiplyScalar(out, a, b) { out[0] = a[0] * b; out[1] = a[1] * b; out[2] = a[2] * b; out[3] = a[3] * b; return out; } /** * Adds two mat2's after multiplying each element of the second operand by a scalar value. * * @param {mat2} out the receiving vector * @param {ReadonlyMat2} a the first operand * @param {ReadonlyMat2} b the second operand * @param {Number} scale the amount to scale b's elements by before adding * @returns {mat2} out */ function multiplyScalarAndAdd(out, a, b, scale) { out[0] = a[0] + b[0] * scale; out[1] = a[1] + b[1] * scale; out[2] = a[2] + b[2] * scale; out[3] = a[3] + b[3] * scale; return out; } /** * Alias for {@link mat2.multiply} * @function */ var mul = multiply; /** * Alias for {@link mat2.subtract} * @function */ var sub = subtract; // CONCATENATED MODULE: ./node_modules/gl-matrix/esm/vec2.js /** * 2 Dimensional Vector * @module vec2 */ /** * Creates a new, empty vec2 * * @returns {vec2} a new 2D vector */ function vec2_create() { var out = new ARRAY_TYPE(2); if (ARRAY_TYPE != Float32Array) { out[0] = 0; out[1] = 0; } return out; } /** * Creates a new vec2 initialized with values from an existing vector * * @param {ReadonlyVec2} a vector to clone * @returns {vec2} a new 2D vector */ function vec2_clone(a) { var out = new ARRAY_TYPE(2); out[0] = a[0]; out[1] = a[1]; return out; } /** * Creates a new vec2 initialized with the given values * * @param {Number} x X component * @param {Number} y Y component * @returns {vec2} a new 2D vector */ function vec2_fromValues(x, y) { var out = new ARRAY_TYPE(2); out[0] = x; out[1] = y; return out; } /** * Copy the values from one vec2 to another * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the source vector * @returns {vec2} out */ function vec2_copy(out, a) { out[0] = a[0]; out[1] = a[1]; return out; } /** * Set the components of a vec2 to the given values * * @param {vec2} out the receiving vector * @param {Number} x X component * @param {Number} y Y component * @returns {vec2} out */ function vec2_set(out, x, y) { out[0] = x; out[1] = y; return out; } /** * Adds two vec2's * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {vec2} out */ function vec2_add(out, a, b) { out[0] = a[0] + b[0]; out[1] = a[1] + b[1]; return out; } /** * Subtracts vector b from vector a * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {vec2} out */ function vec2_subtract(out, a, b) { out[0] = a[0] - b[0]; out[1] = a[1] - b[1]; return out; } /** * Multiplies two vec2's * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {vec2} out */ function vec2_multiply(out, a, b) { out[0] = a[0] * b[0]; out[1] = a[1] * b[1]; return out; } /** * Divides two vec2's * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {vec2} out */ function divide(out, a, b) { out[0] = a[0] / b[0]; out[1] = a[1] / b[1]; return out; } /** * Math.ceil the components of a vec2 * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a vector to ceil * @returns {vec2} out */ function ceil(out, a) { out[0] = Math.ceil(a[0]); out[1] = Math.ceil(a[1]); return out; } /** * Math.floor the components of a vec2 * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a vector to floor * @returns {vec2} out */ function floor(out, a) { out[0] = Math.floor(a[0]); out[1] = Math.floor(a[1]); return out; } /** * Returns the minimum of two vec2's * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {vec2} out */ function min(out, a, b) { out[0] = Math.min(a[0], b[0]); out[1] = Math.min(a[1], b[1]); return out; } /** * Returns the maximum of two vec2's * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {vec2} out */ function vec2_max(out, a, b) { out[0] = Math.max(a[0], b[0]); out[1] = Math.max(a[1], b[1]); return out; } /** * symmetric round the components of a vec2 * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a vector to round * @returns {vec2} out */ function vec2_round(out, a) { out[0] = round(a[0]); out[1] = round(a[1]); return out; } /** * Scales a vec2 by a scalar number * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the vector to scale * @param {Number} b amount to scale the vector by * @returns {vec2} out */ function vec2_scale(out, a, b) { out[0] = a[0] * b; out[1] = a[1] * b; return out; } /** * Adds two vec2's after scaling the second operand by a scalar value * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @param {Number} scale the amount to scale b by before adding * @returns {vec2} out */ function scaleAndAdd(out, a, b, scale) { out[0] = a[0] + b[0] * scale; out[1] = a[1] + b[1] * scale; return out; } /** * Calculates the euclidian distance between two vec2's * * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {Number} distance between a and b */ function distance(a, b) { var x = b[0] - a[0], y = b[1] - a[1]; return Math.sqrt(x * x + y * y); } /** * Calculates the squared euclidian distance between two vec2's * * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {Number} squared distance between a and b */ function squaredDistance(a, b) { var x = b[0] - a[0], y = b[1] - a[1]; return x * x + y * y; } /** * Calculates the length of a vec2 * * @param {ReadonlyVec2} a vector to calculate length of * @returns {Number} length of a */ function vec2_length(a) { var x = a[0], y = a[1]; return Math.sqrt(x * x + y * y); } /** * Calculates the squared length of a vec2 * * @param {ReadonlyVec2} a vector to calculate squared length of * @returns {Number} squared length of a */ function squaredLength(a) { var x = a[0], y = a[1]; return x * x + y * y; } /** * Negates the components of a vec2 * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a vector to negate * @returns {vec2} out */ function negate(out, a) { out[0] = -a[0]; out[1] = -a[1]; return out; } /** * Returns the inverse of the components of a vec2 * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a vector to invert * @returns {vec2} out */ function inverse(out, a) { out[0] = 1.0 / a[0]; out[1] = 1.0 / a[1]; return out; } /** * Normalize a vec2 * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a vector to normalize * @returns {vec2} out */ function normalize(out, a) { var x = a[0], y = a[1]; var len = x * x + y * y; if (len > 0) { //TODO: evaluate use of glm_invsqrt here? len = 1 / Math.sqrt(len); } out[0] = a[0] * len; out[1] = a[1] * len; return out; } /** * Calculates the dot product of two vec2's * * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {Number} dot product of a and b */ function dot(a, b) { return a[0] * b[0] + a[1] * b[1]; } /** * Computes the cross product of two vec2's * Note that the cross product must by definition produce a 3D vector * * @param {vec3} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @returns {vec3} out */ function cross(out, a, b) { var z = a[0] * b[1] - a[1] * b[0]; out[0] = out[1] = 0; out[2] = z; return out; } /** * Performs a linear interpolation between two vec2's * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the first operand * @param {ReadonlyVec2} b the second operand * @param {Number} t interpolation amount, in the range [0-1], between the two inputs * @returns {vec2} out */ function lerp(out, a, b, t) { var ax = a[0], ay = a[1]; out[0] = ax + t * (b[0] - ax); out[1] = ay + t * (b[1] - ay); return out; } /** * Generates a random vector with the given scale * * @param {vec2} out the receiving vector * @param {Number} [scale] Length of the resulting vector. If omitted, a unit vector will be returned * @returns {vec2} out */ function random(out, scale) { scale = scale === undefined ? 1.0 : scale; var r = RANDOM() * 2.0 * Math.PI; out[0] = Math.cos(r) * scale; out[1] = Math.sin(r) * scale; return out; } /** * Transforms the vec2 with a mat2 * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the vector to transform * @param {ReadonlyMat2} m matrix to transform with * @returns {vec2} out */ function transformMat2(out, a, m) { var x = a[0], y = a[1]; out[0] = m[0] * x + m[2] * y; out[1] = m[1] * x + m[3] * y; return out; } /** * Transforms the vec2 with a mat2d * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the vector to transform * @param {ReadonlyMat2d} m matrix to transform with * @returns {vec2} out */ function transformMat2d(out, a, m) { var x = a[0], y = a[1]; out[0] = m[0] * x + m[2] * y + m[4]; out[1] = m[1] * x + m[3] * y + m[5]; return out; } /** * Transforms the vec2 with a mat3 * 3rd vector component is implicitly '1' * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the vector to transform * @param {ReadonlyMat3} m matrix to transform with * @returns {vec2} out */ function transformMat3(out, a, m) { var x = a[0], y = a[1]; out[0] = m[0] * x + m[3] * y + m[6]; out[1] = m[1] * x + m[4] * y + m[7]; return out; } /** * Transforms the vec2 with a mat4 * 3rd vector component is implicitly '0' * 4th vector component is implicitly '1' * * @param {vec2} out the receiving vector * @param {ReadonlyVec2} a the vector to transform * @param {ReadonlyMat4} m matrix to transform with * @returns {vec2} out */ function transformMat4(out, a, m) { var x = a[0]; var y = a[1]; out[0] = m[0] * x + m[4] * y + m[12]; out[1] = m[1] * x + m[5] * y + m[13]; return out; } /** * Rotate a 2D vector * @param {vec2} out The receiving vec2 * @param {ReadonlyVec2} a The vec2 point to rotate * @param {ReadonlyVec2} b The origin of the rotation * @param {Number} rad The angle of rotation in radians * @returns {vec2} out */ function vec2_rotate(out, a, b, rad) { //Translate point to the origin var p0 = a[0] - b[0], p1 = a[1] - b[1], sinC = Math.sin(rad), cosC = Math.cos(rad); //perform rotation and translate to correct position out[0] = p0 * cosC - p1 * sinC + b[0]; out[1] = p0 * sinC + p1 * cosC + b[1]; return out; } /** * Get the smallest angle between two 2D vectors * @param {ReadonlyVec2} a The first operand * @param {ReadonlyVec2} b The second operand * @returns {Number} The angle in radians */ function angle(a, b) { var ax = a[0], ay = a[1], bx = b[0], by = b[1]; return Math.abs(Math.atan2(ay * bx - ax * by, ax * bx + ay * by)); } /** * Get the signed angle in the interval [-pi,pi] between two 2D vectors (positive if `a` is to the right of `b`) * * @param {ReadonlyVec2} a The first vector * @param {ReadonlyVec2} b The second vector * @returns {number} The signed angle in radians */ function signedAngle(a, b) { var ax = a[0], ay = a[1], bx = b[0], by = b[1]; return Math.atan2(ax * by - ay * bx, ax * bx + ay * by); } /** * Set the components of a vec2 to zero * * @param {vec2} out the receiving vector * @returns {vec2} out */ function zero(out) { out[0] = 0.0; out[1] = 0.0; return out; } /** * Returns a string representation of a vector * * @param {ReadonlyVec2} a vector to represent as a string * @returns {String} string representation of the vector */ function vec2_str(a) { return "vec2(" + a[0] + ", " + a[1] + ")"; } /** * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===) * * @param {ReadonlyVec2} a The first vector. * @param {ReadonlyVec2} b The second vector. * @returns {Boolean} True if the vectors are equal, false otherwise. */ function vec2_exactEquals(a, b) { return a[0] === b[0] && a[1] === b[1]; } /** * Returns whether or not the vectors have approximately the same elements in the same position. * * @param {ReadonlyVec2} a The first vector. * @param {ReadonlyVec2} b The second vector. * @returns {Boolean} True if the vectors are equal, false otherwise. */ function vec2_equals(a, b) { var a0 = a[0], a1 = a[1]; var b0 = b[0], b1 = b[1]; return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)); } /** * Alias for {@link vec2.length} * @function */ var len = vec2_length; /** * Alias for {@link vec2.subtract} * @function */ var vec2_sub = vec2_subtract; /** * Alias for {@link vec2.multiply} * @function */ var vec2_mul = vec2_multiply; /** * Alias for {@link vec2.divide} * @function */ var div = divide; /** * Alias for {@link vec2.distance} * @function */ var dist = distance; /** * Alias for {@link vec2.squaredDistance} * @function */ var sqrDist = squaredDistance; /** * Alias for {@link vec2.squaredLength} * @function */ var sqrLen = squaredLength; /** * Perform some operation over an array of vec2s. * * @param {Array} a the array of vectors to iterate over * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed * @param {Number} offset Number of elements to skip at the beginning of the array * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array * @param {Function} fn Function to call for each vector in the array * @param {Object} [arg] additional argument to pass to fn * @returns {Array} a * @function */ var forEach = function () { var vec = vec2_create(); return function (a, stride, offset, count, fn, arg) { var i, l; if (!stride) { stride = 2; } if (!offset) { offset = 0; } if (count) { l = Math.min(count * stride + offset, a.length); } else { l = a.length; } for (i = offset; i < l; i += stride) { vec[0] = a[i]; vec[1] = a[i + 1]; fn(vec, vec, arg); a[i] = vec[0]; a[i + 1] = vec[1]; } return a; }; }(); // CONCATENATED MODULE: ./node_modules/gl-matrix/esm/vec3.js /** * 3 Dimensional Vector * @module vec3 */ /** * Creates a new, empty vec3 * * @returns {vec3} a new 3D vector */ function vec3_create() { var out = new ARRAY_TYPE(3); if (ARRAY_TYPE != Float32Array) { out[0] = 0; out[1] = 0; out[2] = 0; } return out; } /** * Creates a new vec3 initialized with values from an existing vector * * @param {ReadonlyVec3} a vector to clone * @returns {vec3} a new 3D vector */ function vec3_clone(a) { var out = new ARRAY_TYPE(3); out[0] = a[0]; out[1] = a[1]; out[2] = a[2]; return out; } /** * Calculates the length of a vec3 * * @param {ReadonlyVec3} a vector to calculate length of * @returns {Number} length of a */ function vec3_length(a) { var x = a[0]; var y = a[1]; var z = a[2]; return Math.sqrt(x * x + y * y + z * z); } /** * Creates a new vec3 initialized with the given values * * @param {Number} x X component * @param {Number} y Y component * @param {Number} z Z component * @returns {vec3} a new 3D vector */ function vec3_fromValues(x, y, z) { var out = new ARRAY_TYPE(3); out[0] = x; out[1] = y; out[2] = z; return out; } /** * Copy the values from one vec3 to another * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the source vector * @returns {vec3} out */ function vec3_copy(out, a) { out[0] = a[0]; out[1] = a[1]; out[2] = a[2]; return out; } /** * Set the components of a vec3 to the given values * * @param {vec3} out the receiving vector * @param {Number} x X component * @param {Number} y Y component * @param {Number} z Z component * @returns {vec3} out */ function vec3_set(out, x, y, z) { out[0] = x; out[1] = y; out[2] = z; return out; } /** * Adds two vec3's * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {vec3} out */ function vec3_add(out, a, b) { out[0] = a[0] + b[0]; out[1] = a[1] + b[1]; out[2] = a[2] + b[2]; return out; } /** * Subtracts vector b from vector a * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {vec3} out */ function vec3_subtract(out, a, b) { out[0] = a[0] - b[0]; out[1] = a[1] - b[1]; out[2] = a[2] - b[2]; return out; } /** * Multiplies two vec3's * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {vec3} out */ function vec3_multiply(out, a, b) { out[0] = a[0] * b[0]; out[1] = a[1] * b[1]; out[2] = a[2] * b[2]; return out; } /** * Divides two vec3's * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {vec3} out */ function vec3_divide(out, a, b) { out[0] = a[0] / b[0]; out[1] = a[1] / b[1]; out[2] = a[2] / b[2]; return out; } /** * Math.ceil the components of a vec3 * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a vector to ceil * @returns {vec3} out */ function vec3_ceil(out, a) { out[0] = Math.ceil(a[0]); out[1] = Math.ceil(a[1]); out[2] = Math.ceil(a[2]); return out; } /** * Math.floor the components of a vec3 * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a vector to floor * @returns {vec3} out */ function vec3_floor(out, a) { out[0] = Math.floor(a[0]); out[1] = Math.floor(a[1]); out[2] = Math.floor(a[2]); return out; } /** * Returns the minimum of two vec3's * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {vec3} out */ function vec3_min(out, a, b) { out[0] = Math.min(a[0], b[0]); out[1] = Math.min(a[1], b[1]); out[2] = Math.min(a[2], b[2]); return out; } /** * Returns the maximum of two vec3's * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {vec3} out */ function vec3_max(out, a, b) { out[0] = Math.max(a[0], b[0]); out[1] = Math.max(a[1], b[1]); out[2] = Math.max(a[2], b[2]); return out; } /** * symmetric round the components of a vec3 * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a vector to round * @returns {vec3} out */ function vec3_round(out, a) { out[0] = round(a[0]); out[1] = round(a[1]); out[2] = round(a[2]); return out; } /** * Scales a vec3 by a scalar number * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the vector to scale * @param {Number} b amount to scale the vector by * @returns {vec3} out */ function vec3_scale(out, a, b) { out[0] = a[0] * b; out[1] = a[1] * b; out[2] = a[2] * b; return out; } /** * Adds two vec3's after scaling the second operand by a scalar value * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @param {Number} scale the amount to scale b by before adding * @returns {vec3} out */ function vec3_scaleAndAdd(out, a, b, scale) { out[0] = a[0] + b[0] * scale; out[1] = a[1] + b[1] * scale; out[2] = a[2] + b[2] * scale; return out; } /** * Calculates the euclidian distance between two vec3's * * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {Number} distance between a and b */ function vec3_distance(a, b) { var x = b[0] - a[0]; var y = b[1] - a[1]; var z = b[2] - a[2]; return Math.sqrt(x * x + y * y + z * z); } /** * Calculates the squared euclidian distance between two vec3's * * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {Number} squared distance between a and b */ function vec3_squaredDistance(a, b) { var x = b[0] - a[0]; var y = b[1] - a[1]; var z = b[2] - a[2]; return x * x + y * y + z * z; } /** * Calculates the squared length of a vec3 * * @param {ReadonlyVec3} a vector to calculate squared length of * @returns {Number} squared length of a */ function vec3_squaredLength(a) { var x = a[0]; var y = a[1]; var z = a[2]; return x * x + y * y + z * z; } /** * Negates the components of a vec3 * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a vector to negate * @returns {vec3} out */ function vec3_negate(out, a) { out[0] = -a[0]; out[1] = -a[1]; out[2] = -a[2]; return out; } /** * Returns the inverse of the components of a vec3 * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a vector to invert * @returns {vec3} out */ function vec3_inverse(out, a) { out[0] = 1.0 / a[0]; out[1] = 1.0 / a[1]; out[2] = 1.0 / a[2]; return out; } /** * Normalize a vec3 * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a vector to normalize * @returns {vec3} out */ function vec3_normalize(out, a) { var x = a[0]; var y = a[1]; var z = a[2]; var len = x * x + y * y + z * z; if (len > 0) { //TODO: evaluate use of glm_invsqrt here? len = 1 / Math.sqrt(len); } out[0] = a[0] * len; out[1] = a[1] * len; out[2] = a[2] * len; return out; } /** * Calculates the dot product of two vec3's * * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {Number} dot product of a and b */ function vec3_dot(a, b) { return a[0] * b[0] + a[1] * b[1] + a[2] * b[2]; } /** * Computes the cross product of two vec3's * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @returns {vec3} out */ function vec3_cross(out, a, b) { var ax = a[0], ay = a[1], az = a[2]; var bx = b[0], by = b[1], bz = b[2]; out[0] = ay * bz - az * by; out[1] = az * bx - ax * bz; out[2] = ax * by - ay * bx; return out; } /** * Performs a linear interpolation between two vec3's * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @param {Number} t interpolation amount, in the range [0-1], between the two inputs * @returns {vec3} out */ function vec3_lerp(out, a, b, t) { var ax = a[0]; var ay = a[1]; var az = a[2]; out[0] = ax + t * (b[0] - ax); out[1] = ay + t * (b[1] - ay); out[2] = az + t * (b[2] - az); return out; } /** * Performs a spherical linear interpolation between two vec3's * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @param {Number} t interpolation amount, in the range [0-1], between the two inputs * @returns {vec3} out */ function slerp(out, a, b, t) { var angle = Math.acos(Math.min(Math.max(vec3_dot(a, b), -1), 1)); var sinTotal = Math.sin(angle); var ratioA = Math.sin((1 - t) * angle) / sinTotal; var ratioB = Math.sin(t * angle) / sinTotal; out[0] = ratioA * a[0] + ratioB * b[0]; out[1] = ratioA * a[1] + ratioB * b[1]; out[2] = ratioA * a[2] + ratioB * b[2]; return out; } /** * Performs a hermite interpolation with two control points * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @param {ReadonlyVec3} c the third operand * @param {ReadonlyVec3} d the fourth operand * @param {Number} t interpolation amount, in the range [0-1], between the two inputs * @returns {vec3} out */ function hermite(out, a, b, c, d, t) { var factorTimes2 = t * t; var factor1 = factorTimes2 * (2 * t - 3) + 1; var factor2 = factorTimes2 * (t - 2) + t; var factor3 = factorTimes2 * (t - 1); var factor4 = factorTimes2 * (3 - 2 * t); out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4; out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4; out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4; return out; } /** * Performs a bezier interpolation with two control points * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the first operand * @param {ReadonlyVec3} b the second operand * @param {ReadonlyVec3} c the third operand * @param {ReadonlyVec3} d the fourth operand * @param {Number} t interpolation amount, in the range [0-1], between the two inputs * @returns {vec3} out */ function bezier(out, a, b, c, d, t) { var inverseFactor = 1 - t; var inverseFactorTimesTwo = inverseFactor * inverseFactor; var factorTimes2 = t * t; var factor1 = inverseFactorTimesTwo * inverseFactor; var factor2 = 3 * t * inverseFactorTimesTwo; var factor3 = 3 * factorTimes2 * inverseFactor; var factor4 = factorTimes2 * t; out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4; out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4; out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4; return out; } /** * Generates a random vector with the given scale * * @param {vec3} out the receiving vector * @param {Number} [scale] Length of the resulting vector. If omitted, a unit vector will be returned * @returns {vec3} out */ function vec3_random(out, scale) { scale = scale === undefined ? 1.0 : scale; var r = RANDOM() * 2.0 * Math.PI; var z = RANDOM() * 2.0 - 1.0; var zScale = Math.sqrt(1.0 - z * z) * scale; out[0] = Math.cos(r) * zScale; out[1] = Math.sin(r) * zScale; out[2] = z * scale; return out; } /** * Transforms the vec3 with a mat4. * 4th vector component is implicitly '1' * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the vector to transform * @param {ReadonlyMat4} m matrix to transform with * @returns {vec3} out */ function vec3_transformMat4(out, a, m) { var x = a[0], y = a[1], z = a[2]; var w = m[3] * x + m[7] * y + m[11] * z + m[15]; w = w || 1.0; out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w; out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w; out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w; return out; } /** * Transforms the vec3 with a mat3. * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the vector to transform * @param {ReadonlyMat3} m the 3x3 matrix to transform with * @returns {vec3} out */ function vec3_transformMat3(out, a, m) { var x = a[0], y = a[1], z = a[2]; out[0] = x * m[0] + y * m[3] + z * m[6]; out[1] = x * m[1] + y * m[4] + z * m[7]; out[2] = x * m[2] + y * m[5] + z * m[8]; return out; } /** * Transforms the vec3 with a quat * Can also be used for dual quaternions. (Multiply it with the real part) * * @param {vec3} out the receiving vector * @param {ReadonlyVec3} a the vector to transform * @param {ReadonlyQuat} q normalized quaternion to transform with * @returns {vec3} out */ function transformQuat(out, a, q) { // Fast Vector Rotation using Quaternions by Robert Eisele // https://raw.org/proof/vector-rotation-using-quaternions/ var qx = q[0], qy = q[1], qz = q[2], qw = q[3]; var vx = a[0], vy = a[1], vz = a[2]; // t = q x v var tx = qy * vz - qz * vy; var ty = qz * vx - qx * vz; var tz = qx * vy - qy * vx; // t = 2t tx = tx + tx; ty = ty + ty; tz = tz + tz; // v + w t + q x t out[0] = vx + qw * tx + qy * tz - qz * ty; out[1] = vy + qw * ty + qz * tx - qx * tz; out[2] = vz + qw * tz + qx * ty - qy * tx; return out; } /** * Rotate a 3D vector around the x-axis * @param {vec3} out The receiving vec3 * @param {ReadonlyVec3} a The vec3 point to rotate * @param {ReadonlyVec3} b The origin of the rotation * @param {Number} rad The angle of rotation in radians * @returns {vec3} out */ function rotateX(out, a, b, rad) { var p = [], r = []; //Translate point to the origin p[0] = a[0] - b[0]; p[1] = a[1] - b[1]; p[2] = a[2] - b[2]; //perform rotation r[0] = p[0]; r[1] = p[1] * Math.cos(rad) - p[2] * Math.sin(rad); r[2] = p[1] * Math.sin(rad) + p[2] * Math.cos(rad); //translate to correct position out[0] = r[0] + b[0]; out[1] = r[1] + b[1]; out[2] = r[2] + b[2]; return out; } /** * Rotate a 3D vector around the y-axis * @param {vec3} out The receiving vec3 * @param {ReadonlyVec3} a The vec3 point to rotate * @param {ReadonlyVec3} b The origin of the rotation * @param {Number} rad The angle of rotation in radians * @returns {vec3} out */ function rotateY(out, a, b, rad) { var p = [], r = []; //Translate point to the origin p[0] = a[0] - b[0]; p[1] = a[1] - b[1]; p[2] = a[2] - b[2]; //perform rotation r[0] = p[2] * Math.sin(rad) + p[0] * Math.cos(rad); r[1] = p[1]; r[2] = p[2] * Math.cos(rad) - p[0] * Math.sin(rad); //translate to correct position out[0] = r[0] + b[0]; out[1] = r[1] + b[1]; out[2] = r[2] + b[2]; return out; } /** * Rotate a 3D vector around the z-axis * @param {vec3} out The receiving vec3 * @param {ReadonlyVec3} a The vec3 point to rotate * @param {ReadonlyVec3} b The origin of the rotation * @param {Number} rad The angle of rotation in radians * @returns {vec3} out */ function rotateZ(out, a, b, rad) { var p = [], r = []; //Translate point to the origin p[0] = a[0] - b[0]; p[1] = a[1] - b[1]; p[2] = a[2] - b[2]; //perform rotation r[0] = p[0] * Math.cos(rad) - p[1] * Math.sin(rad); r[1] = p[0] * Math.sin(rad) + p[1] * Math.cos(rad); r[2] = p[2]; //translate to correct position out[0] = r[0] + b[0]; out[1] = r[1] + b[1]; out[2] = r[2] + b[2]; return out; } /** * Get the angle between two 3D vectors * @param {ReadonlyVec3} a The first operand * @param {ReadonlyVec3} b The second operand * @returns {Number} The angle in radians */ function vec3_angle(a, b) { var ax = a[0], ay = a[1], az = a[2], bx = b[0], by = b[1], bz = b[2], mag = Math.sqrt((ax * ax + ay * ay + az * az) * (bx * bx + by * by + bz * bz)), cosine = mag && vec3_dot(a, b) / mag; return Math.acos(Math.min(Math.max(cosine, -1), 1)); } /** * Set the components of a vec3 to zero * * @param {vec3} out the receiving vector * @returns {vec3} out */ function vec3_zero(out) { out[0] = 0.0; out[1] = 0.0; out[2] = 0.0; return out; } /** * Returns a string representation of a vector * * @param {ReadonlyVec3} a vector to represent as a string * @returns {String} string representation of the vector */ function vec3_str(a) { return "vec3(" + a[0] + ", " + a[1] + ", " + a[2] + ")"; } /** * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===) * * @param {ReadonlyVec3} a The first vector. * @param {ReadonlyVec3} b The second vector. * @returns {Boolean} True if the vectors are equal, false otherwise. */ function vec3_exactEquals(a, b) { return a[0] === b[0] && a[1] === b[1] && a[2] === b[2]; } /** * Returns whether or not the vectors have approximately the same elements in the same position. * * @param {ReadonlyVec3} a The first vector. * @param {ReadonlyVec3} b The second vector. * @returns {Boolean} True if the vectors are equal, false otherwise. */ function vec3_equals(a, b) { var a0 = a[0], a1 = a[1], a2 = a[2]; var b0 = b[0], b1 = b[1], b2 = b[2]; return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)); } /** * Alias for {@link vec3.subtract} * @function */ var vec3_sub = vec3_subtract; /** * Alias for {@link vec3.multiply} * @function */ var vec3_mul = vec3_multiply; /** * Alias for {@link vec3.divide} * @function */ var vec3_div = vec3_divide; /** * Alias for {@link vec3.distance} * @function */ var vec3_dist = vec3_distance; /** * Alias for {@link vec3.squaredDistance} * @function */ var vec3_sqrDist = vec3_squaredDistance; /** * Alias for {@link vec3.length} * @function */ var vec3_len = vec3_length; /** * Alias for {@link vec3.squaredLength} * @function */ var vec3_sqrLen = vec3_squaredLength; /** * Perform some operation over an array of vec3s. * * @param {Array} a the array of vectors to iterate over * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed * @param {Number} offset Number of elements to skip at the beginning of the array * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array * @param {Function} fn Function to call for each vector in the array * @param {Object} [arg] additional argument to pass to fn * @returns {Array} a * @function */ var vec3_forEach = function () { var vec = vec3_create(); return function (a, stride, offset, count, fn, arg) { var i, l; if (!stride) { stride = 3; } if (!offset) { offset = 0; } if (count) { l = Math.min(count * stride + offset, a.length); } else { l = a.length; } for (i = offset; i < l; i += stride) { vec[0] = a[i]; vec[1] = a[i + 1]; vec[2] = a[i + 2]; fn(vec, vec, arg); a[i] = vec[0]; a[i + 1] = vec[1]; a[i + 2] = vec[2]; } return a; }; }(); // CONCATENATED MODULE: ./node_modules/gl-matrix/esm/index.js // CONCATENATED MODULE: ./src/common/array_helper.ts /* eslint-disable no-param-reassign */ /* harmony default export */ var array_helper = ({ init: function init(arr, val) { arr.fill(val); }, /** * IN-PLACE Shuffles the content of an array */ shuffle: function shuffle(arr) { // Durstenfeld shuffle algorithm // https://stackoverflow.com/questions/2450954/how-to-randomize-shuffle-a-javascript-array for (var i = arr.length - 1; i > 0; i--) { var j = Math.floor(Math.random() * (i + 1)); var _ref = [arr[j], arr[i]]; arr[i] = _ref[0]; arr[j] = _ref[1]; } return arr; }, toPointList: function toPointList(arr) { var rows = arr.reduce(function (p, n) { var row = "[".concat(n.join(','), "]"); p.push(row); return p; }, []); return "[".concat(rows.join(',\r\n'), "]"); }, /** * returns the elements which's score is bigger than the threshold */ // eslint-disable-next-line no-unused-vars threshold: function threshold(arr, _threshold, scoreFunc) { var queue = arr.reduce(function (prev, next) { if (scoreFunc.apply(arr, [next]) >= _threshold) { prev.push(next); } return prev; }, []); return queue; }, maxIndex: function maxIndex(arr) { var max = 0; for (var i = 0; i < arr.length; i++) { if (arr[i] > arr[max]) { max = i; } } return max; }, max: function max(arr) { var max = 0; for (var i = 0; i < arr.length; i++) { if (arr[i] > max) { max = arr[i]; } } return max; }, sum: function sum(arr) { var length = arr.length; var sum = 0; while (length--) { sum += arr[length]; } return sum; } }); // CONCATENATED MODULE: ./src/common/cluster.js // TODO: cluster.js and cv_utils.js are pretty tightly intertwined, making for a complex conversion // into typescript. be warned. :-) /** * Creates a cluster for grouping similar orientations of datapoints */ /* harmony default export */ var cluster = ({ create: function create(point, threshold) { var points = []; var center = { rad: 0, vec: vec2_namespaceObject.clone([0, 0]) }; var pointMap = {}; function _add(pointToAdd) { pointMap[pointToAdd.id] = pointToAdd; points.push(pointToAdd); } function updateCenter() { var i; var sum = 0; for (i = 0; i < points.length; i++) { sum += points[i].rad; } center.rad = sum / points.length; center.vec = vec2_namespaceObject.clone([Math.cos(center.rad), Math.sin(center.rad)]); } function init() { _add(point); updateCenter(); } init(); return { add: function add(pointToAdd) { if (!pointMap[pointToAdd.id]) { _add(pointToAdd); updateCenter(); } }, fits: function fits(otherPoint) { // check cosine similarity to center-angle var similarity = Math.abs(vec2_namespaceObject.dot(otherPoint.point.vec, center.vec)); if (similarity > threshold) { return true; } return false; }, getPoints: function getPoints() { return points; }, getCenter: function getCenter() { return center; } }; }, createPoint: function createPoint(newPoint, id, property) { return { rad: newPoint[property], point: newPoint, id: id }; } }); // CONCATENATED MODULE: ./src/common/cv_utils.js /* eslint-disable no-mixed-operators */ /* eslint-disable no-bitwise */ /** * @param x x-coordinate * @param y y-coordinate * @return ImageReference {x,y} Coordinate */ function imageRef(x, y) { var that = { x: x, y: y, toVec2: function toVec2() { return vec2_namespaceObject.clone([this.x, this.y]); }, toVec3: function toVec3() { return vec3_namespaceObject.clone([this.x, this.y, 1]); }, round: function round() { this.x = this.x > 0.0 ? Math.floor(this.x + 0.5) : Math.floor(this.x - 0.5); this.y = this.y > 0.0 ? Math.floor(this.y + 0.5) : Math.floor(this.y - 0.5); return this; } }; return that; } /** * Computes an integral image of a given grayscale image. * @param imageDataContainer {ImageDataContainer} the image to be integrated */ function computeIntegralImage2(imageWrapper, integralWrapper) { var imageData = imageWrapper.data; var width = imageWrapper.size.x; var height = imageWrapper.size.y; var integralImageData = integralWrapper.data; var sum = 0; var posA = 0; var posB = 0; var posC = 0; var posD = 0; var x; var y; // sum up first column posB = width; sum = 0; for (y = 1; y < height; y++) { sum += imageData[posA]; integralImageData[posB] += sum; posA += width; posB += width; } posA = 0; posB = 1; sum = 0; for (x = 1; x < width; x++) { sum += imageData[posA]; integralImageData[posB] += sum; posA++; posB++; } for (y = 1; y < height; y++) { posA = y * width + 1; posB = (y - 1) * width + 1; posC = y * width; posD = (y - 1) * width; for (x = 1; x < width; x++) { integralImageData[posA] += imageData[posA] + integralImageData[posB] + integralImageData[posC] - integralImageData[posD]; posA++; posB++; posC++; posD++; } } } function computeIntegralImage(imageWrapper, integralWrapper) { var imageData = imageWrapper.data; var width = imageWrapper.size.x; var height = imageWrapper.size.y; var integralImageData = integralWrapper.data; var sum = 0; // sum up first row for (var i = 0; i < width; i++) { sum += imageData[i]; integralImageData[i] = sum; } for (var v = 1; v < height; v++) { sum = 0; for (var u = 0; u < width; u++) { sum += imageData[v * width + u]; integralImageData[v * width + u] = sum + integralImageData[(v - 1) * width + u]; } } } function thresholdImage(imageWrapper, threshold, targetWrapper) { if (!targetWrapper) { // eslint-disable-next-line no-param-reassign targetWrapper = imageWrapper; } var imageData = imageWrapper.data; var length = imageData.length; var targetData = targetWrapper.data; while (length--) { targetData[length] = imageData[length] < threshold ? 1 : 0; } } function computeHistogram(imageWrapper, bitsPerPixel) { if (!bitsPerPixel) { // eslint-disable-next-line no-param-reassign bitsPerPixel = 8; } var imageData = imageWrapper.data; var length = imageData.length; var bitShift = 8 - bitsPerPixel; var bucketCnt = 1 << bitsPerPixel; var hist = new Int32Array(bucketCnt); while (length--) { hist[imageData[length] >> bitShift]++; } return hist; } function sharpenLine(line) { var i; var length = line.length; var left = line[0]; var center = line[1]; var right; for (i = 1; i < length - 1; i++) { right = line[i + 1]; // -1 4 -1 kernel // eslint-disable-next-line no-param-reassign line[i - 1] = center * 2 - left - right & 255; left = center; center = right; } return line; } function determineOtsuThreshold(imageWrapper) { var bitsPerPixel = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 8; var hist; var bitShift = 8 - bitsPerPixel; function px(init, end) { var sum = 0; for (var i = init; i <= end; i++) { sum += hist[i]; } return sum; } function mx(init, end) { var sum = 0; for (var i = init; i <= end; i++) { sum += i * hist[i]; } return sum; } function determineThreshold() { var vet = [0]; var p1; var p2; var p12; var m1; var m2; var m12; var max = (1 << bitsPerPixel) - 1; hist = computeHistogram(imageWrapper, bitsPerPixel); for (var k = 1; k < max; k++) { p1 = px(0, k); p2 = px(k + 1, max); p12 = p1 * p2; if (p12 === 0) { p12 = 1; } m1 = mx(0, k) * p2; m2 = mx(k + 1, max) * p1; m12 = m1 - m2; vet[k] = m12 * m12 / p12; } return array_helper.maxIndex(vet); } var threshold = determineThreshold(); return threshold << bitShift; } function otsuThreshold(imageWrapper, targetWrapper) { var threshold = determineOtsuThreshold(imageWrapper); thresholdImage(imageWrapper, threshold, targetWrapper); return threshold; } // local thresholding function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) { computeIntegralImage(imageWrapper, integralWrapper); if (!targetWrapper) { // eslint-disable-next-line no-param-reassign targetWrapper = imageWrapper; } var imageData = imageWrapper.data; var targetData = targetWrapper.data; var width = imageWrapper.size.x; var height = imageWrapper.size.y; var integralImageData = integralWrapper.data; var sum = 0; var v; var u; var kernel = 3; var A; var B; var C; var D; var avg; var size = (kernel * 2 + 1) * (kernel * 2 + 1); // clear out top & bottom-border for (v = 0; v <= kernel; v++) { for (u = 0; u < width; u++) { targetData[v * width + u] = 0; targetData[(height - 1 - v) * width + u] = 0; } } // clear out left & right border for (v = kernel; v < height - kernel; v++) { for (u = 0; u <= kernel; u++) { targetData[v * width + u] = 0; targetData[v * width + (width - 1 - u)] = 0; } } for (v = kernel + 1; v < height - kernel - 1; v++) { for (u = kernel + 1; u < width - kernel; u++) { A = integralImageData[(v - kernel - 1) * width + (u - kernel - 1)]; B = integralImageData[(v - kernel - 1) * width + (u + kernel)]; C = integralImageData[(v + kernel) * width + (u - kernel - 1)]; D = integralImageData[(v + kernel) * width + (u + kernel)]; sum = D - C - B + A; avg = sum / size; targetData[v * width + u] = imageData[v * width + u] > avg + 5 ? 0 : 1; } } } function cv_utils_cluster(points, threshold, property) { var i; var k; var thisCluster; var point; var clusters = []; if (!property) { // eslint-disable-next-line no-param-reassign property = 'rad'; } function addToCluster(newPoint) { var found = false; for (k = 0; k < clusters.length; k++) { thisCluster = clusters[k]; if (thisCluster.fits(newPoint)) { thisCluster.add(newPoint); found = true; } } return found; } // iterate over each cloud for (i = 0; i < points.length; i++) { point = cluster.createPoint(points[i], i, property); if (!addToCluster(point)) { clusters.push(cluster.create(point, threshold)); } } return clusters; } var Tracer = { trace: function trace(points, vec) { var iteration; var maxIterations = 10; var top = []; var result = []; var centerPos = 0; var currentPos = 0; function trace(idx, forward) { var to; var toIdx; var predictedPos; var thresholdX = 1; var thresholdY = Math.abs(vec[1] / 10); var found = false; function match(pos, predicted) { if (pos.x > predicted.x - thresholdX && pos.x < predicted.x + thresholdX && pos.y > predicted.y - thresholdY && pos.y < predicted.y + thresholdY) { return true; } return false; } // check if the next index is within the vec specifications // if not, check as long as the threshold is met var from = points[idx]; if (forward) { predictedPos = { x: from.x + vec[0], y: from.y + vec[1] }; } else { predictedPos = { x: from.x - vec[0], y: from.y - vec[1] }; } toIdx = forward ? idx + 1 : idx - 1; to = points[toIdx]; // eslint-disable-next-line no-cond-assign while (to && (found = match(to, predictedPos)) !== true && Math.abs(to.y - from.y) < vec[1]) { toIdx = forward ? toIdx + 1 : toIdx - 1; to = points[toIdx]; } return found ? toIdx : null; } for (iteration = 0; iteration < maxIterations; iteration++) { // randomly select point to start with centerPos = Math.floor(Math.random() * points.length); // trace forward top = []; currentPos = centerPos; top.push(points[currentPos]); // eslint-disable-next-line no-cond-assign while ((currentPos = trace(currentPos, true)) !== null) { top.push(points[currentPos]); } if (centerPos > 0) { currentPos = centerPos; // eslint-disable-next-line no-cond-assign while ((currentPos = trace(currentPos, false)) !== null) { top.push(points[currentPos]); } } if (top.length > result.length) { result = top; } } return result; } }; var DILATE = 1; var ERODE = 2; function dilate(inImageWrapper, outImageWrapper) { var v; var u; var inImageData = inImageWrapper.data; var outImageData = outImageWrapper.data; var height = inImageWrapper.size.y; var width = inImageWrapper.size.x; var sum; var yStart1; var yStart2; var xStart1; var xStart2; for (v = 1; v < height - 1; v++) { for (u = 1; u < width - 1; u++) { yStart1 = v - 1; yStart2 = v + 1; xStart1 = u - 1; xStart2 = u + 1; sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] + inImageData[v * width + u] + inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2]; outImageData[v * width + u] = sum > 0 ? 1 : 0; } } } function erode(inImageWrapper, outImageWrapper) { var v; var u; var inImageData = inImageWrapper.data; var outImageData = outImageWrapper.data; var height = inImageWrapper.size.y; var width = inImageWrapper.size.x; var sum; var yStart1; var yStart2; var xStart1; var xStart2; for (v = 1; v < height - 1; v++) { for (u = 1; u < width - 1; u++) { yStart1 = v - 1; yStart2 = v + 1; xStart1 = u - 1; xStart2 = u + 1; sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] + inImageData[v * width + u] + inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2]; outImageData[v * width + u] = sum === 5 ? 1 : 0; } } } function cv_utils_subtract(aImageWrapper, bImageWrapper, resultImageWrapper) { if (!resultImageWrapper) { // eslint-disable-next-line no-param-reassign resultImageWrapper = aImageWrapper; } var length = aImageWrapper.data.length; var aImageData = aImageWrapper.data; var bImageData = bImageWrapper.data; var cImageData = resultImageWrapper.data; while (length--) { cImageData[length] = aImageData[length] - bImageData[length]; } } function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) { if (!resultImageWrapper) { // eslint-disable-next-line no-param-reassign resultImageWrapper = aImageWrapper; } var length = aImageWrapper.data.length; var aImageData = aImageWrapper.data; var bImageData = bImageWrapper.data; var cImageData = resultImageWrapper.data; while (length--) { cImageData[length] = aImageData[length] || bImageData[length]; } } function countNonZero(imageWrapper) { var length = imageWrapper.data.length; var data = imageWrapper.data; var sum = 0; while (length--) { sum += data[length]; } return sum; } function topGeneric(list, top, scoreFunc) { var i; var minIdx = 0; var min = 0; var queue = []; var score; var hit; var pos; for (i = 0; i < top; i++) { queue[i] = { score: 0, item: null }; } for (i = 0; i < list.length; i++) { score = scoreFunc.apply(this, [list[i]]); if (score > min) { hit = queue[minIdx]; hit.score = score; hit.item = list[i]; min = Number.MAX_VALUE; for (pos = 0; pos < top; pos++) { if (queue[pos].score < min) { min = queue[pos].score; minIdx = pos; } } } } return queue; } function grayArrayFromImage(htmlImage, offsetX, ctx, array) { ctx.drawImage(htmlImage, offsetX, 0, htmlImage.width, htmlImage.height); var ctxData = ctx.getImageData(offsetX, 0, htmlImage.width, htmlImage.height).data; computeGray(ctxData, array); } function grayArrayFromContext(ctx, size, offset, array) { var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data; computeGray(ctxData, array); } function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) { var topRowIdx = 0; var bottomRowIdx = size.x; var endIdx = Math.floor(canvasData.length / 4); var outWidth = size.x / 2; var outImgIdx = 0; var inWidth = size.x; var i; while (bottomRowIdx < endIdx) { for (i = 0; i < outWidth; i++) { // eslint-disable-next-line no-param-reassign outArray[outImgIdx] = (0.299 * canvasData[topRowIdx * 4 + 0] + 0.587 * canvasData[topRowIdx * 4 + 1] + 0.114 * canvasData[topRowIdx * 4 + 2] + (0.299 * canvasData[(topRowIdx + 1) * 4 + 0] + 0.587 * canvasData[(topRowIdx + 1) * 4 + 1] + 0.114 * canvasData[(topRowIdx + 1) * 4 + 2]) + (0.299 * canvasData[bottomRowIdx * 4 + 0] + 0.587 * canvasData[bottomRowIdx * 4 + 1] + 0.114 * canvasData[bottomRowIdx * 4 + 2]) + (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] + 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] + 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4; outImgIdx++; topRowIdx += 2; bottomRowIdx += 2; } topRowIdx += inWidth; bottomRowIdx += inWidth; } } function computeGray(imageData, outArray, config) { var l = imageData.length / 4 | 0; var singleChannel = config && config.singleChannel === true; if (singleChannel) { for (var i = 0; i < l; i++) { // eslint-disable-next-line no-param-reassign outArray[i] = imageData[i * 4 + 0]; } } else { for (var _i = 0; _i < l; _i++) { // eslint-disable-next-line no-param-reassign outArray[_i] = 0.299 * imageData[_i * 4 + 0] + 0.587 * imageData[_i * 4 + 1] + 0.114 * imageData[_i * 4 + 2]; } } } function loadImageArray(src, callback) { var canvas = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : document && document.createElement('canvas'); var img = new Image(); img.callback = callback; img.onload = function () { // eslint-disable-next-line no-param-reassign canvas.width = this.width; // eslint-disable-next-line no-param-reassign canvas.height = this.height; console.warn('* loadImageArray getContext 2d'); var ctx = canvas.getContext('2d'); ctx.drawImage(this, 0, 0); var array = new Uint8Array(this.width * this.height); ctx.drawImage(this, 0, 0); var _ctx$getImageData = ctx.getImageData(0, 0, this.width, this.height), data = _ctx$getImageData.data; computeGray(data, array); this.callback(array, { x: this.width, y: this.height }, this); }; img.src = src; } /** * @param inImg {ImageWrapper} input image to be sampled * @param outImg {ImageWrapper} to be stored in */ function halfSample(inImgWrapper, outImgWrapper) { var inImg = inImgWrapper.data; var inWidth = inImgWrapper.size.x; var outImg = outImgWrapper.data; var topRowIdx = 0; var bottomRowIdx = inWidth; var endIdx = inImg.length; var outWidth = inWidth / 2; var outImgIdx = 0; while (bottomRowIdx < endIdx) { for (var i = 0; i < outWidth; i++) { outImg[outImgIdx] = Math.floor((inImg[topRowIdx] + inImg[topRowIdx + 1] + inImg[bottomRowIdx] + inImg[bottomRowIdx + 1]) / 4); outImgIdx++; topRowIdx += 2; bottomRowIdx += 2; } topRowIdx += inWidth; bottomRowIdx += inWidth; } } function hsv2rgb(hsv) { var rgb = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [0, 0, 0]; var h = hsv[0]; var s = hsv[1]; var v = hsv[2]; var c = v * s; var x = c * (1 - Math.abs(h / 60 % 2 - 1)); var m = v - c; var r = 0; var g = 0; var b = 0; if (h < 60) { r = c; g = x; } else if (h < 120) { r = x; g = c; } else if (h < 180) { g = c; b = x; } else if (h < 240) { g = x; b = c; } else if (h < 300) { r = x; b = c; } else if (h < 360) { r = c; b = x; } // eslint-disable-next-line no-param-reassign rgb[0] = (r + m) * 255 | 0; // eslint-disable-next-line no-param-reassign rgb[1] = (g + m) * 255 | 0; // eslint-disable-next-line no-param-reassign rgb[2] = (b + m) * 255 | 0; return rgb; } function _computeDivisors(n) { var largeDivisors = []; var divisors = []; for (var i = 1; i < Math.sqrt(n) + 1; i++) { if (n % i === 0) { divisors.push(i); if (i !== n / i) { largeDivisors.unshift(Math.floor(n / i)); } } } return divisors.concat(largeDivisors); } function _computeIntersection(arr1, arr2) { var i = 0; var j = 0; var result = []; while (i < arr1.length && j < arr2.length) { if (arr1[i] === arr2[j]) { result.push(arr1[i]); i++; j++; } else if (arr1[i] > arr2[j]) { j++; } else { i++; } } return result; } function calculatePatchSize(patchSize, imgSize) { var divisorsX = _computeDivisors(imgSize.x); var divisorsY = _computeDivisors(imgSize.y); var wideSide = Math.max(imgSize.x, imgSize.y); var common = _computeIntersection(divisorsX, divisorsY); var nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80]; var nrOfPatchesMap = { 'x-small': 5, small: 4, medium: 3, large: 2, 'x-large': 1 }; var nrOfPatchesIdx = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium; var nrOfPatches = nrOfPatchesList[nrOfPatchesIdx]; var desiredPatchSize = Math.floor(wideSide / nrOfPatches); var optimalPatchSize; function findPatchSizeForDivisors(divisors) { var i = 0; var found = divisors[Math.floor(divisors.length / 2)]; while (i < divisors.length - 1 && divisors[i] < desiredPatchSize) { i++; } if (i > 0) { if (Math.abs(divisors[i] - desiredPatchSize) > Math.abs(divisors[i - 1] - desiredPatchSize)) { found = divisors[i - 1]; } else { found = divisors[i]; } } if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIdx + 1] / nrOfPatchesList[nrOfPatchesIdx] && desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIdx - 1] / nrOfPatchesList[nrOfPatchesIdx]) { return { x: found, y: found }; } return null; } optimalPatchSize = findPatchSizeForDivisors(common); if (!optimalPatchSize) { optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide)); if (!optimalPatchSize) { optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(desiredPatchSize * nrOfPatches)); } } return optimalPatchSize; } function _parseCSSDimensionValues(value) { var dimension = { value: parseFloat(value), unit: value.indexOf('%') === value.length - 1 ? '%' : '%' }; return dimension; } var _dimensionsConverters = { top: function top(dimension, context) { return dimension.unit === '%' ? Math.floor(context.height * (dimension.value / 100)) : null; }, right: function right(dimension, context) { return dimension.unit === '%' ? Math.floor(context.width - context.width * (dimension.value / 100)) : null; }, bottom: function bottom(dimension, context) { return dimension.unit === '%' ? Math.floor(context.height - context.height * (dimension.value / 100)) : null; }, left: function left(dimension, context) { return dimension.unit === '%' ? Math.floor(context.width * (dimension.value / 100)) : null; } }; function computeImageArea(inputWidth, inputHeight, area) { var context = { width: inputWidth, height: inputHeight }; var parsedArea = Object.keys(area).reduce(function (result, key) { var value = area[key]; var parsed = _parseCSSDimensionValues(value); var calculated = _dimensionsConverters[key](parsed, context); // eslint-disable-next-line no-param-reassign result[key] = calculated; return result; }, {}); return { sx: parsedArea.left, sy: parsedArea.top, sw: parsedArea.right - parsedArea.left, sh: parsedArea.bottom - parsedArea.top }; } // CONCATENATED MODULE: ./src/common/image_wrapper.ts function assertNumberPositive(val) { if (val < 0) { throw new Error("expected positive number, received ".concat(val)); } } var image_wrapper_ImageWrapper = /*#__PURE__*/function () { // Represents a basic image combining the data and size. In addition, some methods for // manipulation are contained within. function ImageWrapper(size, data) { var ArrayType = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : Uint8Array; var initialize = arguments.length > 3 ? arguments[3] : undefined; classCallCheck_default()(this, ImageWrapper); defineProperty_default()(this, "data", void 0); defineProperty_default()(this, "size", void 0); defineProperty_default()(this, "indexMapping", void 0); if (!data) { this.data = new ArrayType(size.x * size.y); if (initialize) { array_helper.init(this.data, 0); } } else { this.data = data; } this.size = size; } // tests if a position is within the image, extended out by a border on each side return createClass_default()(ImageWrapper, [{ key: "inImageWithBorder", value: function inImageWithBorder(imgRef) { var border = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; assertNumberPositive(border); return imgRef.x >= 0 && imgRef.y >= 0 && imgRef.x < this.size.x + border * 2 && imgRef.y < this.size.y + border * 2; } // Copy from THIS ImageWrapper to the new imageWrapper parameter, starting at from, stopping at // end of new imageWrapper size. }, { key: "subImageAsCopy", value: function subImageAsCopy(imageWrapper, from) { assertNumberPositive(from.x); assertNumberPositive(from.y); var _imageWrapper$size = imageWrapper.size, sizeX = _imageWrapper$size.x, sizeY = _imageWrapper$size.y; for (var x = 0; x < sizeX; x++) { for (var y = 0; y < sizeY; y++) { // eslint-disable-next-line no-param-reassign imageWrapper.data[y * sizeX + x] = this.data[(from.y + y) * this.size.x + from.x + x]; } } return imageWrapper; // TODO: this function really probably should call into ImageWrapper somewhere to make // sure that all of it's parameters are set properly, something like // ImageWrapper.UpdateFrom() // that might take a provided data and size, and make sure there's no invalid indexMapping // hanging around, and such. } // Retrieve a grayscale value at the given pixel position of the image }, { key: "get", value: function get(x, y) { return this.data[y * this.size.x + x]; } // Retrieve a grayscale value at the given pixel position of the image (safe, whatever that // means) }, { key: "getSafe", value: function getSafe(x, y) { // cache indexMapping because if we're using it once, we'll probably need it a bunch more // too if (!this.indexMapping) { this.indexMapping = { x: [], y: [] }; for (var i = 0; i < this.size.x; i++) { this.indexMapping.x[i] = i; this.indexMapping.x[i + this.size.x] = i; } for (var _i = 0; _i < this.size.y; _i++) { this.indexMapping.y[_i] = _i; this.indexMapping.y[_i + this.size.y] = _i; } } return this.data[this.indexMapping.y[y + this.size.y] * this.size.x + this.indexMapping.x[x + this.size.x]]; } // Sets a given pixel position in the image to the given grayscale value }, { key: "set", value: function set(x, y, value) { this.data[y * this.size.x + x] = value; delete this.indexMapping; return this; } // Sets the border of the image (1 pixel) to zero }, { key: "zeroBorder", value: function zeroBorder() { var _this$size = this.size, width = _this$size.x, height = _this$size.y; for (var i = 0; i < width; i++) { // eslint-disable-next-line no-multi-assign this.data[i] = this.data[(height - 1) * width + i] = 0; } for (var _i2 = 1; _i2 < height - 1; _i2++) { // eslint-disable-next-line no-multi-assign this.data[_i2 * width] = this.data[_i2 * width + (width - 1)] = 0; } delete this.indexMapping; return this; } // TODO: this function is entirely too large for me to reason out right at this moment that i'm handling // all the rest of it, so this is a verbatim copy of the javascript source, with only tweaks // necessary to get it to run, no thought put into it yet. }, { key: "moments", value: function moments(labelCount) { var data = this.data; var x; var y; var height = this.size.y; var width = this.size.x; var val; var ysq; var labelSum = []; var i; var label; var mu11; var mu02; var mu20; var x_; var y_; var tmp; var result = []; var PI = Math.PI; var PI_4 = PI / 4; if (labelCount <= 0) { return result; } for (i = 0; i < labelCount; i++) { labelSum[i] = { m00: 0, m01: 0, m10: 0, m11: 0, m02: 0, m20: 0, theta: 0, rad: 0 }; } for (y = 0; y < height; y++) { ysq = y * y; for (x = 0; x < width; x++) { val = data[y * width + x]; if (val > 0) { label = labelSum[val - 1]; label.m00 += 1; label.m01 += y; label.m10 += x; label.m11 += x * y; label.m02 += ysq; label.m20 += x * x; } } } for (i = 0; i < labelCount; i++) { label = labelSum[i]; // eslint-disable-next-line no-restricted-globals if (!isNaN(label.m00) && label.m00 !== 0) { x_ = label.m10 / label.m00; y_ = label.m01 / label.m00; mu11 = label.m11 / label.m00 - x_ * y_; mu02 = label.m02 / label.m00 - y_ * y_; mu20 = label.m20 / label.m00 - x_ * x_; tmp = (mu02 - mu20) / (2 * mu11); tmp = 0.5 * Math.atan(tmp) + (mu11 >= 0 ? PI_4 : -PI_4) + PI; // eslint-disable-next-line no-mixed-operators label.theta = (tmp * 180 / PI + 90) % 180 - 90; if (label.theta < 0) { label.theta += 180; } label.rad = tmp > PI ? tmp - PI : tmp; label.vec = vec2_namespaceObject.clone([Math.cos(tmp), Math.sin(tmp)]); result.push(label); } } return result; } // return a Uint8ClampedArray containing this grayscale image converted to RGBA form }, { key: "getAsRGBA", value: function getAsRGBA() { var scale = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1.0; var ret = new Uint8ClampedArray(4 * this.size.x * this.size.y); for (var y = 0; y < this.size.y; y++) { for (var x = 0; x < this.size.x; x++) { var pixel = y * this.size.x + x; var current = this.get(x, y) * scale; ret[pixel * 4 + 0] = current; ret[pixel * 4 + 1] = current; ret[pixel * 4 + 2] = current; ret[pixel * 4 + 3] = 255; } } return ret; } // Display this ImageWrapper in a given Canvas element at the specified scale }, { key: "show", value: function show(canvas) { var scale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1.0; console.warn('* imagewrapper show getcontext 2d'); var ctx = canvas.getContext('2d'); if (!ctx) { throw new Error('Unable to get canvas context'); } var frame = ctx.getImageData(0, 0, canvas.width, canvas.height); var data = this.getAsRGBA(scale); // eslint-disable-next-line no-param-reassign canvas.width = this.size.x; // eslint-disable-next-line no-param-reassign canvas.height = this.size.y; var newFrame = new ImageData(data, frame.width, frame.height); ctx.putImageData(newFrame, 0, 0); } // Displays a specified SubImage area in a given canvas. This differs drastically from // creating a new SubImage and using it's show() method. Why? I don't have the answer to that // yet. I suspect the HSV/RGB operations involved here are making it significantly different, // but until I can visualize these functions side by side, I'm just going to copy the existing // implementation. }, { key: "overlay", value: function overlay(canvas, inScale, from) { var adjustedScale = inScale < 0 || inScale > 360 ? 360 : inScale; var hsv = [0, 1, 1]; var rgb = [0, 0, 0]; var whiteRgb = [255, 255, 255]; var blackRgb = [0, 0, 0]; var result = []; console.warn('* imagewrapper overlay getcontext 2d'); var ctx = canvas.getContext('2d'); if (!ctx) { throw new Error('Unable to get canvas context'); } var frame = ctx.getImageData(from.x, from.y, this.size.x, this.size.y); var data = frame.data; var length = this.data.length; while (length--) { hsv[0] = this.data[length] * adjustedScale; // eslint-disable-next-line no-nested-ternary result = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : hsv2rgb(hsv, rgb); var pos = length * 4; var _result = result; var _result2 = slicedToArray_default()(_result, 3); data[pos] = _result2[0]; data[pos + 1] = _result2[1]; data[pos + 2] = _result2[2]; data[pos + 3] = 255; } ctx.putImageData(frame, from.x, from.y); } }]); }(); /* harmony default export */ var image_wrapper = (image_wrapper_ImageWrapper); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/asyncToGenerator.js var asyncToGenerator = __webpack_require__(7); var asyncToGenerator_default = /*#__PURE__*/__webpack_require__.n(asyncToGenerator); // EXTERNAL MODULE: ./node_modules/@babel/runtime/regenerator/index.js var regenerator = __webpack_require__(6); var regenerator_default = /*#__PURE__*/__webpack_require__.n(regenerator); // CONCATENATED MODULE: ./src/common/image_debug.ts // TODO: XYPosition should be an XYObject, but that breaks XYDefinition, which breaks drawPath() below. // XYDefinition tells us which component of a given array or object is the "X" and which is the "Y". // Usually this is 0 for X and 1 for Y, but might be used as 'x' for x and 'y' for Y. /* harmony default export */ var image_debug = ({ drawRect: function drawRect(pos, size, ctx, style) { ctx.strokeStyle = style.color; ctx.fillStyle = style.color; ctx.lineWidth = style.lineWidth || 1; ctx.beginPath(); ctx.strokeRect(pos.x, pos.y, size.x, size.y); }, drawPath: function drawPath(path, def, ctx, style) { ctx.strokeStyle = style.color; ctx.fillStyle = style.color; ctx.lineWidth = style.lineWidth; ctx.beginPath(); ctx.moveTo(path[0][def.x], path[0][def.y]); for (var j = 1; j < path.length; j++) { ctx.lineTo(path[j][def.x], path[j][def.y]); } ctx.closePath(); ctx.stroke(); }, drawImage: function drawImage(imageData, size, ctx) { var canvasData = ctx.getImageData(0, 0, size.x, size.y); var data = canvasData.data; var canvasDataPos = data.length; var imageDataPos = imageData.length; if (canvasDataPos / imageDataPos !== 4) { return false; } while (imageDataPos--) { var value = imageData[imageDataPos]; data[--canvasDataPos] = 255; data[--canvasDataPos] = value; data[--canvasDataPos] = value; data[--canvasDataPos] = value; } ctx.putImageData(canvasData, 0, 0); return true; } }); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/possibleConstructorReturn.js var possibleConstructorReturn = __webpack_require__(4); var possibleConstructorReturn_default = /*#__PURE__*/__webpack_require__.n(possibleConstructorReturn); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/getPrototypeOf.js var getPrototypeOf = __webpack_require__(1); var getPrototypeOf_default = /*#__PURE__*/__webpack_require__.n(getPrototypeOf); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/inherits.js var inherits = __webpack_require__(5); var inherits_default = /*#__PURE__*/__webpack_require__.n(inherits); // CONCATENATED MODULE: ./src/reader/barcode_reader.ts /* eslint-disable no-unused-vars */ /* eslint-disable class-methods-use-this */ // eslint-disable-next-line import/no-cycle // for some reason this throws a shadow error on itself?! // eslint-disable-next-line no-shadow var BarcodeDirection = /*#__PURE__*/function (BarcodeDirection) { BarcodeDirection[BarcodeDirection["Forward"] = 1] = "Forward"; BarcodeDirection[BarcodeDirection["Reverse"] = -1] = "Reverse"; return BarcodeDirection; }({}); var barcode_reader_BarcodeReader = /*#__PURE__*/function () { function BarcodeReader(config, supplements) { classCallCheck_default()(this, BarcodeReader); defineProperty_default()(this, "_row", []); defineProperty_default()(this, "config", {}); defineProperty_default()(this, "supplements", []); defineProperty_default()(this, "SINGLE_CODE_ERROR", 0); defineProperty_default()(this, "FORMAT", 'unknown'); defineProperty_default()(this, "CONFIG_KEYS", {}); this._row = []; this.config = config || {}; if (supplements) { this.supplements = supplements; } } return createClass_default()(BarcodeReader, [{ key: "_nextUnset", value: function _nextUnset(line) { var start = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; for (var i = start; i < line.length; i++) { if (!line[i]) return i; } return line.length; } }, { key: "_matchPattern", value: function _matchPattern(counter, code) { var maxSingleError = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this.SINGLE_CODE_ERROR || 1; var error = 0; var singleError = 0; var sum = 0; var modulo = 0; var barWidth = 0; var count = 0; var scaled = 0; for (var i = 0; i < counter.length; i++) { sum += counter[i]; modulo += code[i]; } if (sum < modulo) { return Number.MAX_VALUE; } barWidth = sum / modulo; // eslint-disable-next-line no-param-reassign maxSingleError *= barWidth; for (var _i = 0; _i < counter.length; _i++) { count = counter[_i]; scaled = code[_i] * barWidth; singleError = Math.abs(count - scaled) / scaled; if (singleError > maxSingleError) { return Number.MAX_VALUE; } error += singleError; } return error / modulo; } }, { key: "_nextSet", value: function _nextSet(line) { var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; for (var i = offset; i < line.length; i++) { if (line[i]) return i; } return line.length; } }, { key: "_correctBars", value: function _correctBars(counter, correction, indices) { var length = indices.length; var tmp = 0; while (length--) { tmp = counter[indices[length]] * (1 - (1 - correction) / 2); if (tmp > 1) { // eslint-disable-next-line no-param-reassign counter[indices[length]] = tmp; } } } }, { key: "decodePattern", value: function decodePattern(pattern) { // console.warn('* decodePattern', pattern); this._row = pattern; // console.warn('* decodePattern calling decode', typeof this, this.constructor, this.FORMAT, JSON.stringify(this)); var result = this.decode(); // console.warn('* first result=', result); if (result === null) { this._row.reverse(); result = this.decode(); // console.warn('* reversed result=', result); if (result) { result.direction = BarcodeDirection.Reverse; result.start = this._row.length - result.start; result.end = this._row.length - result.end; } } else { result.direction = BarcodeDirection.Forward; } if (result) { result.format = this.FORMAT; } // console.warn('* returning', result); return result; } }, { key: "_matchRange", value: function _matchRange(start, end, value) { // eslint-disable-next-line no-param-reassign start = start < 0 ? 0 : start; var i; for (i = start; i < end; i++) { if (this._row[i] !== value) { return false; } } return true; } }, { key: "_fillCounters", value: function _fillCounters() { var offset = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this._nextUnset(this._row); var end = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this._row.length; var isWhite = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; var counters = []; var counterPos = 0; counters[counterPos] = 0; for (var i = offset; i < end; i++) { // eslint-disable-next-line no-bitwise if (this._row[i] ^ (isWhite ? 1 : 0)) { counters[counterPos]++; } else { counterPos++; counters[counterPos] = 1; // eslint-disable-next-line no-param-reassign isWhite = !isWhite; } } return counters; } }, { key: "_toCounters", value: function _toCounters(start, counters) { var numCounters = counters.length; var end = this._row.length; var isWhite = !this._row[start]; var counterPos = 0; array_helper.init(counters, 0); for (var i = start; i < end; i++) { // eslint-disable-next-line no-bitwise if (this._row[i] ^ (isWhite ? 1 : 0)) { // eslint-disable-next-line no-param-reassign counters[counterPos]++; } else { counterPos++; if (counterPos === numCounters) { break; } else { // eslint-disable-next-line no-param-reassign counters[counterPos] = 1; isWhite = !isWhite; } } } return counters; } // override/implement this in your custom readers. }, { key: "decodeImage", value: function decodeImage(imageWrapper) { // eslint-disable-next-line no-void void imageWrapper; return null; } }], [{ key: "Exception", get: function get() { return { StartNotFoundException: 'Start-Info was not found!', CodeNotFoundException: 'Code could not be found!', PatternNotFoundException: 'Pattern could not be found!' }; } }]); }(); /* harmony default export */ var barcode_reader = (barcode_reader_BarcodeReader); // CONCATENATED MODULE: ./src/reader/2of5_reader.ts function _callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var N = 1; var W = 3; var START_PATTERN = [W, N, W, N, N, N]; var STOP_PATTERN = [W, N, N, N, W]; var CODE_PATTERN = [[N, N, W, W, N], [W, N, N, N, W], [N, W, N, N, W], [W, W, N, N, N], [N, N, W, N, W], [W, N, W, N, N], [N, W, W, N, N], [N, N, N, W, W], [W, N, N, W, N], [N, W, N, W, N]]; var START_PATTERN_LENGTH = START_PATTERN.reduce(function (sum, val) { return sum + val; }, 0); var _2of5_reader_TwoOfFiveReader = /*#__PURE__*/function (_BarcodeReader) { function TwoOfFiveReader() { var _this; classCallCheck_default()(this, TwoOfFiveReader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _callSuper(this, TwoOfFiveReader, [].concat(args)); defineProperty_default()(_this, "barSpaceRatio", [1, 1]); defineProperty_default()(_this, "FORMAT", '2of5'); defineProperty_default()(_this, "SINGLE_CODE_ERROR", 0.78); defineProperty_default()(_this, "AVG_CODE_ERROR", 0.30); return _this; } inherits_default()(TwoOfFiveReader, _BarcodeReader); return createClass_default()(TwoOfFiveReader, [{ key: "_findPattern", value: function _findPattern(pattern, offset) { var isWhite = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; var tryHarder = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; var counter = []; var counterPos = 0; var bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0 }; var sum = 0; var error = 0; var epsilon = this.AVG_CODE_ERROR; if (!offset) { offset = this._nextSet(this._row); } for (var i = 0; i < pattern.length; i++) { counter[i] = 0; } for (var _i = offset; _i < this._row.length; _i++) { if (this._row[_i] ^ (isWhite ? 1 : 0)) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { sum = 0; for (var j = 0; j < counter.length; j++) { sum += counter[j]; } error = this._matchPattern(counter, pattern); if (error < epsilon) { bestMatch.error = error; bestMatch.start = _i - sum; bestMatch.end = _i; return bestMatch; } if (tryHarder) { for (var _j = 0; _j < counter.length - 2; _j++) { counter[_j] = counter[_j + 2]; } counter[counter.length - 2] = 0; counter[counter.length - 1] = 0; counterPos--; } else { return null; } } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return null; } }, { key: "_findStart", value: function _findStart() { var startInfo = null; var offset = this._nextSet(this._row); var narrowBarWidth = 1; var leadingWhitespaceStart = 0; while (!startInfo) { startInfo = this._findPattern(START_PATTERN, offset, false, true); if (!startInfo) { return null; } narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / START_PATTERN_LENGTH); leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5; if (leadingWhitespaceStart >= 0) { if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) { return startInfo; } } offset = startInfo.end; startInfo = null; } return startInfo; } }, { key: "_verifyTrailingWhitespace", value: function _verifyTrailingWhitespace(endInfo) { var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; if (trailingWhitespaceEnd < this._row.length) { if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { return endInfo; } } return null; } }, { key: "_findEnd", value: function _findEnd() { // TODO: reverse, followed by some calcs, followed by another reverse? really? this._row.reverse(); var offset = this._nextSet(this._row); var endInfo = this._findPattern(STOP_PATTERN, offset, false, true); this._row.reverse(); if (endInfo === null) { return null; } // reverse numbers var tmp = endInfo.start; endInfo.start = this._row.length - endInfo.end; endInfo.end = this._row.length - tmp; return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null; } }, { key: "_verifyCounterLength", value: function _verifyCounterLength(counters) { return counters.length % 10 === 0; } }, { key: "_decodeCode", value: function _decodeCode(counter) { var epsilon = this.AVG_CODE_ERROR; var bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0 }; for (var code = 0; code < CODE_PATTERN.length; code++) { var error = this._matchPattern(counter, CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } if (bestMatch.error < epsilon) { return bestMatch; } return null; } }, { key: "_decodePayload", value: function _decodePayload(counters, result, decodedCodes) { var pos = 0; var counterLength = counters.length; var counter = [0, 0, 0, 0, 0]; var code = null; while (pos < counterLength) { for (var i = 0; i < 5; i++) { counter[i] = counters[pos] * this.barSpaceRatio[0]; pos += 2; } code = this._decodeCode(counter); if (!code) { return null; } result.push("".concat(code.code)); decodedCodes.push(code); } return code; } }, { key: "decode", value: function decode(row, start) { var startInfo = this._findStart(); if (!startInfo) { return null; } var endInfo = this._findEnd(); if (!endInfo) { return null; } var counters = this._fillCounters(startInfo.end, endInfo.start, false); if (!this._verifyCounterLength(counters)) { return null; } var decodedCodes = []; decodedCodes.push(startInfo); var result = []; var code = this._decodePayload(counters, result, decodedCodes); if (!code) { return null; } if (result.length < 5) { return null; } decodedCodes.push(endInfo); return { code: result.join(''), start: startInfo.start, end: endInfo.end, startInfo: startInfo, decodedCodes: decodedCodes, format: this.FORMAT }; } }]); }(barcode_reader); /* harmony default export */ var _2of5_reader = (_2of5_reader_TwoOfFiveReader); // CONCATENATED MODULE: ./src/reader/codabar_reader.ts function codabar_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, codabar_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function codabar_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (codabar_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } // const ALPHABETH_STRING = '0123456789-$:/.+ABCD'; var ALPHABET = [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 45, 36, 58, 47, 46, 43, 65, 66, 67, 68]; var CHARACTER_ENCODINGS = [0x003, 0x006, 0x009, 0x060, 0x012, 0x042, 0x021, 0x024, 0x030, 0x048, 0x00c, 0x018, 0x045, 0x051, 0x054, 0x015, 0x01A, 0x029, 0x00B, 0x00E]; var START_END = [0x01A, 0x029, 0x00B, 0x00E]; var MIN_ENCODED_CHARS = 4; var MAX_ACCEPTABLE = 2.0; var PADDING = 1.5; ; ; var codabar_reader_NewCodabarReader = /*#__PURE__*/function (_BarcodeReader) { function NewCodabarReader() { var _this; classCallCheck_default()(this, NewCodabarReader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = codabar_reader_callSuper(this, NewCodabarReader, [].concat(args)); defineProperty_default()(_this, "_counters", []); defineProperty_default()(_this, "FORMAT", 'codabar'); return _this; } inherits_default()(NewCodabarReader, _BarcodeReader); return createClass_default()(NewCodabarReader, [{ key: "_computeAlternatingThreshold", value: function _computeAlternatingThreshold(offset, end) { var min = Number.MAX_VALUE; var max = 0; var counter = 0; for (var i = offset; i < end; i += 2) { counter = this._counters[i]; if (counter > max) { max = counter; } if (counter < min) { min = counter; } } return (min + max) / 2.0 | 0; } }, { key: "_toPattern", value: function _toPattern(offset) { var numCounters = 7; var end = offset + numCounters; if (end > this._counters.length) { return -1; } var barThreshold = this._computeAlternatingThreshold(offset, end); var spaceThreshold = this._computeAlternatingThreshold(offset + 1, end); var bitmask = 1 << numCounters - 1; var threshold = 0; var pattern = 0; for (var i = 0; i < numCounters; i++) { threshold = (i & 1) === 0 ? barThreshold : spaceThreshold; if (this._counters[offset + i] > threshold) { pattern |= bitmask; } bitmask >>= 1; } return pattern; } }, { key: "_isStartEnd", value: function _isStartEnd(pattern) { for (var i = 0; i < START_END.length; i++) { if (START_END[i] === pattern) { return true; } } return false; } }, { key: "_sumCounters", value: function _sumCounters(start, end) { var sum = 0; for (var i = start; i < end; i++) { sum += this._counters[i]; } return sum; } }, { key: "_findStart", value: function _findStart() { var start = this._nextUnset(this._row); var end = start; for (var i = 1; i < this._counters.length; i++) { var pattern = this._toPattern(i); if (pattern !== -1 && this._isStartEnd(pattern)) { // TODO: Look for whitespace ahead start += this._sumCounters(0, i); end = start + this._sumCounters(i, i + 8); return { start: start, end: end, startCounter: i, endCounter: i + 8 }; } } return null; } }, { key: "_patternToChar", value: function _patternToChar(pattern) { for (var i = 0; i < CHARACTER_ENCODINGS.length; i++) { if (CHARACTER_ENCODINGS[i] === pattern) { return String.fromCharCode(ALPHABET[i]); } } return null; } }, { key: "_calculatePatternLength", value: function _calculatePatternLength(offset) { var sum = 0; for (var i = offset; i < offset + 7; i++) { sum += this._counters[i]; } return sum; } }, { key: "_verifyWhitespace", value: function _verifyWhitespace(startCounter, endCounter) { if (startCounter - 1 <= 0 || this._counters[startCounter - 1] >= this._calculatePatternLength(startCounter) / 2.0) { if (endCounter + 8 >= this._counters.length || this._counters[endCounter + 7] >= this._calculatePatternLength(endCounter) / 2.0) { return true; } } return false; } }, { key: "_charToPattern", value: function _charToPattern(_char) { var charCode = _char.charCodeAt(0); for (var i = 0; i < ALPHABET.length; i++) { if (ALPHABET[i] === charCode) { return CHARACTER_ENCODINGS[i]; } } return 0x0; } }, { key: "_thresholdResultPattern", value: function _thresholdResultPattern(result, startCounter) { var categorization = { space: { narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE }, wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE } }, bar: { narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE }, wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE } } }; var pos = startCounter; var pattern; for (var i = 0; i < result.length; i++) { pattern = this._charToPattern(result[i]); for (var j = 6; j >= 0; j--) { var kind = (j & 1) === 2 ? categorization.bar : categorization.space; var cat = (pattern & 1) === 1 ? kind.wide : kind.narrow; cat.size += this._counters[pos + j]; cat.counts++; pattern >>= 1; } pos += 8; } ['space', 'bar'].forEach(function (key) { var newkind = categorization[key]; newkind.wide.min = Math.floor((newkind.narrow.size / newkind.narrow.counts + newkind.wide.size / newkind.wide.counts) / 2); newkind.narrow.max = Math.ceil(newkind.wide.min); newkind.wide.max = Math.ceil((newkind.wide.size * MAX_ACCEPTABLE + PADDING) / newkind.wide.counts); }); return categorization; } }, { key: "_validateResult", value: function _validateResult(result, startCounter) { var thresholds = this._thresholdResultPattern(result, startCounter); var pos = startCounter; var pattern; for (var i = 0; i < result.length; i++) { pattern = this._charToPattern(result[i]); for (var j = 6; j >= 0; j--) { var kind = (j & 1) === 0 ? thresholds.bar : thresholds.space; var cat = (pattern & 1) === 1 ? kind.wide : kind.narrow; var size = this._counters[pos + j]; if (size < cat.min || size > cat.max) { return false; } pattern >>= 1; } pos += 8; } return true; } }, { key: "decode", value: function decode(row, start) { this._counters = this._fillCounters(); start = this._findStart(); if (!start) { return null; } var nextStart = start.startCounter; var result = []; var pattern; do { pattern = this._toPattern(nextStart); if (pattern < 0) { return null; } var decodedChar = this._patternToChar(pattern); if (decodedChar === null) { return null; } result.push(decodedChar); nextStart += 8; if (result.length > 1 && this._isStartEnd(pattern)) { break; } } while (nextStart < this._counters.length); // verify end if (result.length - 2 < MIN_ENCODED_CHARS || !this._isStartEnd(pattern)) { return null; } // verify end white space if (!this._verifyWhitespace(start.startCounter, nextStart - 8)) { return null; } if (!this._validateResult(result, start.startCounter)) { return null; } nextStart = nextStart > this._counters.length ? this._counters.length : nextStart; var end = start.start + this._sumCounters(start.startCounter, nextStart - 8); return { code: result.join(''), start: start.start, end: end, startInfo: start, decodedCodes: result, format: this.FORMAT // TODO: i think it should not be required to return format from this, as barcode_reader force sets the format anyway }; } }]); }(barcode_reader); /* harmony default export */ var codabar_reader = (codabar_reader_NewCodabarReader); // CONCATENATED MODULE: ./src/reader/code_128_reader.ts function code_128_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, code_128_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function code_128_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (code_128_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var code_128_reader_Code128Reader = /*#__PURE__*/function (_BarcodeReader) { function Code128Reader() { var _this; classCallCheck_default()(this, Code128Reader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = code_128_reader_callSuper(this, Code128Reader, [].concat(args)); defineProperty_default()(_this, "CODE_SHIFT", 98); defineProperty_default()(_this, "CODE_C", 99); defineProperty_default()(_this, "CODE_B", 100); defineProperty_default()(_this, "CODE_A", 101); defineProperty_default()(_this, "START_CODE_A", 103); defineProperty_default()(_this, "START_CODE_B", 104); defineProperty_default()(_this, "START_CODE_C", 105); defineProperty_default()(_this, "STOP_CODE", 106); defineProperty_default()(_this, "CODE_PATTERN", [[2, 1, 2, 2, 2, 2], [2, 2, 2, 1, 2, 2], [2, 2, 2, 2, 2, 1], [1, 2, 1, 2, 2, 3], [1, 2, 1, 3, 2, 2], [1, 3, 1, 2, 2, 2], [1, 2, 2, 2, 1, 3], [1, 2, 2, 3, 1, 2], [1, 3, 2, 2, 1, 2], [2, 2, 1, 2, 1, 3], [2, 2, 1, 3, 1, 2], [2, 3, 1, 2, 1, 2], [1, 1, 2, 2, 3, 2], [1, 2, 2, 1, 3, 2], [1, 2, 2, 2, 3, 1], [1, 1, 3, 2, 2, 2], [1, 2, 3, 1, 2, 2], [1, 2, 3, 2, 2, 1], [2, 2, 3, 2, 1, 1], [2, 2, 1, 1, 3, 2], [2, 2, 1, 2, 3, 1], [2, 1, 3, 2, 1, 2], [2, 2, 3, 1, 1, 2], [3, 1, 2, 1, 3, 1], [3, 1, 1, 2, 2, 2], [3, 2, 1, 1, 2, 2], [3, 2, 1, 2, 2, 1], [3, 1, 2, 2, 1, 2], [3, 2, 2, 1, 1, 2], [3, 2, 2, 2, 1, 1], [2, 1, 2, 1, 2, 3], [2, 1, 2, 3, 2, 1], [2, 3, 2, 1, 2, 1], [1, 1, 1, 3, 2, 3], [1, 3, 1, 1, 2, 3], [1, 3, 1, 3, 2, 1], [1, 1, 2, 3, 1, 3], [1, 3, 2, 1, 1, 3], [1, 3, 2, 3, 1, 1], [2, 1, 1, 3, 1, 3], [2, 3, 1, 1, 1, 3], [2, 3, 1, 3, 1, 1], [1, 1, 2, 1, 3, 3], [1, 1, 2, 3, 3, 1], [1, 3, 2, 1, 3, 1], [1, 1, 3, 1, 2, 3], [1, 1, 3, 3, 2, 1], [1, 3, 3, 1, 2, 1], [3, 1, 3, 1, 2, 1], [2, 1, 1, 3, 3, 1], [2, 3, 1, 1, 3, 1], [2, 1, 3, 1, 1, 3], [2, 1, 3, 3, 1, 1], [2, 1, 3, 1, 3, 1], [3, 1, 1, 1, 2, 3], [3, 1, 1, 3, 2, 1], [3, 3, 1, 1, 2, 1], [3, 1, 2, 1, 1, 3], [3, 1, 2, 3, 1, 1], [3, 3, 2, 1, 1, 1], [3, 1, 4, 1, 1, 1], [2, 2, 1, 4, 1, 1], [4, 3, 1, 1, 1, 1], [1, 1, 1, 2, 2, 4], [1, 1, 1, 4, 2, 2], [1, 2, 1, 1, 2, 4], [1, 2, 1, 4, 2, 1], [1, 4, 1, 1, 2, 2], [1, 4, 1, 2, 2, 1], [1, 1, 2, 2, 1, 4], [1, 1, 2, 4, 1, 2], [1, 2, 2, 1, 1, 4], [1, 2, 2, 4, 1, 1], [1, 4, 2, 1, 1, 2], [1, 4, 2, 2, 1, 1], [2, 4, 1, 2, 1, 1], [2, 2, 1, 1, 1, 4], [4, 1, 3, 1, 1, 1], [2, 4, 1, 1, 1, 2], [1, 3, 4, 1, 1, 1], [1, 1, 1, 2, 4, 2], [1, 2, 1, 1, 4, 2], [1, 2, 1, 2, 4, 1], [1, 1, 4, 2, 1, 2], [1, 2, 4, 1, 1, 2], [1, 2, 4, 2, 1, 1], [4, 1, 1, 2, 1, 2], [4, 2, 1, 1, 1, 2], [4, 2, 1, 2, 1, 1], [2, 1, 2, 1, 4, 1], [2, 1, 4, 1, 2, 1], [4, 1, 2, 1, 2, 1], [1, 1, 1, 1, 4, 3], [1, 1, 1, 3, 4, 1], [1, 3, 1, 1, 4, 1], [1, 1, 4, 1, 1, 3], [1, 1, 4, 3, 1, 1], [4, 1, 1, 1, 1, 3], [4, 1, 1, 3, 1, 1], [1, 1, 3, 1, 4, 1], [1, 1, 4, 1, 3, 1], [3, 1, 1, 1, 4, 1], [4, 1, 1, 1, 3, 1], [2, 1, 1, 4, 1, 2], [2, 1, 1, 2, 1, 4], [2, 1, 1, 2, 3, 2], [2, 3, 3, 1, 1, 1, 2]]); defineProperty_default()(_this, "SINGLE_CODE_ERROR", 0.64); defineProperty_default()(_this, "AVG_CODE_ERROR", 0.30); defineProperty_default()(_this, "FORMAT", 'code_128'); defineProperty_default()(_this, "MODULE_INDICES", { bar: [0, 2, 4], space: [1, 3, 5] }); return _this; } inherits_default()(Code128Reader, _BarcodeReader); return createClass_default()(Code128Reader, [{ key: "_decodeCode", value: function _decodeCode(start, correction) { var bestMatch = { error: Number.MAX_VALUE, code: -1, start: start, end: start, correction: { bar: 1, space: 1 } }; var counter = [0, 0, 0, 0, 0, 0]; var offset = start; var isWhite = !this._row[offset]; var counterPos = 0; for (var i = offset; i < this._row.length; i++) { if (this._row[i] ^ (isWhite ? 1 : 0)) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { if (correction) { this._correct(counter, correction); } for (var code = 0; code < this.CODE_PATTERN.length; code++) { var error = this._matchPattern(counter, this.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } bestMatch.end = i; if (bestMatch.code === -1 || bestMatch.error > this.AVG_CODE_ERROR) { return null; } if (this.CODE_PATTERN[bestMatch.code]) { bestMatch.correction.bar = this.calculateCorrection(this.CODE_PATTERN[bestMatch.code], counter, this.MODULE_INDICES.bar); bestMatch.correction.space = this.calculateCorrection(this.CODE_PATTERN[bestMatch.code], counter, this.MODULE_INDICES.space); } return bestMatch; } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return null; } }, { key: "_correct", value: function _correct(counter, correction) { this._correctBars(counter, correction.bar, this.MODULE_INDICES.bar); this._correctBars(counter, correction.space, this.MODULE_INDICES.space); } }, { key: "_findStart", value: // TODO: _findStart and decodeCode share similar code, can we re-use some? function _findStart() { var counter = [0, 0, 0, 0, 0, 0]; var offset = this._nextSet(this._row); var bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0, correction: { bar: 1, space: 1 } }; var isWhite = false; var counterPos = 0; for (var i = offset; i < this._row.length; i++) { if (this._row[i] ^ (isWhite ? 1 : 0)) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { var sum = counter.reduce(function (prev, next) { return prev + next; }, 0); for (var code = this.START_CODE_A; code <= this.START_CODE_C; code++) { var error = this._matchPattern(counter, this.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } if (bestMatch.error < this.AVG_CODE_ERROR) { bestMatch.start = i - sum; bestMatch.end = i; bestMatch.correction.bar = this.calculateCorrection(this.CODE_PATTERN[bestMatch.code], counter, this.MODULE_INDICES.bar); bestMatch.correction.space = this.calculateCorrection(this.CODE_PATTERN[bestMatch.code], counter, this.MODULE_INDICES.space); return bestMatch; } for (var j = 0; j < 4; j++) { counter[j] = counter[j + 2]; } counter[4] = 0; counter[5] = 0; counterPos--; } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return null; } }, { key: "decode", value: function decode(row, start) { var _this2 = this; var startInfo = this._findStart(); if (startInfo === null) { return null; } // var self = this, // done = false, // result = [], // multiplier = 0, // checksum = 0, // codeset, // rawResult = [], // decodedCodes = [], // shiftNext = false, // unshift, // removeLastCharacter = true; var code = { code: startInfo.code, start: startInfo.start, end: startInfo.end, correction: { bar: startInfo.correction.bar, space: startInfo.correction.space } }; var decodedCodes = []; decodedCodes.push(code); var checksum = code.code; var codeset = function (c) { switch (c) { case _this2.START_CODE_A: return _this2.CODE_A; case _this2.START_CODE_B: return _this2.CODE_B; case _this2.START_CODE_C: return _this2.CODE_C; default: return null; } }(code.code); var done = false; var shiftNext = false; var unshift = shiftNext; var removeLastCharacter = true; var multiplier = 0; var rawResult = []; var result = []; // TODO: i think this should be string only, but it creates problems if it is while (!done) { unshift = shiftNext; shiftNext = false; code = this._decodeCode(code.end, code.correction); if (code !== null) { if (code.code !== this.STOP_CODE) { removeLastCharacter = true; } if (code.code !== this.STOP_CODE) { rawResult.push(code.code); multiplier++; checksum += multiplier * code.code; } decodedCodes.push(code); switch (codeset) { case this.CODE_A: if (code.code < 64) { result.push(String.fromCharCode(32 + code.code)); } else if (code.code < 96) { result.push(String.fromCharCode(code.code - 64)); } else { if (code.code !== this.STOP_CODE) { removeLastCharacter = false; } switch (code.code) { case this.CODE_SHIFT: shiftNext = true; codeset = this.CODE_B; break; case this.CODE_B: codeset = this.CODE_B; break; case this.CODE_C: codeset = this.CODE_C; break; case this.STOP_CODE: done = true; break; } } break; case this.CODE_B: if (code.code < 96) { result.push(String.fromCharCode(32 + code.code)); } else { if (code.code !== this.STOP_CODE) { removeLastCharacter = false; } switch (code.code) { case this.CODE_SHIFT: shiftNext = true; codeset = this.CODE_A; break; case this.CODE_A: codeset = this.CODE_A; break; case this.CODE_C: codeset = this.CODE_C; break; case this.STOP_CODE: done = true; break; } } break; case this.CODE_C: if (code.code < 100) { result.push(code.code < 10 ? '0' + code.code : code.code); } else { if (code.code !== this.STOP_CODE) { removeLastCharacter = false; } switch (code.code) { case this.CODE_A: codeset = this.CODE_A; break; case this.CODE_B: codeset = this.CODE_B; break; case this.STOP_CODE: done = true; break; } } break; } } else { done = true; } if (unshift) { codeset = codeset === this.CODE_A ? this.CODE_B : this.CODE_A; } } if (code === null) { return null; } code.end = this._nextUnset(this._row, code.end); if (!this._verifyTrailingWhitespace(code)) { return null; } checksum -= multiplier * rawResult[rawResult.length - 1]; if (checksum % 103 !== rawResult[rawResult.length - 1]) { return null; } if (!result.length) { return null; } // remove last code from result (checksum) if (removeLastCharacter) { result.splice(result.length - 1, 1); } return { code: result.join(''), start: startInfo.start, end: code.end, codeset: codeset, startInfo: startInfo, decodedCodes: decodedCodes, endInfo: code, format: this.FORMAT }; } }, { key: "_verifyTrailingWhitespace", value: function _verifyTrailingWhitespace(endInfo) { var self = this, trailingWhitespaceEnd; trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; if (trailingWhitespaceEnd < self._row.length) { if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { return endInfo; } } return null; } }, { key: "calculateCorrection", value: function calculateCorrection(expected, normalized, indices) { var length = indices.length, sumNormalized = 0, sumExpected = 0; while (length--) { sumExpected += expected[indices[length]]; sumNormalized += normalized[indices[length]]; } return sumExpected / sumNormalized; } }]); }(barcode_reader); /* harmony default export */ var code_128_reader = (code_128_reader_Code128Reader); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/get.js var get = __webpack_require__(10); var get_default = /*#__PURE__*/__webpack_require__.n(get); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/toConsumableArray.js var toConsumableArray = __webpack_require__(25); var toConsumableArray_default = /*#__PURE__*/__webpack_require__.n(toConsumableArray); // CONCATENATED MODULE: ./src/reader/code_39_reader.ts function code_39_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, code_39_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function code_39_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (code_39_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } /* eslint-disable class-methods-use-this */ var ALPHABETH_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%'; var code_39_reader_ALPHABET = new Uint16Array(toConsumableArray_default()(ALPHABETH_STRING).map(function (_char) { return _char.charCodeAt(0); })); var code_39_reader_CHARACTER_ENCODINGS = new Uint16Array([0x034, 0x121, 0x061, 0x160, 0x031, 0x130, 0x070, 0x025, 0x124, 0x064, 0x109, 0x049, 0x148, 0x019, 0x118, 0x058, 0x00D, 0x10C, 0x04C, 0x01C, 0x103, 0x043, 0x142, 0x013, 0x112, 0x052, 0x007, 0x106, 0x046, 0x016, 0x181, 0x0C1, 0x1C0, 0x091, 0x190, 0x0D0, 0x085, 0x184, 0x0C4, 0x094, 0x0A8, 0x0A2, 0x08A, 0x02A]); var ASTERISK = 0x094; var code_39_reader_Code39Reader = /*#__PURE__*/function (_BarcodeReader) { function Code39Reader() { var _this; classCallCheck_default()(this, Code39Reader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = code_39_reader_callSuper(this, Code39Reader, [].concat(args)); defineProperty_default()(_this, "FORMAT", 'code_39'); return _this; } inherits_default()(Code39Reader, _BarcodeReader); return createClass_default()(Code39Reader, [{ key: "_findStart", value: function _findStart() { var offset = this._nextSet(this._row); var patternStart = offset; var counter = new Uint16Array([0, 0, 0, 0, 0, 0, 0, 0, 0]); var counterPos = 0; var isWhite = false; for (var i = offset; i < this._row.length; i++) { // eslint-disable-next-line no-bitwise if (this._row[i] ^ (isWhite ? 1 : 0)) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { // find start pattern if (this._toPattern(counter) === ASTERISK) { var whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - (i - patternStart) / 4)); if (this._matchRange(whiteSpaceMustStart, patternStart, 0)) { return { start: patternStart, end: i }; } } patternStart += counter[0] + counter[1]; for (var j = 0; j < 7; j++) { counter[j] = counter[j + 2]; } counter[7] = 0; counter[8] = 0; counterPos--; } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return null; } }, { key: "_toPattern", value: function _toPattern(counters) { var numCounters = counters.length; var maxNarrowWidth = 0; var numWideBars = numCounters; var wideBarWidth = 0; while (numWideBars > 3) { maxNarrowWidth = this._findNextWidth(counters, maxNarrowWidth); numWideBars = 0; var pattern = 0; for (var i = 0; i < numCounters; i++) { if (counters[i] > maxNarrowWidth) { // eslint-disable-next-line no-bitwise pattern |= 1 << numCounters - 1 - i; numWideBars++; wideBarWidth += counters[i]; } } if (numWideBars === 3) { for (var _i = 0; _i < numCounters && numWideBars > 0; _i++) { if (counters[_i] > maxNarrowWidth) { numWideBars--; if (counters[_i] * 2 >= wideBarWidth) { return -1; } } } return pattern; } } return -1; } }, { key: "_findNextWidth", value: function _findNextWidth(counters, current) { var minWidth = Number.MAX_VALUE; for (var i = 0; i < counters.length; i++) { if (counters[i] < minWidth && counters[i] > current) { minWidth = counters[i]; } } return minWidth; } }, { key: "_patternToChar", value: function _patternToChar(pattern) { for (var i = 0; i < code_39_reader_CHARACTER_ENCODINGS.length; i++) { if (code_39_reader_CHARACTER_ENCODINGS[i] === pattern) { return String.fromCharCode(code_39_reader_ALPHABET[i]); } } return null; } }, { key: "_verifyTrailingWhitespace", value: function _verifyTrailingWhitespace(lastStart, nextStart, counters) { var patternSize = array_helper.sum(counters); var trailingWhitespaceEnd = nextStart - lastStart - patternSize; if (trailingWhitespaceEnd * 3 >= patternSize) { return true; } return false; } }, { key: "decode", value: function decode() { var counters = new Uint16Array([0, 0, 0, 0, 0, 0, 0, 0, 0]); var result = []; var start = this._findStart(); if (!start) { return null; } var nextStart = this._nextSet(this._row, start.end); var decodedChar; var lastStart; do { counters = this._toCounters(nextStart, counters); var pattern = this._toPattern(counters); if (pattern < 0) { return null; } decodedChar = this._patternToChar(pattern); if (decodedChar === null) { return null; } result.push(decodedChar); lastStart = nextStart; nextStart += array_helper.sum(counters); nextStart = this._nextSet(this._row, nextStart); } while (decodedChar !== '*'); result.pop(); if (!result.length) { return null; } if (!this._verifyTrailingWhitespace(lastStart, nextStart, counters)) { return null; } return { code: result.join(''), start: start.start, end: nextStart, startInfo: start, decodedCodes: result, format: this.FORMAT }; } }]); }(barcode_reader); /* harmony default export */ var code_39_reader = (code_39_reader_Code39Reader); // CONCATENATED MODULE: ./src/reader/code_32_reader.ts function code_32_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, code_32_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function code_32_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (code_32_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } function _superPropGet(t, o, e, r) { var p = get_default()(getPrototypeOf_default()(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } var patterns = { AEIO: /[AEIO]/g, AZ09: /[A-Z0-9]/ }; var code32set = '0123456789BCDFGHJKLMNPQRSTUVWXYZ'; var code_32_reader_Code32Reader = /*#__PURE__*/function (_Code39Reader) { function Code32Reader() { var _this; classCallCheck_default()(this, Code32Reader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = code_32_reader_callSuper(this, Code32Reader, [].concat(args)); defineProperty_default()(_this, "FORMAT", 'code_32_reader'); return _this; } inherits_default()(Code32Reader, _Code39Reader); return createClass_default()(Code32Reader, [{ key: "_decodeCode32", value: function _decodeCode32(code) { if (/[^0-9BCDFGHJKLMNPQRSTUVWXYZ]/.test(code)) { return null; } var res = 0; for (var i = 0; i < code.length; i++) { res = res * 32 + code32set.indexOf(code[i]); } var code32 = "".concat(res); if (code32.length < 9) { code32 = ('000000000' + code32).slice(-9); } return 'A' + code32; } // TODO (this was todo in original repo, no text was there. sorry.) }, { key: "_checkChecksum", value: function _checkChecksum(code) { return !!code; } }, { key: "decode", value: function decode() { var result = _superPropGet(Code32Reader, "decode", this, 3)([]); if (!result) { return null; } var code = result.code; if (!code) { return null; } code = code.replace(patterns.AEIO, ''); if (!this._checkChecksum(code)) { return null; } var code32 = this._decodeCode32(code); if (!code32) { return null; } result.code = code32; return result; } }]); }(code_39_reader); /* harmony default export */ var code_32_reader = (code_32_reader_Code32Reader); // CONCATENATED MODULE: ./src/reader/code_39_vin_reader.ts function code_39_vin_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, code_39_vin_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function code_39_vin_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (code_39_vin_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } function code_39_vin_reader_superPropGet(t, o, e, r) { var p = get_default()(getPrototypeOf_default()(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } /* eslint-disable class-methods-use-this */ var code_39_vin_reader_patterns = { IOQ: /[IOQ]/g, AZ09: /[A-Z0-9]{17}/ }; var code_39_vin_reader_Code39VINReader = /*#__PURE__*/function (_Code39Reader) { function Code39VINReader() { var _this; classCallCheck_default()(this, Code39VINReader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = code_39_vin_reader_callSuper(this, Code39VINReader, [].concat(args)); defineProperty_default()(_this, "FORMAT", 'code_39_vin'); return _this; } inherits_default()(Code39VINReader, _Code39Reader); return createClass_default()(Code39VINReader, [{ key: "_checkChecksum", value: // TODO (this was todo in original repo, no text was there. sorry.) function _checkChecksum(code) { return !!code; } // Cribbed from: // https://github.com/zxing/zxing/blob/master/core/src/main/java/com/google/zxing/client/result/VINResultParser.java }, { key: "decode", value: function decode() { var result = code_39_vin_reader_superPropGet(Code39VINReader, "decode", this, 3)([]); if (!result) { return null; } var code = result.code; if (!code) { return null; } code = code.replace(code_39_vin_reader_patterns.IOQ, ''); if (!code.match(code_39_vin_reader_patterns.AZ09)) { if (true) { console.log('Failed AZ09 pattern code:', code); } return null; } if (!this._checkChecksum(code)) { return null; } result.code = code; return result; } }]); }(code_39_reader); /* harmony default export */ var code_39_vin_reader = (code_39_vin_reader_Code39VINReader); // CONCATENATED MODULE: ./src/reader/code_93_reader.ts function code_93_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, code_93_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function code_93_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (code_93_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var code_93_reader_ALPHABETH_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*'; var code_93_reader_ALPHABET = new Uint16Array(toConsumableArray_default()(code_93_reader_ALPHABETH_STRING).map(function (_char) { return _char.charCodeAt(0); })); var code_93_reader_CHARACTER_ENCODINGS = new Uint16Array([0x114, 0x148, 0x144, 0x142, 0x128, 0x124, 0x122, 0x150, 0x112, 0x10A, 0x1A8, 0x1A4, 0x1A2, 0x194, 0x192, 0x18A, 0x168, 0x164, 0x162, 0x134, 0x11A, 0x158, 0x14C, 0x146, 0x12C, 0x116, 0x1B4, 0x1B2, 0x1AC, 0x1A6, 0x196, 0x19A, 0x16C, 0x166, 0x136, 0x13A, 0x12E, 0x1D4, 0x1D2, 0x1CA, 0x16E, 0x176, 0x1AE, 0x126, 0x1DA, 0x1D6, 0x132, 0x15E]); var code_93_reader_ASTERISK = 0x15E; var code_93_reader_Code93Reader = /*#__PURE__*/function (_BarcodeReader) { function Code93Reader() { var _this; classCallCheck_default()(this, Code93Reader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = code_93_reader_callSuper(this, Code93Reader, [].concat(args)); defineProperty_default()(_this, "FORMAT", 'code_93'); return _this; } inherits_default()(Code93Reader, _BarcodeReader); return createClass_default()(Code93Reader, [{ key: "_patternToChar", value: function _patternToChar(pattern) { for (var i = 0; i < code_93_reader_CHARACTER_ENCODINGS.length; i++) { if (code_93_reader_CHARACTER_ENCODINGS[i] === pattern) { return String.fromCharCode(code_93_reader_ALPHABET[i]); } } return null; } }, { key: "_toPattern", value: function _toPattern(counters) { var numCounters = counters.length; var sum = counters.reduce(function (prev, next) { return prev + next; }, 0); var pattern = 0; for (var i = 0; i < numCounters; i++) { var normalized = Math.round(counters[i] * 9 / sum); if (normalized < 1 || normalized > 4) { return -1; } if ((i & 1) === 0) { for (var j = 0; j < normalized; j++) { pattern = pattern << 1 | 1; } } else { pattern <<= normalized; } } return pattern; } }, { key: "_findStart", value: function _findStart() { var offset = this._nextSet(this._row); var patternStart = offset; var counter = new Uint16Array([0, 0, 0, 0, 0, 0]); var counterPos = 0; var isWhite = false; for (var i = offset; i < this._row.length; i++) { if (this._row[i] ^ (isWhite ? 1 : 0)) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { // find start pattern if (this._toPattern(counter) === code_93_reader_ASTERISK) { var whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - (i - patternStart) / 4)); if (this._matchRange(whiteSpaceMustStart, patternStart, 0)) { return { start: patternStart, end: i }; } } patternStart += counter[0] + counter[1]; for (var j = 0; j < 4; j++) { counter[j] = counter[j + 2]; } counter[4] = 0; counter[5] = 0; counterPos--; } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return null; } }, { key: "_verifyEnd", value: function _verifyEnd(lastStart, nextStart) { if (lastStart === nextStart || !this._row[nextStart]) { return false; } return true; } }, { key: "_decodeExtended", value: function _decodeExtended(charArray) { var length = charArray.length; var result = []; for (var i = 0; i < length; i++) { var _char2 = charArray[i]; if (_char2 >= 'a' && _char2 <= 'd') { if (i > length - 2) { return null; } var nextChar = charArray[++i]; var nextCharCode = nextChar.charCodeAt(0); var decodedChar = void 0; switch (_char2) { case 'a': if (nextChar >= 'A' && nextChar <= 'Z') { decodedChar = String.fromCharCode(nextCharCode - 64); } else { return null; } break; case 'b': if (nextChar >= 'A' && nextChar <= 'E') { decodedChar = String.fromCharCode(nextCharCode - 38); } else if (nextChar >= 'F' && nextChar <= 'J') { decodedChar = String.fromCharCode(nextCharCode - 11); } else if (nextChar >= 'K' && nextChar <= 'O') { decodedChar = String.fromCharCode(nextCharCode + 16); } else if (nextChar >= 'P' && nextChar <= 'S') { decodedChar = String.fromCharCode(nextCharCode + 43); } else if (nextChar >= 'T' && nextChar <= 'Z') { decodedChar = String.fromCharCode(127); } else { return null; } break; case 'c': if (nextChar >= 'A' && nextChar <= 'O') { decodedChar = String.fromCharCode(nextCharCode - 32); } else if (nextChar === 'Z') { decodedChar = ':'; } else { return null; } break; case 'd': if (nextChar >= 'A' && nextChar <= 'Z') { decodedChar = String.fromCharCode(nextCharCode + 32); } else { return null; } break; default: console.warn('* code_93_reader _decodeExtended hit default case, this may be an error', decodedChar); return null; } result.push(decodedChar); } else { result.push(_char2); } } return result; } }, { key: "_matchCheckChar", value: function _matchCheckChar(charArray, index, maxWeight) { var arrayToCheck = charArray.slice(0, index); var length = arrayToCheck.length; var weightedSums = arrayToCheck.reduce(function (sum, _char3, i) { var weight = (i * -1 + (length - 1)) % maxWeight + 1; var value = code_93_reader_ALPHABET.indexOf(_char3.charCodeAt(0)); return sum + weight * value; }, 0); var checkChar = code_93_reader_ALPHABET[weightedSums % 47]; return checkChar === charArray[index].charCodeAt(0); } }, { key: "_verifyChecksums", value: function _verifyChecksums(charArray) { return this._matchCheckChar(charArray, charArray.length - 2, 20) && this._matchCheckChar(charArray, charArray.length - 1, 15); } }, { key: "decode", value: function decode(row, start) { start = this._findStart(); if (!start) { return null; } var counters = new Uint16Array([0, 0, 0, 0, 0, 0]); var result = []; var nextStart = this._nextSet(this._row, start.end); var lastStart; var decodedChar; do { counters = this._toCounters(nextStart, counters); var pattern = this._toPattern(counters); if (pattern < 0) { return null; } decodedChar = this._patternToChar(pattern); if (decodedChar === null) { return null; } result.push(decodedChar); lastStart = nextStart; nextStart += array_helper.sum(counters); nextStart = this._nextSet(this._row, nextStart); } while (decodedChar !== '*'); result.pop(); if (!result.length) { return null; } if (!this._verifyEnd(lastStart, nextStart)) { return null; } if (!this._verifyChecksums(result)) { return null; } result = result.slice(0, result.length - 2); // yes, this is an assign inside an if. if ((result = this._decodeExtended(result)) === null) { return null; } return { code: result.join(''), start: start.start, end: nextStart, startInfo: start, decodedCodes: result, format: this.FORMAT }; } }]); }(barcode_reader); /* harmony default export */ var code_93_reader = (code_93_reader_Code93Reader); // CONCATENATED MODULE: ./src/reader/ean_reader.ts function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { defineProperty_default()(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function ean_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, ean_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function ean_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (ean_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } // const CODE_L_START = 0; var CODE_G_START = 10; var ean_reader_START_PATTERN = [1, 1, 1]; var MIDDLE_PATTERN = [1, 1, 1, 1, 1]; var EXTENSION_START_PATTERN = [1, 1, 2]; var ean_reader_CODE_PATTERN = [[3, 2, 1, 1], [2, 2, 2, 1], [2, 1, 2, 2], [1, 4, 1, 1], [1, 1, 3, 2], [1, 2, 3, 1], [1, 1, 1, 4], [1, 3, 1, 2], [1, 2, 1, 3], [3, 1, 1, 2], [1, 1, 2, 3], [1, 2, 2, 2], [2, 2, 1, 2], [1, 1, 4, 1], [2, 3, 1, 1], [1, 3, 2, 1], [4, 1, 1, 1], [2, 1, 3, 1], [3, 1, 2, 1], [2, 1, 1, 3]]; var CODE_FREQUENCY = [0, 11, 13, 14, 19, 25, 28, 21, 22, 26]; // const SINGLE_CODE_ERROR = 0.70; var AVG_CODE_ERROR = 0.48; var ean_reader_EANReader = /*#__PURE__*/function (_BarcodeReader) { // TODO: does this need to be in the class? function EANReader(config, supplements) { var _this; classCallCheck_default()(this, EANReader); _this = ean_reader_callSuper(this, EANReader, [merge_default()({ supplements: [] }, config), supplements]); defineProperty_default()(_this, "FORMAT", 'ean_13'); defineProperty_default()(_this, "SINGLE_CODE_ERROR", 0.70); defineProperty_default()(_this, "STOP_PATTERN", [1, 1, 1]); return _this; } inherits_default()(EANReader, _BarcodeReader); return createClass_default()(EANReader, [{ key: "_findPattern", value: function _findPattern(pattern, offset, isWhite, tryHarder) { var counter = new Array(pattern.length).fill(0); var bestMatch = { error: Number.MAX_VALUE, start: 0, end: 0 }; var epsilon = AVG_CODE_ERROR; // console.warn('* findPattern', pattern, offset, isWhite, tryHarder, epsilon); var counterPos = 0; if (!offset) { offset = this._nextSet(this._row); } var found = false; for (var i = offset; i < this._row.length; i++) { // console.warn(`* loop i=${offset} len=${this._row.length} isWhite=${isWhite} counterPos=${counterPos}`); if (this._row[i] ^ (isWhite ? 1 : 0)) { counter[counterPos] += 1; } else { if (counterPos === counter.length - 1) { var error = this._matchPattern(counter, pattern); // console.warn('* matchPattern', error, counter, pattern); if (error < epsilon && bestMatch.error && error < bestMatch.error) { found = true; bestMatch.error = error; bestMatch.start = i - counter.reduce(function (sum, value) { return sum + value; }, 0); bestMatch.end = i; // console.warn('* return bestMatch', JSON.stringify(bestMatch)); return bestMatch; } if (tryHarder) { for (var j = 0; j < counter.length - 2; j++) { counter[j] = counter[j + 2]; } counter[counter.length - 2] = 0; counter[counter.length - 1] = 0; counterPos--; } } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } if (found) { // console.warn('* return bestMatch', JSON.stringify(bestMatch)); } else { // console.warn('* return null'); } return found ? bestMatch : null; } // TODO: findPattern and decodeCode appear to share quite similar code, can it be reduced? }, { key: "_decodeCode", value: function _decodeCode(start, coderange) { // console.warn('* decodeCode', start, coderange); var counter = [0, 0, 0, 0]; var offset = start; var bestMatch = { error: Number.MAX_VALUE, code: -1, start: start, end: start }; var epsilon = AVG_CODE_ERROR; var isWhite = !this._row[offset]; var counterPos = 0; if (!coderange) { // console.warn('* decodeCode before length'); coderange = ean_reader_CODE_PATTERN.length; // console.warn('* decodeCode after length'); } var found = false; for (var i = offset; i < this._row.length; i++) { if (this._row[i] ^ (isWhite ? 1 : 0)) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { for (var code = 0; code < coderange; code++) { var error = this._matchPattern(counter, ean_reader_CODE_PATTERN[code]); bestMatch.end = i; if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } if (bestMatch.error > epsilon) { // console.warn('* return null'); return null; } // console.warn('* return bestMatch', JSON.stringify(bestMatch)); return bestMatch; } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return found ? bestMatch : null; } }, { key: "_findStart", value: function _findStart() { // console.warn('* findStart'); var offset = this._nextSet(this._row); var startInfo = null; while (!startInfo) { startInfo = this._findPattern(ean_reader_START_PATTERN, offset, false, true); // console.warn('* startInfo=', JSON.stringify(startInfo)); if (!startInfo) { return null; } var leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start); if (leadingWhitespaceStart >= 0) { if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) { // console.warn('* returning startInfo'); return startInfo; } } offset = startInfo.end; startInfo = null; } // console.warn('* returning null'); return null; } }, { key: "_calculateFirstDigit", value: function _calculateFirstDigit(codeFrequency) { // console.warn('* calculateFirstDigit', codeFrequency); for (var i = 0; i < CODE_FREQUENCY.length; i++) { if (codeFrequency === CODE_FREQUENCY[i]) { // console.warn('* returning', i); return i; } } // console.warn('* return null'); return null; } }, { key: "_decodePayload", value: function _decodePayload(inCode, result, decodedCodes) { // console.warn('* decodePayload', inCode, result, decodedCodes); var outCode = _objectSpread({}, inCode); var codeFrequency = 0x0; for (var i = 0; i < 6; i++) { outCode = this._decodeCode(outCode.end); // console.warn('* decodeCode=', outCode); if (!outCode) { // console.warn('* return null'); return null; } if (outCode.code >= CODE_G_START) { outCode.code -= CODE_G_START; codeFrequency |= 1 << 5 - i; } else { codeFrequency |= 0 << 5 - i; } result.push(outCode.code); decodedCodes.push(outCode); } var firstDigit = this._calculateFirstDigit(codeFrequency); // console.warn('* firstDigit=', firstDigit); if (firstDigit === null) { // console.warn('* return null'); return null; } result.unshift(firstDigit); var middlePattern = this._findPattern(MIDDLE_PATTERN, outCode.end, true, false); // console.warn('* findPattern=', JSON.stringify(middlePattern)); if (middlePattern === null || !middlePattern.end) { // console.warn('* return null'); return null; } decodedCodes.push(middlePattern); for (var _i = 0; _i < 6; _i++) { middlePattern = this._decodeCode(middlePattern.end, CODE_G_START); // console.warn('* decodeCode=', JSON.stringify(middlePattern)); if (!middlePattern) { // console.warn('* return null'); return null; } decodedCodes.push(middlePattern); result.push(middlePattern.code); } // console.warn('* end code=', JSON.stringify(middlePattern)); // console.warn('* end result=', JSON.stringify(result)); // console.warn('* end decodedCodes=', decodedCodes); return middlePattern; } }, { key: "_verifyTrailingWhitespace", value: function _verifyTrailingWhitespace(endInfo) { // console.warn('* verifyTrailingWhitespace', JSON.stringify(endInfo)); var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start); if (trailingWhitespaceEnd < this._row.length) { if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { // console.warn('* returning', JSON.stringify(endInfo)); return endInfo; } } // console.warn('* return null'); return null; } }, { key: "_findEnd", value: function _findEnd(offset, isWhite) { // console.warn('* findEnd', offset, isWhite); var endInfo = this._findPattern(this.STOP_PATTERN, offset, isWhite, false); return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null; } }, { key: "_checksum", value: function _checksum(result) { // console.warn('* _checksum', result); var sum = 0; for (var i = result.length - 2; i >= 0; i -= 2) { sum += result[i]; } sum *= 3; for (var _i2 = result.length - 1; _i2 >= 0; _i2 -= 2) { sum += result[_i2]; } // console.warn('* end checksum', sum % 10 === 0); return sum % 10 === 0; } }, { key: "_decodeExtensions", value: function _decodeExtensions(offset) { var start = this._nextSet(this._row, offset); var startInfo = this._findPattern(EXTENSION_START_PATTERN, start, false, false); if (startInfo === null) { return null; } // console.warn('* decodeExtensions', this.supplements); // console.warn('* there are ', this.supplements.length, ' supplements'); for (var i = 0; i < this.supplements.length; i++) { // console.warn('* extensions loop', i, this.supplements[i], this.supplements[i]._decode); try { var result = this.supplements[i].decode(this._row, startInfo.end); // console.warn('* decode result=', result); if (result !== null) { return { code: result.code, start: start, startInfo: startInfo, end: result.end, decodedCodes: result.decodedCodes, format: this.supplements[i].FORMAT }; } } catch (err) { console.error('* decodeExtensions error in ', this.supplements[i], ': ', err); } } // console.warn('* end decodeExtensions'); return null; } }, { key: "decode", value: function decode(row, start) { // console.warn('* decode', row); // console.warn('* decode', start); var result = new Array(); var decodedCodes = new Array(); var resultInfo = {}; var startInfo = this._findStart(); if (!startInfo) { return null; } var code = { start: startInfo.start, end: startInfo.end }; decodedCodes.push(code); code = this._decodePayload(code, result, decodedCodes); if (!code) { return null; } code = this._findEnd(code.end, false); if (!code) { return null; } decodedCodes.push(code); // Checksum if (!this._checksum(result)) { return null; } // console.warn('* this.supplements=', this.supplements); if (this.supplements.length > 0) { var supplement = this._decodeExtensions(code.end); // console.warn('* decodeExtensions returns', supplement); if (!supplement) { return null; } if (!supplement.decodedCodes) { return null; } var lastCode = supplement.decodedCodes[supplement.decodedCodes.length - 1]; var endInfo = { start: lastCode.start + ((lastCode.end - lastCode.start) / 2 | 0), end: lastCode.end }; if (!this._verifyTrailingWhitespace(endInfo)) { return null; } resultInfo = { supplement: supplement, code: result.join('') + supplement.code }; } return _objectSpread(_objectSpread({ code: result.join(''), start: startInfo.start, end: code.end, startInfo: startInfo, decodedCodes: decodedCodes }, resultInfo), {}, { format: this.FORMAT }); } }]); }(barcode_reader); /* harmony default export */ var ean_reader = (ean_reader_EANReader); // CONCATENATED MODULE: ./src/reader/ean_2_reader.ts function ean_2_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, ean_2_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function ean_2_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (ean_2_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var ean_2_reader_EAN2Reader = /*#__PURE__*/function (_EANReader) { function EAN2Reader() { var _this; classCallCheck_default()(this, EAN2Reader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = ean_2_reader_callSuper(this, EAN2Reader, [].concat(args)); defineProperty_default()(_this, "FORMAT", 'ean_2'); return _this; } inherits_default()(EAN2Reader, _EANReader); return createClass_default()(EAN2Reader, [{ key: "decode", value: function decode(row, start) { if (row) { this._row = row; } var codeFrequency = 0; var offset = start; var end = this._row.length; var result = []; var decodedCodes = []; var code = null; if (offset === undefined) { return null; } for (var i = 0; i < 2 && offset < end; i++) { code = this._decodeCode(offset); if (!code) { return null; } decodedCodes.push(code); result.push(code.code % 10); if (code.code >= CODE_G_START) { codeFrequency |= 1 << 1 - i; } if (i !== 1) { offset = this._nextSet(this._row, code.end); offset = this._nextUnset(this._row, offset); } } if (result.length !== 2 || parseInt(result.join('')) % 4 !== codeFrequency) { return null; } var startInfo = this._findStart(); return { code: result.join(''), decodedCodes: decodedCodes, end: code.end, format: this.FORMAT, startInfo: startInfo, start: startInfo.start }; } }]); }(ean_reader); ; /* harmony default export */ var ean_2_reader = (ean_2_reader_EAN2Reader); // CONCATENATED MODULE: ./src/reader/ean_5_reader.ts function ean_5_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, ean_5_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function ean_5_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (ean_5_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var CHECK_DIGIT_ENCODINGS = [24, 20, 18, 17, 12, 6, 3, 10, 9, 5]; function determineCheckDigit(codeFrequency) { for (var i = 0; i < 10; i++) { if (codeFrequency === CHECK_DIGIT_ENCODINGS[i]) { return i; } } return null; } function extensionChecksum(result) { var length = result.length; var sum = 0; for (var i = length - 2; i >= 0; i -= 2) { sum += result[i]; } sum *= 3; for (var _i = length - 1; _i >= 0; _i -= 2) { sum += result[_i]; } sum *= 3; return sum % 10; } var ean_5_reader_EAN5Reader = /*#__PURE__*/function (_EANReader) { function EAN5Reader() { var _this; classCallCheck_default()(this, EAN5Reader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = ean_5_reader_callSuper(this, EAN5Reader, [].concat(args)); defineProperty_default()(_this, "FORMAT", 'ean_5'); return _this; } inherits_default()(EAN5Reader, _EANReader); return createClass_default()(EAN5Reader, [{ key: "decode", value: function decode(row, start) { if (start === undefined) { return null; } if (row) { this._row = row; } var codeFrequency = 0; var offset = start; var end = this._row.length; var code = null; var result = []; var decodedCodes = []; for (var i = 0; i < 5 && offset < end; i++) { code = this._decodeCode(offset); if (!code) { return null; } decodedCodes.push(code); result.push(code.code % 10); if (code.code >= CODE_G_START) { codeFrequency |= 1 << 4 - i; } if (i !== 4) { offset = this._nextSet(this._row, code.end); offset = this._nextUnset(this._row, offset); } } if (result.length !== 5) { return null; } if (extensionChecksum(result) !== determineCheckDigit(codeFrequency)) { return null; } var startInfo = this._findStart(); return { code: result.join(''), decodedCodes: decodedCodes, end: code.end, format: this.FORMAT, startInfo: startInfo, start: startInfo.start }; } }]); }(ean_reader); ; /* harmony default export */ var ean_5_reader = (ean_5_reader_EAN5Reader); // CONCATENATED MODULE: ./src/reader/ean_8_reader.ts function ean_8_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, ean_8_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function ean_8_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (ean_8_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var ean_8_reader_EAN8Reader = /*#__PURE__*/function (_EANReader) { function EAN8Reader() { var _this; classCallCheck_default()(this, EAN8Reader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = ean_8_reader_callSuper(this, EAN8Reader, [].concat(args)); defineProperty_default()(_this, "FORMAT", 'ean_8'); return _this; } inherits_default()(EAN8Reader, _EANReader); return createClass_default()(EAN8Reader, [{ key: "_decodePayload", value: function _decodePayload(inCode, result, decodedCodes) { var code = inCode; for (var i = 0; i < 4; i++) { code = this._decodeCode(code.end, CODE_G_START); if (!code) { return null; } result.push(code.code); decodedCodes.push(code); } code = this._findPattern(MIDDLE_PATTERN, code.end, true, false); if (code === null) { return null; } decodedCodes.push(code); for (var _i = 0; _i < 4; _i++) { code = this._decodeCode(code.end, CODE_G_START); if (!code) { return null; } decodedCodes.push(code); result.push(code.code); } return code; } }]); }(ean_reader); /* harmony default export */ var ean_8_reader = (ean_8_reader_EAN8Reader); // CONCATENATED MODULE: ./src/reader/i2of5_reader.ts function i2of5_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, i2of5_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function i2of5_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (i2of5_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } function i2of5_reader_superPropGet(t, o, e, r) { var p = get_default()(getPrototypeOf_default()(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } // TODO: i2of5_reader and 2of5_reader share very similar code, make use of that var i2of5_reader_N = 1; var i2of5_reader_W = 3; var i2of5_reader_I2of5Reader = /*#__PURE__*/function (_BarcodeReader) { function I2of5Reader(opts) { var _this; classCallCheck_default()(this, I2of5Reader); _this = i2of5_reader_callSuper(this, I2of5Reader, [merge_default()({ normalizeBarSpaceWidth: false }, opts)]); defineProperty_default()(_this, "barSpaceRatio", [1, 1]); defineProperty_default()(_this, "SINGLE_CODE_ERROR", 0.78); defineProperty_default()(_this, "AVG_CODE_ERROR", 0.38); defineProperty_default()(_this, "START_PATTERN", [i2of5_reader_N, i2of5_reader_N, i2of5_reader_N, i2of5_reader_N]); defineProperty_default()(_this, "STOP_PATTERN", [i2of5_reader_N, i2of5_reader_N, i2of5_reader_W]); defineProperty_default()(_this, "CODE_PATTERN", [[i2of5_reader_N, i2of5_reader_N, i2of5_reader_W, i2of5_reader_W, i2of5_reader_N], [i2of5_reader_W, i2of5_reader_N, i2of5_reader_N, i2of5_reader_N, i2of5_reader_W], [i2of5_reader_N, i2of5_reader_W, i2of5_reader_N, i2of5_reader_N, i2of5_reader_W], [i2of5_reader_W, i2of5_reader_W, i2of5_reader_N, i2of5_reader_N, i2of5_reader_N], [i2of5_reader_N, i2of5_reader_N, i2of5_reader_W, i2of5_reader_N, i2of5_reader_W], [i2of5_reader_W, i2of5_reader_N, i2of5_reader_W, i2of5_reader_N, i2of5_reader_N], [i2of5_reader_N, i2of5_reader_W, i2of5_reader_W, i2of5_reader_N, i2of5_reader_N], [i2of5_reader_N, i2of5_reader_N, i2of5_reader_N, i2of5_reader_W, i2of5_reader_W], [i2of5_reader_W, i2of5_reader_N, i2of5_reader_N, i2of5_reader_W, i2of5_reader_N], [i2of5_reader_N, i2of5_reader_W, i2of5_reader_N, i2of5_reader_W, i2of5_reader_N]]); defineProperty_default()(_this, "MAX_CORRECTION_FACTOR", 5); defineProperty_default()(_this, "FORMAT", 'i2of5'); if (opts.normalizeBarSpaceWidth) { _this.SINGLE_CODE_ERROR = 0.38; _this.AVG_CODE_ERROR = 0.09; } _this.config = opts; return possibleConstructorReturn_default()(_this, _this); } inherits_default()(I2of5Reader, _BarcodeReader); return createClass_default()(I2of5Reader, [{ key: "_matchPattern", value: function _matchPattern(counter, code) { if (this.config.normalizeBarSpaceWidth) { var counterSum = [0, 0]; var codeSum = [0, 0]; var correction = [0, 0]; var correctionRatio = this.MAX_CORRECTION_FACTOR; var correctionRatioInverse = 1 / correctionRatio; for (var i = 0; i < counter.length; i++) { counterSum[i % 2] += counter[i]; codeSum[i % 2] += code[i]; } correction[0] = codeSum[0] / counterSum[0]; correction[1] = codeSum[1] / counterSum[1]; correction[0] = Math.max(Math.min(correction[0], correctionRatio), correctionRatioInverse); correction[1] = Math.max(Math.min(correction[1], correctionRatio), correctionRatioInverse); this.barSpaceRatio = correction; for (var _i = 0; _i < counter.length; _i++) { counter[_i] *= this.barSpaceRatio[_i % 2]; } } return i2of5_reader_superPropGet(I2of5Reader, "_matchPattern", this, 3)([counter, code]); } }, { key: "_findPattern", value: function _findPattern(pattern, offset) { var isWhite = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; var tryHarder = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; var counter = new Array(pattern.length).fill(0); var counterPos = 0; var bestMatch = { error: Number.MAX_VALUE, start: 0, end: 0 }; var epsilon = this.AVG_CODE_ERROR; isWhite = isWhite || false; tryHarder = tryHarder || false; if (!offset) { offset = this._nextSet(this._row); } for (var i = offset; i < this._row.length; i++) { if (this._row[i] ^ (isWhite ? 1 : 0)) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { var sum = counter.reduce(function (prev, next) { return prev + next; }, 0); var error = this._matchPattern(counter, pattern); if (error < epsilon) { bestMatch.error = error; bestMatch.start = i - sum; bestMatch.end = i; return bestMatch; } if (tryHarder) { for (var j = 0; j < counter.length - 2; j++) { counter[j] = counter[j + 2]; } counter[counter.length - 2] = 0; counter[counter.length - 1] = 0; counterPos--; } else { return null; } } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return null; } }, { key: "_findStart", value: function _findStart() { var leadingWhitespaceStart = 0; var offset = this._nextSet(this._row); var startInfo = null; var narrowBarWidth = 1; while (!startInfo) { startInfo = this._findPattern(this.START_PATTERN, offset, false, true); if (!startInfo) { return null; } narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / 4); leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10; if (leadingWhitespaceStart >= 0) { if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) { return startInfo; } } offset = startInfo.end; startInfo = null; } return null; } }, { key: "_verifyTrailingWhitespace", value: function _verifyTrailingWhitespace(endInfo) { var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; if (trailingWhitespaceEnd < this._row.length) { if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { return endInfo; } } return null; } }, { key: "_findEnd", value: function _findEnd() { this._row.reverse(); var endInfo = this._findPattern(this.STOP_PATTERN); this._row.reverse(); if (endInfo === null) { return null; } // reverse numbers var tmp = endInfo.start; endInfo.start = this._row.length - endInfo.end; endInfo.end = this._row.length - tmp; return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null; } }, { key: "_decodePair", value: function _decodePair(counterPair) { var codes = []; for (var i = 0; i < counterPair.length; i++) { var code = this._decodeCode(counterPair[i]); if (!code) { return null; } codes.push(code); } return codes; } }, { key: "_decodeCode", value: function _decodeCode(counter) { var epsilon = this.AVG_CODE_ERROR; var bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0 }; for (var code = 0; code < this.CODE_PATTERN.length; code++) { var error = this._matchPattern(counter, this.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } if (bestMatch.error < epsilon) { return bestMatch; } return null; } }, { key: "_decodePayload", value: function _decodePayload(counters, result, decodedCodes) { var pos = 0; var counterLength = counters.length; var counterPair = [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0]]; var codes = null; while (pos < counterLength) { for (var i = 0; i < 5; i++) { counterPair[0][i] = counters[pos] * this.barSpaceRatio[0]; counterPair[1][i] = counters[pos + 1] * this.barSpaceRatio[1]; pos += 2; } codes = this._decodePair(counterPair); if (!codes) { return null; } for (var _i2 = 0; _i2 < codes.length; _i2++) { result.push(codes[_i2].code + ''); decodedCodes.push(codes[_i2]); } } return codes; } }, { key: "_verifyCounterLength", value: function _verifyCounterLength(counters) { return counters.length % 10 === 0; } }, { key: "decode", value: function decode(row, start) { var result = new Array(); var decodedCodes = new Array(); var startInfo = this._findStart(); if (!startInfo) { return null; } decodedCodes.push(startInfo); var endInfo = this._findEnd(); if (!endInfo) { return null; } var counters = this._fillCounters(startInfo.end, endInfo.start, false); if (!this._verifyCounterLength(counters)) { return null; } var code = this._decodePayload(counters, result, decodedCodes); if (!code) { return null; } if (result.length % 2 !== 0 || result.length < 6) { return null; } decodedCodes.push(endInfo); return { code: result.join(''), start: startInfo.start, end: endInfo.end, startInfo: startInfo, decodedCodes: decodedCodes, format: this.FORMAT }; } }]); }(barcode_reader); /* harmony default export */ var i2of5_reader = (i2of5_reader_I2of5Reader); // CONCATENATED MODULE: ./src/reader/upc_e_reader.ts function upc_e_reader_ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function upc_e_reader_objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? upc_e_reader_ownKeys(Object(t), !0).forEach(function (r) { defineProperty_default()(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : upc_e_reader_ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function upc_e_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, upc_e_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function upc_e_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (upc_e_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } function upc_e_reader_superPropGet(t, o, e, r) { var p = get_default()(getPrototypeOf_default()(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } var upc_e_reader_UPCEReader = /*#__PURE__*/function (_EANReader) { function UPCEReader() { var _this; classCallCheck_default()(this, UPCEReader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = upc_e_reader_callSuper(this, UPCEReader, [].concat(args)); defineProperty_default()(_this, "CODE_FREQUENCY", [[56, 52, 50, 49, 44, 38, 35, 42, 41, 37], [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]]); defineProperty_default()(_this, "STOP_PATTERN", [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7]); defineProperty_default()(_this, "FORMAT", 'upc_e'); return _this; } inherits_default()(UPCEReader, _EANReader); return createClass_default()(UPCEReader, [{ key: "_decodePayload", value: function _decodePayload(inCode, result, decodedCodes) { var outCode = upc_e_reader_objectSpread({}, inCode); var codeFrequency = 0x0; for (var i = 0; i < 6; i++) { outCode = this._decodeCode(outCode.end); if (!outCode) { return null; } if (outCode.code >= CODE_G_START) { outCode.code = outCode.code - CODE_G_START; codeFrequency |= 1 << 5 - i; } result.push(outCode.code); decodedCodes.push(outCode); } if (!this._determineParity(codeFrequency, result)) { return null; } return outCode; } }, { key: "_determineParity", value: function _determineParity(codeFrequency, result) { for (var nrSystem = 0; nrSystem < this.CODE_FREQUENCY.length; nrSystem++) { for (var i = 0; i < this.CODE_FREQUENCY[nrSystem].length; i++) { if (codeFrequency === this.CODE_FREQUENCY[nrSystem][i]) { result.unshift(nrSystem); result.push(i); return true; } } } return false; } }, { key: "_convertToUPCA", value: function _convertToUPCA(result) { var upca = [result[0]]; var lastDigit = result[result.length - 2]; if (lastDigit <= 2) { upca = upca.concat(result.slice(1, 3)).concat([lastDigit, 0, 0, 0, 0]).concat(result.slice(3, 6)); } else if (lastDigit === 3) { upca = upca.concat(result.slice(1, 4)).concat([0, 0, 0, 0, 0]).concat(result.slice(4, 6)); } else if (lastDigit === 4) { upca = upca.concat(result.slice(1, 5)).concat([0, 0, 0, 0, 0, result[5]]); } else { upca = upca.concat(result.slice(1, 6)).concat([0, 0, 0, 0, lastDigit]); } upca.push(result[result.length - 1]); return upca; } }, { key: "_checksum", value: function _checksum(result) { return upc_e_reader_superPropGet(UPCEReader, "_checksum", this, 3)([this._convertToUPCA(result)]); } }, { key: "_findEnd", value: function _findEnd(offset, isWhite) { return upc_e_reader_superPropGet(UPCEReader, "_findEnd", this, 3)([offset, true]); } }, { key: "_verifyTrailingWhitespace", value: function _verifyTrailingWhitespace(endInfo) { var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; if (trailingWhitespaceEnd < this._row.length) { if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { return endInfo; } } return null; } }]); }(ean_reader); /* harmony default export */ var upc_e_reader = (upc_e_reader_UPCEReader); // CONCATENATED MODULE: ./src/reader/upc_reader.ts function upc_reader_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, upc_reader_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function upc_reader_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (upc_reader_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var upc_reader_UPCReader = /*#__PURE__*/function (_EANReader) { function UPCReader() { var _this; classCallCheck_default()(this, UPCReader); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = upc_reader_callSuper(this, UPCReader, [].concat(args)); defineProperty_default()(_this, "FORMAT", 'upc_a'); return _this; } inherits_default()(UPCReader, _EANReader); return createClass_default()(UPCReader, [{ key: "decode", value: function decode(row, start) { var result = ean_reader.prototype.decode.call(this); if (result && result.code && result.code.length === 13 && result.code.charAt(0) === '0') { result.code = result.code.substring(1); return result; } return null; } }]); }(ean_reader); /* harmony default export */ var upc_reader = (upc_reader_UPCReader); // CONCATENATED MODULE: ./src/decoder/bresenham.js var Bresenham = {}; var Slope = { DIR: { UP: 1, DOWN: -1 } }; /** * Scans a line of the given image from point p1 to p2 and returns a result object containing * gray-scale values (0-255) of the underlying pixels in addition to the min * and max values. * @param {Object} imageWrapper * @param {Object} p1 The start point {x,y} * @param {Object} p2 The end point {x,y} * @returns {line, min, max} */ Bresenham.getBarcodeLine = function (imageWrapper, p1, p2) { /* eslint-disable no-bitwise */ var x0 = p1.x | 0; var y0 = p1.y | 0; var x1 = p2.x | 0; var y1 = p2.y | 0; /* eslint-disable no-bitwise */ var steep = Math.abs(y1 - y0) > Math.abs(x1 - x0); var error; var y; var tmp; var x; var line = []; var imageData = imageWrapper.data; var width = imageWrapper.size.x; var val; var min = 255; var max = 0; function read(a, b) { val = imageData[b * width + a]; min = val < min ? val : min; max = val > max ? val : max; line.push(val); } if (steep) { tmp = x0; x0 = y0; y0 = tmp; tmp = x1; x1 = y1; y1 = tmp; } if (x0 > x1) { tmp = x0; x0 = x1; x1 = tmp; tmp = y0; y0 = y1; y1 = tmp; } var deltaX = x1 - x0; var deltaY = Math.abs(y1 - y0); error = deltaX / 2 | 0; y = y0; var yStep = y0 < y1 ? 1 : -1; for (x = x0; x < x1; x++) { if (steep) { read(y, x); } else { read(x, y); } error -= deltaY; if (error < 0) { y += yStep; error += deltaX; } } return { line: line, min: min, max: max }; }; /** * Converts the result from getBarcodeLine into a binary representation * also considering the frequency and slope of the signal for more robust results * @param {Object} result {line, min, max} */ Bresenham.toBinaryLine = function (result) { var min = result.min; var max = result.max; var line = result.line; var slope; var slope2; var center = min + (max - min) / 2; var extrema = []; var currentDir; var dir; var threshold = (max - min) / 12; var rThreshold = -threshold; var i; var j; // 1. find extrema currentDir = line[0] > center ? Slope.DIR.UP : Slope.DIR.DOWN; extrema.push({ pos: 0, val: line[0] }); for (i = 0; i < line.length - 2; i++) { slope = line[i + 1] - line[i]; slope2 = line[i + 2] - line[i + 1]; if (slope + slope2 < rThreshold && line[i + 1] < center * 1.5) { dir = Slope.DIR.DOWN; } else if (slope + slope2 > threshold && line[i + 1] > center * 0.5) { dir = Slope.DIR.UP; } else { dir = currentDir; } if (currentDir !== dir) { extrema.push({ pos: i, val: line[i] }); currentDir = dir; } } extrema.push({ pos: line.length, val: line[line.length - 1] }); for (j = extrema[0].pos; j < extrema[1].pos; j++) { line[j] = line[j] > center ? 0 : 1; } // iterate over extrema and convert to binary based on avg between minmax for (i = 1; i < extrema.length - 1; i++) { if (extrema[i + 1].val > extrema[i].val) { threshold = extrema[i].val + (extrema[i + 1].val - extrema[i].val) / 3 * 2 | 0; } else { threshold = extrema[i + 1].val + (extrema[i].val - extrema[i + 1].val) / 3 | 0; } for (j = extrema[i].pos; j < extrema[i + 1].pos; j++) { line[j] = line[j] > threshold ? 0 : 1; } } return { line: line, threshold: threshold }; }; /** * Used for development only */ Bresenham.debug = { printFrequency: function printFrequency(line, canvas) { var i; var ctx = canvas.getContext('2d'); // eslint-disable-next-line no-param-reassign canvas.width = line.length; // eslint-disable-next-line no-param-reassign canvas.height = 256; ctx.beginPath(); ctx.strokeStyle = 'blue'; for (i = 0; i < line.length; i++) { ctx.moveTo(i, 255); ctx.lineTo(i, 255 - line[i]); } ctx.stroke(); ctx.closePath(); }, printPattern: function printPattern(line, canvas) { var ctx = canvas.getContext('2d'); var i; // eslint-disable-next-line no-param-reassign canvas.width = line.length; ctx.fillColor = 'black'; for (i = 0; i < line.length; i++) { if (line[i] === 1) { ctx.fillRect(i, 0, 1, 100); } } } }; /* harmony default export */ var bresenham = (Bresenham); // CONCATENATED MODULE: ./src/decoder/barcode_decoder.js function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } /* eslint-disable import/no-cycle */ var READERS = { code_128_reader: code_128_reader, ean_reader: ean_reader, ean_5_reader: ean_5_reader, ean_2_reader: ean_2_reader, ean_8_reader: ean_8_reader, code_39_reader: code_39_reader, code_39_vin_reader: code_39_vin_reader, codabar_reader: codabar_reader, upc_reader: upc_reader, upc_e_reader: upc_e_reader, i2of5_reader: i2of5_reader, '2of5_reader': _2of5_reader, code_93_reader: code_93_reader, code_32_reader: code_32_reader }; /* harmony default export */ var barcode_decoder = ({ registerReader: function registerReader(name, reader) { READERS[name] = reader; }, create: function create(config, inputImageWrapper) { var _canvas = { ctx: { frequency: null, pattern: null, overlay: null }, dom: { frequency: null, pattern: null, overlay: null } }; var _barcodeReaders = []; initCanvas(); initReaders(); initConfig(); function initCanvas() { if ( true && typeof document !== 'undefined') { var _config$debug; var $debug = document.querySelector('#debug.detection'); _canvas.dom.frequency = document.querySelector('canvas.frequency'); if (!_canvas.dom.frequency) { _canvas.dom.frequency = document.createElement('canvas'); _canvas.dom.frequency.className = 'frequency'; if ($debug) { $debug.appendChild(_canvas.dom.frequency); } } if ( true && (_config$debug = config.debug) !== null && _config$debug !== void 0 && _config$debug.printReaderInfo) { console.warn('* barcode decoder initCanvas getcontext 2d'); } _canvas.ctx.frequency = _canvas.dom.frequency.getContext('2d'); _canvas.dom.pattern = document.querySelector('canvas.patternBuffer'); if (!_canvas.dom.pattern) { _canvas.dom.pattern = document.createElement('canvas'); _canvas.dom.pattern.className = 'patternBuffer'; if ($debug) { $debug.appendChild(_canvas.dom.pattern); } } _canvas.ctx.pattern = _canvas.dom.pattern.getContext('2d'); _canvas.dom.overlay = document.querySelector('canvas.drawingBuffer'); if (_canvas.dom.overlay) { _canvas.ctx.overlay = _canvas.dom.overlay.getContext('2d'); } } } function initReaders() { var _config$debug3; config.readers.forEach(function (readerConfig) { var _config$debug2; var reader; var configuration = {}; var supplements = []; if (typeof_default()(readerConfig) === 'object') { reader = readerConfig.format; configuration = readerConfig.config; } else if (typeof readerConfig === 'string') { reader = readerConfig; } if ( true && (_config$debug2 = config.debug) !== null && _config$debug2 !== void 0 && _config$debug2.printReaderInfo) { console.log('Before registering reader: ', reader); } if (configuration.supplements) { supplements = configuration.supplements.map(function (supplement) { return new READERS[supplement](); }); } try { var readerObj = new READERS[reader](configuration, supplements); _barcodeReaders.push(readerObj); } catch (err) { console.error('* Error constructing reader ', reader, err); throw err; } }); if ( true && (_config$debug3 = config.debug) !== null && _config$debug3 !== void 0 && _config$debug3.printReaderInfo) { console.log("Registered Readers: ".concat(_barcodeReaders.map(function (reader) { return JSON.stringify({ format: reader.FORMAT, config: reader.config }); }).join(', '))); } } function initConfig() { if ( true && typeof document !== 'undefined') { var i; var vis = [{ node: _canvas.dom.frequency, prop: config.debug.showFrequency }, { node: _canvas.dom.pattern, prop: config.debug.showPattern }]; for (i = 0; i < vis.length; i++) { if (vis[i].prop === true) { vis[i].node.style.display = 'block'; } else { vis[i].node.style.display = 'none'; } } } } /** * extend the line on both ends * @param {Array} line * @param {Number} angle */ function getExtendedLine(line, angle, ext) { function extendLine(amount) { var extension = { y: amount * Math.sin(angle), x: amount * Math.cos(angle) }; /* eslint-disable no-param-reassign */ line[0].y -= extension.y; line[0].x -= extension.x; line[1].y += extension.y; line[1].x += extension.x; /* eslint-enable no-param-reassign */ } // check if inside image extendLine(ext); while (ext > 1 && (!inputImageWrapper.inImageWithBorder(line[0]) || !inputImageWrapper.inImageWithBorder(line[1]))) { // eslint-disable-next-line no-param-reassign ext -= Math.ceil(ext / 2); extendLine(-ext); } return line; } function getLine(box) { return [{ x: (box[1][0] - box[0][0]) / 2 + box[0][0], y: (box[1][1] - box[0][1]) / 2 + box[0][1] }, { x: (box[3][0] - box[2][0]) / 2 + box[2][0], y: (box[3][1] - box[2][1]) / 2 + box[2][1] }]; } function tryDecode(line) { var result = null; var i; var barcodeLine = bresenham.getBarcodeLine(inputImageWrapper, line[0], line[1]); if ( true && config.debug.showFrequency) { image_debug.drawPath(line, { x: 'x', y: 'y' }, _canvas.ctx.overlay, { color: 'red', lineWidth: 3 }); bresenham.debug.printFrequency(barcodeLine.line, _canvas.dom.frequency); } bresenham.toBinaryLine(barcodeLine); if ( true && config.debug.showPattern) { bresenham.debug.printPattern(barcodeLine.line, _canvas.dom.pattern); } for (i = 0; i < _barcodeReaders.length && result === null; i++) { result = _barcodeReaders[i].decodePattern(barcodeLine.line); } if (result === null) { return null; } return { codeResult: result, barcodeLine: barcodeLine }; } /** * This method slices the given area apart and tries to detect a barcode-pattern * for each slice. It returns the decoded barcode, or null if nothing was found * @param {Array} box * @param {Array} line * @param {Number} lineAngle */ function tryDecodeBruteForce(box, line, lineAngle) { var sideLength = Math.sqrt(Math.pow(box[1][0] - box[0][0], 2) + Math.pow(box[1][1] - box[0][1], 2)); var i; var slices = 16; var result = null; var dir; var extension; var xdir = Math.sin(lineAngle); var ydir = Math.cos(lineAngle); for (i = 1; i < slices && result === null; i++) { // move line perpendicular to angle // eslint-disable-next-line no-mixed-operators dir = sideLength / slices * i * (i % 2 === 0 ? -1 : 1); extension = { y: dir * xdir, x: dir * ydir }; /* eslint-disable no-param-reassign */ line[0].y += extension.x; line[0].x -= extension.y; line[1].y += extension.x; line[1].x -= extension.y; /* eslint-enable no-param-reassign */ result = tryDecode(line); } return result; } function getLineLength(line) { return Math.sqrt(Math.pow(Math.abs(line[1].y - line[0].y), 2) + Math.pow(Math.abs(line[1].x - line[0].x), 2)); } function _decodeFromImage2(_x) { return _decodeFromImage.apply(this, arguments); } /** * With the help of the configured readers (Code128 or EAN) this function tries to detect a * valid barcode pattern within the given area. * @param {Object} box The area to search in * @returns {Object} the result {codeResult, line, angle, pattern, threshold} */ function _decodeFromImage() { _decodeFromImage = asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee2(imageWrapper) { var result, _iterator, _step, reader, _t; return regenerator_default.a.wrap(function (_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: result = null; _iterator = _createForOfIteratorHelper(_barcodeReaders); _context2.prev = 1; _iterator.s(); case 2: if ((_step = _iterator.n()).done) { _context2.next = 5; break; } reader = _step.value; if (!reader.decodeImage) { _context2.next = 4; break; } _context2.next = 3; return reader.decodeImage(imageWrapper); case 3: result = _context2.sent; if (!result) { _context2.next = 4; break; } return _context2.abrupt("continue", 5); case 4: _context2.next = 2; break; case 5: _context2.next = 7; break; case 6: _context2.prev = 6; _t = _context2["catch"](1); _iterator.e(_t); case 7: _context2.prev = 7; _iterator.f(); return _context2.finish(7); case 8: return _context2.abrupt("return", result); case 9: case "end": return _context2.stop(); } }, _callee2, null, [[1, 6, 7, 8]]); })); return _decodeFromImage.apply(this, arguments); } function _decodeFromBoundingBox(box) { var line; var ctx = _canvas.ctx.overlay; var result; if (true) { if (config.debug.drawBoundingBox && ctx) { image_debug.drawPath(box, { x: 0, y: 1 }, ctx, { color: 'blue', lineWidth: 2 }); } } line = getLine(box); var lineLength = getLineLength(line); var lineAngle = Math.atan2(line[1].y - line[0].y, line[1].x - line[0].x); line = getExtendedLine(line, lineAngle, Math.floor(lineLength * 0.1)); if (line === null) { return null; } result = tryDecode(line); if (result === null) { result = tryDecodeBruteForce(box, line, lineAngle); } if (result === null) { return null; } if ( true && result && config.debug.drawScanline && ctx) { image_debug.drawPath(line, { x: 'x', y: 'y' }, ctx, { color: 'red', lineWidth: 3 }); } return { codeResult: result.codeResult, line: line, angle: lineAngle, pattern: result.barcodeLine.line, threshold: result.barcodeLine.threshold }; } return { decodeFromBoundingBox: function decodeFromBoundingBox(box) { return _decodeFromBoundingBox(box); }, decodeFromBoundingBoxes: function decodeFromBoundingBoxes(boxes) { var i; var result; var barcodes = []; var multiple = config.multiple; for (i = 0; i < boxes.length; i++) { var box = boxes[i]; result = _decodeFromBoundingBox(box) || {}; result.box = box; if (multiple) { barcodes.push(result); } else if (result.codeResult) { return result; } } return { barcodes: barcodes }; }, decodeFromImage: function decodeFromImage(imageWrapperIn) { return asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee() { var result; return regenerator_default.a.wrap(function (_context) { while (1) switch (_context.prev = _context.next) { case 0: _context.next = 1; return _decodeFromImage2(imageWrapperIn); case 1: result = _context.sent; return _context.abrupt("return", result); case 2: case "end": return _context.stop(); } }, _callee); }))(); }, registerReader: function registerReader(name, reader) { if (READERS[name]) { throw new Error('cannot register existing reader', name); } READERS[name] = reader; }, setReaders: function setReaders(readers) { // eslint-disable-next-line no-param-reassign config.readers = readers; _barcodeReaders.length = 0; initReaders(); } }; } }); // CONCATENATED MODULE: ./src/reader/index.ts // CONCATENATED MODULE: ./src/common/events.ts /* harmony default export */ var events = ((function EventInterface() { var events = {}; function getEvent(eventName) { if (!events[eventName]) { events[eventName] = { subscribers: [] }; } return events[eventName]; } function clearEvents() { events = {}; } function publishSubscription(subscription, data) { if (subscription.async) { setTimeout(function () { subscription.callback(data); }, 4); } else { subscription.callback(data); } } function _subscribe(event, callback, async) { var subscription; if (typeof callback === 'function') { subscription = { callback: callback, async: async }; } else { subscription = callback; if (!subscription.callback) { throw new Error('Callback was not specified on options'); } } getEvent(event).subscribers.push(subscription); } return { subscribe: function subscribe(event, callback, async) { return _subscribe(event, callback, async); }, publish: function publish(eventName, data) { var event = getEvent(eventName); var subscribers = event.subscribers; // Publish one-time subscriptions subscribers.filter(function (subscriber) { return !!subscriber.once; }).forEach(function (subscriber) { publishSubscription(subscriber, data); }); // remove them from the subscriber event.subscribers = subscribers.filter(function (subscriber) { return !subscriber.once; }); // publish the rest event.subscribers.forEach(function (subscriber) { publishSubscription(subscriber, data); }); }, once: function once(event, callback) { var async = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; _subscribe(event, { callback: callback, async: async, once: true }); }, unsubscribe: function unsubscribe(eventName, callback) { if (eventName) { var _event = getEvent(eventName); if (_event && callback) { _event.subscribers = _event.subscribers.filter(function (subscriber) { return subscriber.callback !== callback; }); } else { _event.subscribers = []; } } else { clearEvents(); } } }; })()); // EXTERNAL MODULE: ./node_modules/lodash/pick.js var pick = __webpack_require__(59); var pick_default = /*#__PURE__*/__webpack_require__.n(pick); // EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/wrapNativeSuper.js var wrapNativeSuper = __webpack_require__(60); var wrapNativeSuper_default = /*#__PURE__*/__webpack_require__.n(wrapNativeSuper); // CONCATENATED MODULE: ./src/quagga/Exception.ts function Exception_callSuper(t, o, e) { return o = getPrototypeOf_default()(o), possibleConstructorReturn_default()(t, Exception_isNativeReflectConstruct() ? Reflect.construct(o, e || [], getPrototypeOf_default()(t).constructor) : o.apply(t, e)); } function Exception_isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (Exception_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var Exception_Exception = /*#__PURE__*/function (_Error) { function Exception(m, code) { var _this; classCallCheck_default()(this, Exception); _this = Exception_callSuper(this, Exception, [m]); defineProperty_default()(_this, "code", void 0); _this.code = code; Object.setPrototypeOf(_this, Exception.prototype); return _this; } inherits_default()(Exception, _Error); return createClass_default()(Exception); }(/*#__PURE__*/wrapNativeSuper_default()(Error)); // CONCATENATED MODULE: ./src/common/mediaDevices.ts var ERROR_DESC = 'This may mean that the user has declined camera access, or the browser does not support media APIs. If you are running in iOS, you must use Safari.'; function enumerateDevices() { try { return navigator.mediaDevices.enumerateDevices(); } catch (err) { var error = new Exception_Exception("enumerateDevices is not defined. ".concat(ERROR_DESC), -1); return Promise.reject(error); } } function getUserMedia(constraints) { try { return navigator.mediaDevices.getUserMedia(constraints); } catch (err) { var error = new Exception_Exception("getUserMedia is not defined. ".concat(ERROR_DESC), -1); return Promise.reject(error); } } // CONCATENATED MODULE: ./src/input/camera_access.ts // TODO: when this file was written years ago, HTMLMediaElement.play() did not return a useful value // to let us know when the video started playing. Now, it does. So, we shouldn't need to run this // odd waitForVideo() function that polls to see if the video has started. var streamRef; function waitForVideo(video) { return new Promise(function (resolve, reject) { var attempts = 10; function checkVideo() { if (attempts > 0) { if (video.videoWidth > 10 && video.videoHeight > 10) { if (true) { console.log("* dev: checkVideo found ".concat(video.videoWidth, "px x ").concat(video.videoHeight, "px")); } resolve(); } else { window.setTimeout(checkVideo, 500); } } else { reject(new Exception_Exception('Unable to play video stream. Is webcam working?', -1)); // TODO: add error code } attempts--; } checkVideo(); }); } /** * Tries to attach the camera-stream to a given video-element * and calls the callback function when the content is ready * @param {Object} constraints * @param {Object} video */ function initCamera(_x, _x2) { return _initCamera.apply(this, arguments); } function _initCamera() { _initCamera = asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee4(video, constraints) { var stream; return regenerator_default.a.wrap(function (_context4) { while (1) switch (_context4.prev = _context4.next) { case 0: _context4.next = 1; return getUserMedia(constraints); case 1: stream = _context4.sent; streamRef = stream; if (!video) { _context4.next = 2; break; } video.setAttribute('autoplay', 'true'); video.setAttribute('muted', 'true'); video.setAttribute('playsinline', 'true'); // not listed on MDN... // eslint-disable-next-line no-param-reassign video.srcObject = stream; video.addEventListener('loadedmetadata', function () { video.play()["catch"](function (err) { console.warn('* Error while trying to play video stream:', err); }); }); return _context4.abrupt("return", waitForVideo(video)); case 2: return _context4.abrupt("return", Promise.resolve()); case 3: case "end": return _context4.stop(); } }, _callee4); })); return _initCamera.apply(this, arguments); } function deprecatedConstraints(videoConstraints) { var normalized = pick_default()(videoConstraints, ['width', 'height', 'facingMode', 'aspectRatio', 'deviceId']); if (typeof videoConstraints.minAspectRatio !== 'undefined' && videoConstraints.minAspectRatio > 0) { normalized.aspectRatio = videoConstraints.minAspectRatio; console.log('WARNING: Constraint \'minAspectRatio\' is deprecated; Use \'aspectRatio\' instead'); } if (typeof videoConstraints.facing !== 'undefined') { normalized.facingMode = videoConstraints.facing; console.log('WARNING: Constraint \'facing\' is deprecated. Use \'facingMode\' instead\''); } return normalized; } // TODO: #192 I don't think there's any good reason pickConstraints should return a Promise, // I think it was just that way so it could be chained to other functions that did return a Promise. // That's not necessary with async functions being a thing, so that should be fixed. function pickConstraints() { var videoConstraints = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var video = deprecatedConstraints(videoConstraints); if (video && video.deviceId && video.facingMode) { delete video.facingMode; } return Promise.resolve({ audio: false, video: video }); } function enumerateVideoDevices() { return _enumerateVideoDevices.apply(this, arguments); } function _enumerateVideoDevices() { _enumerateVideoDevices = asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee5() { var devices; return regenerator_default.a.wrap(function (_context5) { while (1) switch (_context5.prev = _context5.next) { case 0: _context5.next = 1; return enumerateDevices(); case 1: devices = _context5.sent; return _context5.abrupt("return", devices.filter(function (device) { return device.kind === 'videoinput'; })); case 2: case "end": return _context5.stop(); } }, _callee5); })); return _enumerateVideoDevices.apply(this, arguments); } function getActiveTrack() { if (!streamRef) { return null; } var tracks = streamRef.getVideoTracks(); return tracks && tracks !== null && tracks !== void 0 && tracks.length ? tracks[0] : null; } /** * Used for accessing information about the active stream track and available video devices. */ var QuaggaJSCameraAccess = { requestedVideoElement: null, request: function request(video, videoConstraints) { return asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee() { var newConstraints; return regenerator_default.a.wrap(function (_context) { while (1) switch (_context.prev = _context.next) { case 0: QuaggaJSCameraAccess.requestedVideoElement = video; _context.next = 1; return pickConstraints(videoConstraints); case 1: newConstraints = _context.sent; return _context.abrupt("return", initCamera(video, newConstraints)); case 2: case "end": return _context.stop(); } }, _callee); }))(); }, release: function release() { var tracks = streamRef && streamRef.getVideoTracks(); if (QuaggaJSCameraAccess.requestedVideoElement !== null) { QuaggaJSCameraAccess.requestedVideoElement.pause(); } return new Promise(function (resolve) { setTimeout(function () { if (tracks && tracks.length) { tracks.forEach(function (track) { return track.stop(); }); } streamRef = null; QuaggaJSCameraAccess.requestedVideoElement = null; resolve(); }, 0); }); }, enumerateVideoDevices: enumerateVideoDevices, getActiveStreamLabel: function getActiveStreamLabel() { var track = getActiveTrack(); return track ? track.label : ''; }, getActiveTrack: getActiveTrack, disableTorch: function disableTorch() { return asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee2() { var track, _t; return regenerator_default.a.wrap(function (_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: track = getActiveTrack(); // TODO: should we acquire camera access even if there's no current camera open? // TODO: what happens on iOS or another device where torch isn't supported at all? Should we throw an error? if (!track) { _context2.next = 4; break; } _context2.prev = 1; _context2.next = 2; return track.applyConstraints({ advanced: [{ torch: false }] }); case 2: _context2.next = 4; break; case 3: _context2.prev = 3; _t = _context2["catch"](1); if (_t instanceof OverconstrainedError) { console.warn('quagga2/CameraAccess: Torch not supported on this device'); } throw _t; case 4: case "end": return _context2.stop(); } }, _callee2, null, [[1, 3]]); }))(); }, enableTorch: function enableTorch() { return asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee3() { var track, _t2; return regenerator_default.a.wrap(function (_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: track = getActiveTrack(); // TODO: should we acquire camera access even if there's no current camera open? // TODO: what happens on iOS or another device where torch isn't supported at all? Should we throw an error? if (!track) { _context3.next = 4; break; } _context3.prev = 1; _context3.next = 2; return track.applyConstraints({ advanced: [{ torch: true }] }); case 2: _context3.next = 4; break; case 3: _context3.prev = 3; _t2 = _context3["catch"](1); if (_t2 instanceof OverconstrainedError) { console.warn('quagga2/CameraAccess: Torch not supported on this device'); } throw _t2; case 4: case "end": return _context3.stop(); } }, _callee3, null, [[1, 3]]); }))(); } }; /* harmony default export */ var camera_access = (QuaggaJSCameraAccess); // CONCATENATED MODULE: ./src/analytics/result_collector.ts function contains(codeResult, list) { return list && list.some(function (item) { var keys = Object.keys(item); return keys.every(function (key) { return item[key] === codeResult[key]; }); }); } function passesFilter(codeResult, filter) { return typeof filter === 'function' ? filter(codeResult) : true; } /* harmony default export */ var result_collector = ({ create: function create(config) { var _config$capacity; var canvas = document.createElement('canvas'); var ctx = canvas.getContext('2d', { willReadFrequently: !!config.willReadFrequently }); var results = []; var capacity = (_config$capacity = config.capacity) !== null && _config$capacity !== void 0 ? _config$capacity : 20; var capture = config.capture === true; function matchesConstraints(codeResult) { return !!capacity && codeResult && !contains(codeResult, config.blacklist) && passesFilter(codeResult, config.filter); } return { addResult: function addResult(data, imageSize, codeResult) { var result = {}; // this is 'any' to avoid having to construct a whole QuaggaJSCodeResult :| if (matchesConstraints(codeResult)) { capacity--; result.codeResult = codeResult; if (capture) { canvas.width = imageSize.x; canvas.height = imageSize.y; image_debug.drawImage(data, imageSize, ctx); result.frame = canvas.toDataURL(); } results.push(result); } }, getResults: function getResults() { return results; } }; } }); // CONCATENATED MODULE: ./src/config/config.dev.ts var DevConfig = { inputStream: { name: 'Live', type: 'LiveStream', constraints: { width: 640, height: 480, // aspectRatio: 640/480, // optional facingMode: 'environment' // or user // deviceId: "38745983457387598375983759834" }, area: { top: '0%', right: '0%', left: '0%', bottom: '0%' }, singleChannel: false, // true: only the red color-channel is read debug: { showImageDetails: false // logs frame grabber info, canvas size adjustments } }, locate: true, numOfWorkers: 0, decoder: { readers: ['code_128_reader'], debug: { drawBoundingBox: false, showFrequency: false, drawScanline: false, showPattern: false, printReaderInfo: false // logs reader registration and initialization } }, locator: { halfSample: true, patchSize: 'medium', // x-small, small, medium, large, x-large debug: { showCanvas: false, showPatches: false, showFoundPatches: false, showSkeleton: false, showLabels: false, showPatchLabels: false, showRemainingPatchLabels: false, showPatchSize: false, // logs calculated patch size showImageDetails: false, // logs image wrapper size, canvas details boxFromPatches: { showTransformed: false, showTransformedBox: false, showBB: false } } } }; /* harmony default export */ var config_dev = (DevConfig); // CONCATENATED MODULE: ./src/config/config.node.ts var NodeConfig = { inputStream: { type: 'ImageStream', sequence: false, size: 800, area: { top: '0%', right: '0%', left: '0%', bottom: '0%' }, singleChannel: false // true: only the red color-channel is read }, locate: true, numOfWorkers: 0, decoder: { readers: ['code_128_reader'] }, locator: { halfSample: true, patchSize: 'medium' // x-small, small, medium, large, x-large } }; /* harmony default export */ var config_node = (NodeConfig); // CONCATENATED MODULE: ./src/config/config.prod.ts var ProdConfig = { inputStream: { name: 'Live', type: 'LiveStream', constraints: { width: 640, height: 480, // aspectRatio: 640/480, // optional facingMode: 'environment' // or user // deviceId: "38745983457387598375983759834" }, area: { top: '0%', right: '0%', left: '0%', bottom: '0%' }, singleChannel: false // true: only the red color-channel is read }, locate: true, numOfWorkers: 4, decoder: { readers: ['code_128_reader'] }, locator: { halfSample: true, patchSize: 'medium' // x-small, small, medium, large, x-large } }; /* harmony default export */ var config_prod = (ProdConfig); // CONCATENATED MODULE: ./src/config/config.ts var ExportConfig = function () { var QuaggaConfig; if (true) { QuaggaConfig = config_dev; } else {} return QuaggaConfig; }(); /* harmony default export */ var config_config = (ExportConfig); // CONCATENATED MODULE: ./src/input/frame_grabber_browser.js // NOTE FOR ANYONE IN HERE IN THE FUTURE: // webpack.config.js replaces the frame_grabber module with THIS module when it is building for a Browser environment. var TO_RADIANS = Math.PI / 180; function adjustCanvasSize(canvas, targetSize, debug) { if (canvas.width !== targetSize.x) { if ( true && debug !== null && debug !== void 0 && debug.showImageDetails) { console.log('WARNING: canvas-size needs to be adjusted'); } canvas.width = targetSize.x; } if (canvas.height !== targetSize.y) { if ( true && debug !== null && debug !== void 0 && debug.showImageDetails) { console.log('WARNING: canvas-size needs to be adjusted'); } canvas.height = targetSize.y; } } var FrameGrabber = {}; FrameGrabber.create = function (inputStream, canvas) { var _streamConfig$debug, _streamConfig$debug2; // console.warn('*** FrameGrabberBrowser create'); var _that = {}; var _streamConfig = inputStream.getConfig(); var _videoSize = imageRef(inputStream.getRealWidth(), inputStream.getRealHeight()); var _canvasSize = inputStream.getCanvasSize(); var _size = imageRef(inputStream.getWidth(), inputStream.getHeight()); var topRight = inputStream.getTopRight(); var _sx = topRight.x; var _sy = topRight.y; var _canvas; var _ctx = null; var _data = null; var willReadFrequently = _streamConfig.willReadFrequently; _canvas = canvas || document.createElement('canvas'); _canvas.width = _canvasSize.x; _canvas.height = _canvasSize.y; if ( true && (_streamConfig$debug = _streamConfig.debug) !== null && _streamConfig$debug !== void 0 && _streamConfig$debug.showImageDetails) { console.warn('*** frame_grabber_browser: willReadFrequently=', willReadFrequently, 'canvas=', _canvas); } _ctx = _canvas.getContext('2d', { willReadFrequently: !!willReadFrequently }); // double not because we have an optional bool that needs to pass as a bool _data = new Uint8Array(_size.x * _size.y); if ( true && (_streamConfig$debug2 = _streamConfig.debug) !== null && _streamConfig$debug2 !== void 0 && _streamConfig$debug2.showImageDetails) { console.log('FrameGrabber', JSON.stringify({ size: _size, topRight: topRight, videoSize: _videoSize, canvasSize: _canvasSize })); } /** * Uses the given array as frame-buffer */ _that.attachData = function (data) { _data = data; }; /** * Returns the used frame-buffer */ _that.getData = function () { return _data; }; /** * Fetches a frame from the input-stream and puts into the frame-buffer. * The image-data is converted to gray-scale and then half-sampled if configured. */ _that.grab = function () { var doHalfSample = _streamConfig.halfSample; var frame = inputStream.getFrame(); var drawable = frame; var drawAngle = 0; var ctxData; if (drawable) { adjustCanvasSize(_canvas, _canvasSize, _streamConfig.debug); if (_streamConfig.type === 'ImageStream') { drawable = frame.img; if (frame.tags && frame.tags.orientation) { switch (frame.tags.orientation) { case 6: drawAngle = 90 * TO_RADIANS; break; case 8: drawAngle = -90 * TO_RADIANS; break; } } } if (drawAngle !== 0) { _ctx.translate(_canvasSize.x / 2, _canvasSize.y / 2); _ctx.rotate(drawAngle); _ctx.drawImage(drawable, -_canvasSize.y / 2, -_canvasSize.x / 2, _canvasSize.y, _canvasSize.x); _ctx.rotate(-drawAngle); _ctx.translate(-_canvasSize.x / 2, -_canvasSize.y / 2); } else { _ctx.drawImage(drawable, 0, 0, _canvasSize.x, _canvasSize.y); } ctxData = _ctx.getImageData(_sx, _sy, _size.x, _size.y).data; if (doHalfSample) { grayAndHalfSampleFromCanvasData(ctxData, _size, _data); } else { computeGray(ctxData, _data, _streamConfig); } return true; } return false; }; _that.getSize = function () { return _size; }; return _that; }; /* harmony default export */ var frame_grabber_browser = (FrameGrabber); // CONCATENATED MODULE: ./src/input/exif_helper.js // NOTE: (SOME OF) THIS IS BROWSER ONLY CODE. Node does not have 'atob' built in, nor XMLHttpRequest. // How exactly is this set of functions used in Quagga? Do we need the browser specific code? Do we // need to port any part of this that doesn't work in Node to node? // Tags scraped from https://github.com/exif-js/exif-js var ExifTags = { 0x0112: 'orientation' }; var AvailableTags = Object.keys(ExifTags).map(function (key) { return ExifTags[key]; }); function findTagsInObjectURL(src) { var tags = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : AvailableTags; if (/^blob:/i.test(src)) { return objectURLToBlob(src).then(readToBuffer).then(function (buffer) { return findTagsInBuffer(buffer, tags); }); } return Promise.resolve(null); } function base64ToArrayBuffer(dataUrl) { var base64 = dataUrl.replace(/^data:([^;]+);base64,/gmi, ''); var binary = atob(base64); var len = binary.length; var buffer = new ArrayBuffer(len); var view = new Uint8Array(buffer); for (var i = 0; i < len; i++) { view[i] = binary.charCodeAt(i); } return buffer; } function readToBuffer(blob) { return new Promise(function (resolve) { var fileReader = new FileReader(); fileReader.onload = function (e) { return resolve(e.target.result); }; fileReader.readAsArrayBuffer(blob); }); } function objectURLToBlob(url) { return new Promise(function (resolve, reject) { var http = new XMLHttpRequest(); http.open('GET', url, true); http.responseType = 'blob'; http.onreadystatechange = function () { if (http.readyState === XMLHttpRequest.DONE && (http.status === 200 || http.status === 0)) { resolve(this.response); } }; http.onerror = reject; http.send(); }); } function findTagsInBuffer(file) { var selectedTags = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : AvailableTags; var dataView = new DataView(file); var length = file.byteLength; var exifTags = selectedTags.reduce(function (result, selectedTag) { var exifTag = Object.keys(ExifTags).filter(function (tag) { return ExifTags[tag] === selectedTag; })[0]; if (exifTag) { result[exifTag] = selectedTag; } return result; }, {}); var offset = 2; var marker; if (dataView.getUint8(0) !== 0xFF || dataView.getUint8(1) !== 0xD8) { return false; } while (offset < length) { if (dataView.getUint8(offset) !== 0xFF) { return false; } marker = dataView.getUint8(offset + 1); if (marker === 0xE1) { return readEXIFData(dataView, offset + 4, exifTags); } offset += 2 + dataView.getUint16(offset + 2); } return false; } function readEXIFData(file, start, exifTags) { if (getStringFromBuffer(file, start, 4) !== 'Exif') { return false; } var tiffOffset = start + 6; var bigEnd; if (file.getUint16(tiffOffset) === 0x4949) { bigEnd = false; } else if (file.getUint16(tiffOffset) === 0x4D4D) { bigEnd = true; } else { return false; } if (file.getUint16(tiffOffset + 2, !bigEnd) !== 0x002A) { return false; } var firstIFDOffset = file.getUint32(tiffOffset + 4, !bigEnd); if (firstIFDOffset < 0x00000008) { return false; } var tags = readTags(file, tiffOffset, tiffOffset + firstIFDOffset, exifTags, bigEnd); return tags; } function readTags(file, tiffStart, dirStart, strings, bigEnd) { var entries = file.getUint16(dirStart, !bigEnd); var tags = {}; for (var i = 0; i < entries; i++) { var entryOffset = dirStart + i * 12 + 2; var tag = strings[file.getUint16(entryOffset, !bigEnd)]; if (tag) { tags[tag] = readTagValue(file, entryOffset, tiffStart, dirStart, bigEnd); } } return tags; } function readTagValue(file, entryOffset, tiffStart, dirStart, bigEnd) { var type = file.getUint16(entryOffset + 2, !bigEnd); var numValues = file.getUint32(entryOffset + 4, !bigEnd); switch (type) { case 3: if (numValues === 1) { return file.getUint16(entryOffset + 8, !bigEnd); } } return null; } function getStringFromBuffer(buffer, start, length) { var outstr = ''; for (var n = start; n < start + length; n++) { outstr += String.fromCharCode(buffer.getUint8(n)); } return outstr; } // CONCATENATED MODULE: ./src/input/image_loader.js var ImageLoader = {}; ImageLoader.load = function (directory, callback, offset, size, sequence, config) { var htmlImagesSrcArray = new Array(size); var htmlImagesArray = new Array(htmlImagesSrcArray.length); var i; var img; var num; if (sequence === false) { htmlImagesSrcArray[0] = directory; } else { for (i = 0; i < htmlImagesSrcArray.length; i++) { num = offset + i; htmlImagesSrcArray[i] = "".concat(directory, "image-").concat("00".concat(num).slice(-3), ".jpg"); } } htmlImagesArray.notLoaded = []; htmlImagesArray.addImage = function (image) { htmlImagesArray.notLoaded.push(image); }; htmlImagesArray.loaded = function (loadedImg) { var notloadedImgs = htmlImagesArray.notLoaded; for (var x = 0; x < notloadedImgs.length; x++) { if (notloadedImgs[x] === loadedImg) { notloadedImgs.splice(x, 1); for (var y = 0; y < htmlImagesSrcArray.length; y++) { var imgName = htmlImagesSrcArray[y].substr(htmlImagesSrcArray[y].lastIndexOf('/')); if (loadedImg.src.lastIndexOf(imgName) !== -1) { htmlImagesArray[y] = { img: loadedImg }; break; } } break; } } if (notloadedImgs.length === 0) { var _config$debug; if ( true && config !== null && config !== void 0 && (_config$debug = config.debug) !== null && _config$debug !== void 0 && _config$debug.showImageDetails) { console.log("Images loaded: ".concat(htmlImagesArray.length, " image").concat(htmlImagesArray.length !== 1 ? 's' : '', " from ").concat(sequence === false ? directory : directory + ' (sequence)')); } if (sequence === false) { findTagsInObjectURL(directory, ['orientation']).then(function (tags) { htmlImagesArray[0].tags = tags; callback(htmlImagesArray); })["catch"](function (e) { console.log(e); callback(htmlImagesArray); }); } else { callback(htmlImagesArray); } } }; for (i = 0; i < htmlImagesSrcArray.length; i++) { img = new Image(); htmlImagesArray.addImage(img); addOnloadHandler(img, htmlImagesArray); img.src = htmlImagesSrcArray[i]; } }; function addOnloadHandler(img, htmlImagesArray) { img.onload = function () { htmlImagesArray.loaded(this); }; } /* harmony default export */ var image_loader = (ImageLoader); // CONCATENATED MODULE: ./src/input/input_stream/input_stream_browser.ts /* eslint-disable @typescript-eslint/no-explicit-any */ var inputStreamFactory = { createVideoStream: function createVideoStream(video) { console.warn('**** InputStreamBrowser createVideoStream'); var _config = null; var _eventNames = ['canrecord', 'ended']; var _eventHandlers = {}; var _calculatedWidth; var _calculatedHeight; var _topRight = { x: 0, y: 0, type: 'Point' }; var _canvasSize = { x: 0, y: 0, type: 'XYSize' }; function initSize() { var _config2, _config3; var width = video.videoWidth; var height = video.videoHeight; // eslint-disable-next-line no-nested-ternary _calculatedWidth = (_config2 = _config) !== null && _config2 !== void 0 && _config2.size ? width / height > 1 ? _config.size : Math.floor(width / height * _config.size) : width; // eslint-disable-next-line no-nested-ternary _calculatedHeight = (_config3 = _config) !== null && _config3 !== void 0 && _config3.size ? width / height > 1 ? Math.floor(height / width * _config.size) : _config.size : height; _canvasSize.x = _calculatedWidth; _canvasSize.y = _calculatedHeight; } var inputStream = { getRealWidth: function getRealWidth() { return video.videoWidth; }, getRealHeight: function getRealHeight() { return video.videoHeight; }, getWidth: function getWidth() { return _calculatedWidth; }, getHeight: function getHeight() { return _calculatedHeight; }, setWidth: function setWidth(width) { _calculatedWidth = width; }, setHeight: function setHeight(height) { _calculatedHeight = height; }, setInputStream: function setInputStream(config) { // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment _config = config; // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access this.setAttribute('src', typeof config.src !== 'undefined' ? config.src : ''); }, ended: function ended() { return video.ended; }, getConfig: function getConfig() { return _config; }, setAttribute: function setAttribute(name, value) { if (video) { video.setAttribute(name, value); } }, pause: function pause() { video.pause(); }, play: function play() { // eslint-disable-next-line @typescript-eslint/no-floating-promises video.play(); }, setCurrentTime: function setCurrentTime(time) { var _config4; if (((_config4 = _config) === null || _config4 === void 0 ? void 0 : _config4.type) !== 'LiveStream') { this.setAttribute('currentTime', time.toString()); } }, addEventListener: function addEventListener(event, f, bool) { if (_eventNames.indexOf(event) !== -1) { if (!_eventHandlers[event]) { _eventHandlers[event] = []; } _eventHandlers[event].push(f); } else { video.addEventListener(event, f, bool); } }, clearEventHandlers: function clearEventHandlers() { _eventNames.forEach(function (eventName) { var handlers = _eventHandlers[eventName]; if (handlers && handlers.length > 0) { handlers.forEach(function (handler) { video.removeEventListener(eventName, handler); }); } }); }, trigger: function trigger(eventName, args) { var j; // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access var handlers = _eventHandlers[eventName]; if (eventName === 'canrecord') { initSize(); } if (handlers && handlers.length > 0) { for (j = 0; j < handlers.length; j++) { handlers[j].apply(inputStream, args); } } }, setTopRight: function setTopRight(topRight) { _topRight.x = topRight.x; _topRight.y = topRight.y; }, getTopRight: function getTopRight() { return _topRight; }, setCanvasSize: function setCanvasSize(size) { _canvasSize.x = size.x; _canvasSize.y = size.y; }, getCanvasSize: function getCanvasSize() { return _canvasSize; }, getFrame: function getFrame() { return video; } }; return inputStream; }, createLiveStream: function createLiveStream(video) { console.warn('**** InputStreamBrowser createLiveStream'); if (video) { video.setAttribute('autoplay', 'true'); } var that = inputStreamFactory.createVideoStream(video); that.ended = function ended() { return false; }; return that; }, createImageStream: function createImageStream() { // console.warn('**** InputStreamBrowser createImageStream'); var _config = null; var width = 0; var height = 0; var frameIdx = 0; var paused = true; var loaded = false; var imgArray = null; var size = 0; var offset = 1; var baseUrl = null; var _ended = false; var calculatedWidth; var calculatedHeight; var _eventNames = ['canrecord', 'ended']; var _eventHandlers = {}; var _topRight = { x: 0, y: 0, type: 'Point' }; var _canvasSize = { x: 0, y: 0, type: 'XYSize' }; function loadImages() { var _config7; loaded = false; image_loader.load(baseUrl, function (imgs) { var _config5, _config6; imgArray = imgs; // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access if (imgs[0].tags && imgs[0].tags.orientation) { // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access switch (imgs[0].tags.orientation) { case 6: case 8: width = imgs[0].img.height; height = imgs[0].img.width; break; default: width = imgs[0].img.width; height = imgs[0].img.height; } } else { width = imgs[0].img.width; height = imgs[0].img.height; } // eslint-disable-next-line no-nested-ternary calculatedWidth = (_config5 = _config) !== null && _config5 !== void 0 && _config5.size ? width / height > 1 ? _config.size : Math.floor(width / height * _config.size) : width; // eslint-disable-next-line no-nested-ternary calculatedHeight = (_config6 = _config) !== null && _config6 !== void 0 && _config6.size ? width / height > 1 ? Math.floor(height / width * _config.size) : _config.size : height; _canvasSize.x = calculatedWidth; _canvasSize.y = calculatedHeight; loaded = true; frameIdx = 0; setTimeout(function () { // eslint-disable-next-line @typescript-eslint/no-use-before-define publishEvent('canrecord', []); }, 0); }, offset, size, (_config7 = _config) === null || _config7 === void 0 ? void 0 : _config7.sequence, _config); } function publishEvent(eventName, args) { var j; var handlers = _eventHandlers[eventName]; if (handlers && handlers.length > 0) { for (j = 0; j < handlers.length; j++) { // eslint-disable-next-line @typescript-eslint/no-use-before-define handlers[j].apply(inputStream, args); // TODO: typescript complains that any[] is not valid for a second arg for apply?! } } } // TODO: any code shared with the first InputStream above should be shared not copied // TODO: publishEvent needs access to inputStream, but inputStream needs access to publishEvent // TODO: This is why it's a 'var', so it hoists back. This is ugly, and should be changed. // eslint-disable-next-line no-var,vars-on-top var inputStream = { trigger: publishEvent, getWidth: function getWidth() { return calculatedWidth; }, getHeight: function getHeight() { return calculatedHeight; }, setWidth: function setWidth(newWidth) { calculatedWidth = newWidth; }, setHeight: function setHeight(newHeight) { calculatedHeight = newHeight; }, getRealWidth: function getRealWidth() { return width; }, getRealHeight: function getRealHeight() { return height; }, setInputStream: function setInputStream(stream) { // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment _config = stream; // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access if (stream.sequence === false) { // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access baseUrl = stream.src; size = 1; } else { // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access baseUrl = stream.src; // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access size = stream.length; } loadImages(); }, ended: function ended() { return _ended; }, setAttribute: function setAttribute() {}, getConfig: function getConfig() { return _config; }, pause: function pause() { paused = true; }, play: function play() { paused = false; }, setCurrentTime: function setCurrentTime(time) { frameIdx = time; }, addEventListener: function addEventListener(event, f) { if (_eventNames.indexOf(event) !== -1) { if (!_eventHandlers[event]) { _eventHandlers[event] = []; } _eventHandlers[event].push(f); } }, clearEventHandlers: function clearEventHandlers() { Object.keys(_eventHandlers).forEach(function (ind) { return delete _eventHandlers[ind]; }); }, setTopRight: function setTopRight(topRight) { _topRight.x = topRight.x; _topRight.y = topRight.y; }, getTopRight: function getTopRight() { return _topRight; }, setCanvasSize: function setCanvasSize(canvasSize) { _canvasSize.x = canvasSize.x; _canvasSize.y = canvasSize.y; }, getCanvasSize: function getCanvasSize() { return _canvasSize; }, getFrame: function getFrame() { var frame; if (!loaded) { return null; } if (!paused) { var _imgArray; // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment frame = (_imgArray = imgArray) === null || _imgArray === void 0 ? void 0 : _imgArray[frameIdx]; if (frameIdx < size - 1) { frameIdx++; } else { setTimeout(function () { _ended = true; publishEvent('ended', []); }, 0); } } // eslint-disable-next-line @typescript-eslint/no-unsafe-return return frame; } }; return inputStream; } }; /* harmony default export */ var input_stream_browser = (inputStreamFactory); // CONCATENATED MODULE: ./src/locator/tracer.js /** * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization */ var tracer_Tracer = { searchDirections: [[0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [-1, -1], [-1, 0], [-1, 1]], create: function create(imageWrapper, labelWrapper) { var imageData = imageWrapper.data; var labelData = labelWrapper.data; var searchDirections = this.searchDirections; var width = imageWrapper.size.x; var pos; function _trace(current, color, label, edgelabel) { var i; var y; var x; for (i = 0; i < searchDirections.length; i++) { y = current.cy + searchDirections[current.dir][0]; x = current.cx + searchDirections[current.dir][1]; pos = y * width + x; if (imageData[pos] === color && (labelData[pos] === 0 || labelData[pos] === label)) { labelData[pos] = label; current.cy = y; current.cx = x; return true; } if (labelData[pos] === 0) { labelData[pos] = edgelabel; } current.dir = (current.dir + 1) % 8; } return false; } function vertex2D(x, y, dir) { return { dir: dir, x: x, y: y, next: null, prev: null }; } function _contourTracing(sy, sx, label, color, edgelabel) { var Fv = null; var Cv; var P; var ldir; var current = { cx: sx, cy: sy, dir: 0 }; if (_trace(current, color, label, edgelabel)) { Fv = vertex2D(sx, sy, current.dir); Cv = Fv; ldir = current.dir; P = vertex2D(current.cx, current.cy, 0); P.prev = Cv; Cv.next = P; P.next = null; Cv = P; var totalPixelCount = imageWrapper.size.x * imageWrapper.size.y; var pixelCounter = 0; do { current.dir = (current.dir + 6) % 8; _trace(current, color, label, edgelabel); if (ldir !== current.dir) { Cv.dir = current.dir; P = vertex2D(current.cx, current.cy, 0); P.prev = Cv; Cv.next = P; P.next = null; Cv = P; } else { Cv.dir = ldir; Cv.x = current.cx; Cv.y = current.cy; } ldir = current.dir; } while ((current.cx !== sx || current.cy !== sy) && ++pixelCounter < totalPixelCount); Fv.prev = Cv.prev; Cv.prev.next = Fv; } return Fv; } return { trace: function trace(current, color, label, edgelabel) { return _trace(current, color, label, edgelabel); }, contourTracing: function contourTracing(sy, sx, label, color, edgelabel) { return _contourTracing(sy, sx, label, color, edgelabel); } }; } }; /* harmony default export */ var locator_tracer = (tracer_Tracer); // CONCATENATED MODULE: ./src/locator/rasterizer.js /** * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization */ var Rasterizer = { createContour2D: function createContour2D() { return { dir: null, index: null, firstVertex: null, insideContours: null, nextpeer: null, prevpeer: null }; }, CONTOUR_DIR: { CW_DIR: 0, CCW_DIR: 1, UNKNOWN_DIR: 2 }, DIR: { OUTSIDE_EDGE: -32767, INSIDE_EDGE: -32766 }, create: function create(imageWrapper, labelWrapper) { var imageData = imageWrapper.data; var labelData = labelWrapper.data; var width = imageWrapper.size.x; var height = imageWrapper.size.y; var tracer = locator_tracer.create(imageWrapper, labelWrapper); return { rasterize: function rasterize(depthlabel) { var color; var bc; var lc; var labelindex; var cx; var cy; var colorMap = []; var vertex; var p; var cc; var sc; var pos; var connectedCount = 0; var i; for (i = 0; i < 400; i++) { colorMap[i] = 0; } colorMap[0] = imageData[0]; cc = null; for (cy = 1; cy < height - 1; cy++) { labelindex = 0; bc = colorMap[0]; for (cx = 1; cx < width - 1; cx++) { pos = cy * width + cx; if (labelData[pos] === 0) { color = imageData[pos]; if (color !== bc) { if (labelindex === 0) { lc = connectedCount + 1; colorMap[lc] = color; bc = color; vertex = tracer.contourTracing(cy, cx, lc, color, Rasterizer.DIR.OUTSIDE_EDGE); if (vertex !== null) { connectedCount++; labelindex = lc; p = Rasterizer.createContour2D(); p.dir = Rasterizer.CONTOUR_DIR.CW_DIR; p.index = labelindex; p.firstVertex = vertex; p.nextpeer = cc; p.insideContours = null; if (cc !== null) { cc.prevpeer = p; } cc = p; } } else { vertex = tracer.contourTracing(cy, cx, Rasterizer.DIR.INSIDE_EDGE, color, labelindex); if (vertex !== null) { p = Rasterizer.createContour2D(); p.firstVertex = vertex; p.insideContours = null; if (depthlabel === 0) { p.dir = Rasterizer.CONTOUR_DIR.CCW_DIR; } else { p.dir = Rasterizer.CONTOUR_DIR.CW_DIR; } p.index = depthlabel; sc = cc; while (sc !== null && sc.index !== labelindex) { sc = sc.nextpeer; } if (sc !== null) { p.nextpeer = sc.insideContours; if (sc.insideContours !== null) { sc.insideContours.prevpeer = p; } sc.insideContours = p; } } } } else { labelData[pos] = labelindex; } } else if (labelData[pos] === Rasterizer.DIR.OUTSIDE_EDGE || labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) { labelindex = 0; if (labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) { bc = imageData[pos]; } else { bc = colorMap[0]; } } else { labelindex = labelData[pos]; bc = colorMap[labelindex]; } } } sc = cc; while (sc !== null) { sc.index = depthlabel; sc = sc.nextpeer; } return { cc: cc, count: connectedCount }; }, debug: { drawContour: function drawContour(canvas, firstContour) { var ctx = canvas.getContext('2d'); var pq = firstContour; var iq; var q; var p; ctx.strokeStyle = 'red'; ctx.fillStyle = 'red'; ctx.lineWidth = 1; if (pq !== null) { iq = pq.insideContours; } else { iq = null; } while (pq !== null) { if (iq !== null) { q = iq; iq = iq.nextpeer; } else { q = pq; pq = pq.nextpeer; if (pq !== null) { iq = pq.insideContours; } else { iq = null; } } switch (q.dir) { case Rasterizer.CONTOUR_DIR.CW_DIR: ctx.strokeStyle = 'red'; break; case Rasterizer.CONTOUR_DIR.CCW_DIR: ctx.strokeStyle = 'blue'; break; case Rasterizer.CONTOUR_DIR.UNKNOWN_DIR: ctx.strokeStyle = 'green'; break; } p = q.firstVertex; ctx.beginPath(); ctx.moveTo(p.x, p.y); do { p = p.next; ctx.lineTo(p.x, p.y); } while (p !== q.firstVertex); ctx.stroke(); } } } }; } }; /* harmony default export */ var locator_rasterizer = (Rasterizer); // CONCATENATED MODULE: ./src/locator/skeletonizer.js /* eslint-disable no-param-reassign */ /* eslint-disable no-bitwise */ /* eslint-disable eqeqeq */ /* @preserve ASM BEGIN */ /** * Morphological skeletonization using iterative thinning algorithm. * Reduces binary images to single-pixel-wide skeletons while preserving topology. * * Memory layout in shared ArrayBuffer (4 regions of size²): * - Region 0: Working image (subImagePtr = 0) * - Region 1: Eroded result (erodedImagePtr = size²) * - Region 2: Temp/scratch space (tempImagePtr = 2*size²) * - Region 3: Final skeleton output (skelImagePtr = 3*size²) */ function Skeletonizer(stdlib, foreign, buffer) { 'use asm'; var images = new stdlib.Uint8Array(buffer); var size = foreign.size | 0; var imul = stdlib.Math.imul; /** * Morphological erosion with 5-pixel cross structuring element. * A pixel survives only if all 5 pixels in the cross pattern are set: * top-left, top-right, center, bottom-left, bottom-right. */ function erode(inImagePtr, outImagePtr) { inImagePtr = inImagePtr | 0; outImagePtr = outImagePtr | 0; var v = 0; var u = 0; var sum = 0; var yStart1 = 0; var yStart2 = 0; var xStart1 = 0; var xStart2 = 0; var offset = 0; for (v = 1; (v | 0) < (size - 1 | 0); v = v + 1 | 0) { offset = offset + size | 0; for (u = 1; (u | 0) < (size - 1 | 0); u = u + 1 | 0) { yStart1 = offset - size | 0; yStart2 = offset + size | 0; xStart1 = u - 1 | 0; xStart2 = u + 1 | 0; sum = (images[inImagePtr + yStart1 + xStart1 | 0] | 0) + (images[inImagePtr + yStart1 + xStart2 | 0] | 0) + (images[inImagePtr + offset + u | 0] | 0) + (images[inImagePtr + yStart2 + xStart1 | 0] | 0) + (images[inImagePtr + yStart2 + xStart2 | 0] | 0) | 0; // Pixel survives erosion only if all 5 cross neighbors are set if ((sum | 0) == (5 | 0)) { images[outImagePtr + offset + u | 0] = 1; } else { images[outImagePtr + offset + u | 0] = 0; } } } } // Pixel-wise subtraction: out = a - b (captures the "peeled" layer) function subtract(aImagePtr, bImagePtr, outImagePtr) { aImagePtr = aImagePtr | 0; bImagePtr = bImagePtr | 0; outImagePtr = outImagePtr | 0; var length = 0; length = imul(size, size) | 0; while ((length | 0) > 0) { length = length - 1 | 0; images[outImagePtr + length | 0] = (images[aImagePtr + length | 0] | 0) - (images[bImagePtr + length | 0] | 0) | 0; } } // Pixel-wise OR: out = a | b (accumulates skeleton layers) function bitwiseOr(aImagePtr, bImagePtr, outImagePtr) { aImagePtr = aImagePtr | 0; bImagePtr = bImagePtr | 0; outImagePtr = outImagePtr | 0; var length = 0; length = imul(size, size) | 0; while ((length | 0) > 0) { length = length - 1 | 0; images[outImagePtr + length | 0] = images[aImagePtr + length | 0] | 0 | (images[bImagePtr + length | 0] | 0) | 0; } } // Counts non-zero pixels to detect when erosion is complete function countNonZero(imagePtr) { imagePtr = imagePtr | 0; var sum = 0; var length = 0; length = imul(size, size) | 0; while ((length | 0) > 0) { length = length - 1 | 0; sum = (sum | 0) + (images[imagePtr + length | 0] | 0) | 0; } return sum | 0; } // Fills image region with a constant value function init(imagePtr, value) { imagePtr = imagePtr | 0; value = value | 0; var length = 0; length = imul(size, size) | 0; while ((length | 0) > 0) { length = length - 1 | 0; images[imagePtr + length | 0] = value; } } // Morphological dilation with 5-pixel cross - pixel is set if any neighbor is set function dilate(inImagePtr, outImagePtr) { inImagePtr = inImagePtr | 0; outImagePtr = outImagePtr | 0; var v = 0; var u = 0; var sum = 0; var yStart1 = 0; var yStart2 = 0; var xStart1 = 0; var xStart2 = 0; var offset = 0; for (v = 1; (v | 0) < (size - 1 | 0); v = v + 1 | 0) { offset = offset + size | 0; for (u = 1; (u | 0) < (size - 1 | 0); u = u + 1 | 0) { yStart1 = offset - size | 0; yStart2 = offset + size | 0; xStart1 = u - 1 | 0; xStart2 = u + 1 | 0; sum = (images[inImagePtr + yStart1 + xStart1 | 0] | 0) + (images[inImagePtr + yStart1 + xStart2 | 0] | 0) + (images[inImagePtr + offset + u | 0] | 0) + (images[inImagePtr + yStart2 + xStart1 | 0] | 0) + (images[inImagePtr + yStart2 + xStart2 | 0] | 0) | 0; if ((sum | 0) > (0 | 0)) { images[outImagePtr + offset + u | 0] = 1; } else { images[outImagePtr + offset + u | 0] = 0; } } } } // Copies image data from src to dst region function memcpy(srcImagePtr, dstImagePtr) { srcImagePtr = srcImagePtr | 0; dstImagePtr = dstImagePtr | 0; var length = 0; length = imul(size, size) | 0; while ((length | 0) > 0) { length = length - 1 | 0; images[dstImagePtr + length | 0] = images[srcImagePtr + length | 0] | 0; } } /** * Zeros out the border pixels of the image. * First loop: handles top, left, and right edges simultaneously * Second loop: handles bottom edge */ function zeroBorder(imagePtr) { imagePtr = imagePtr | 0; var x = 0; var y = 0; for (x = 0; (x | 0) < (size - 1 | 0); x = x + 1 | 0) { images[imagePtr + x | 0] = 0; images[imagePtr + y | 0] = 0; y = y + size - 1 | 0; images[imagePtr + y | 0] = 0; y = y + 1 | 0; } for (x = 0; (x | 0) < (size | 0); x = x + 1 | 0) { images[imagePtr + y | 0] = 0; y = y + 1 | 0; } } /** * Main skeletonization algorithm using iterative thinning: * 1. Erode the working image * 2. Dilate the eroded version * 3. Subtract dilated from original (extracts "peeled" layer) * 4. OR the peeled layer into skeleton accumulator * 5. Copy eroded image back to working image * 6. Repeat until working image is empty * * @returns {void} No return value - operates directly on shared buffer. * Input image is read from buffer offset 0 (subImagePtr). * Output skeleton is written to buffer offset 3*size² (skelImagePtr). */ function skeletonize() { var subImagePtr = 0; // Region 0: Working image (input, offset = 0) var erodedImagePtr = 0; // Region 1: Eroded result (offset = size²) var tempImagePtr = 0; // Region 2: Scratch space (offset = 2*size²) var skelImagePtr = 0; // Region 3: Final skeleton (output, offset = 3*size²) var sum = 0; var done = 0; // Calculate byte offsets for each region in the shared buffer erodedImagePtr = imul(size, size) | 0; // Region 1: size² bytes in tempImagePtr = erodedImagePtr + erodedImagePtr | 0; // Region 2: 2*size² bytes in skelImagePtr = tempImagePtr + erodedImagePtr | 0; // Region 3: 3*size² bytes in // Initialize skeleton accumulator to zero init(skelImagePtr, 0); zeroBorder(subImagePtr); do { erode(subImagePtr, erodedImagePtr); dilate(erodedImagePtr, tempImagePtr); subtract(subImagePtr, tempImagePtr, tempImagePtr); bitwiseOr(skelImagePtr, tempImagePtr, skelImagePtr); memcpy(erodedImagePtr, subImagePtr); sum = countNonZero(subImagePtr) | 0; done = (sum | 0) == 0 | 0; } while (!done); } return { skeletonize: skeletonize }; } /* @preserve ASM END */ /* harmony default export */ var skeletonizer = (Skeletonizer); /* eslint-enable eqeqeq */ // CONCATENATED MODULE: ./src/locator/barcode_locator.js var barcode_locator_config; var _currentImageWrapper; var _skelImageWrapper; var _subImageWrapper; var _labelImageWrapper; var _patchGrid; var _patchLabelGrid; var _imageToPatchGrid; var _binaryImageWrapper; var _patchSize; var _canvasContainer = { ctx: { binary: null }, dom: { binary: null } }; var _numPatches = { x: 0, y: 0 }; var _inputImageWrapper; var _skeletonizer; function barcode_locator_initBuffers() { if (barcode_locator_config.halfSample) { _currentImageWrapper = new image_wrapper({ // eslint-disable-next-line no-bitwise x: _inputImageWrapper.size.x / 2 | 0, // eslint-disable-next-line no-bitwise y: _inputImageWrapper.size.y / 2 | 0 }); } else { _currentImageWrapper = _inputImageWrapper; } _patchSize = calculatePatchSize(barcode_locator_config.patchSize, _currentImageWrapper.size); // eslint-disable-next-line no-bitwise _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0; // eslint-disable-next-line no-bitwise _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0; _binaryImageWrapper = new image_wrapper(_currentImageWrapper.size, undefined, Uint8Array, false); _labelImageWrapper = new image_wrapper(_patchSize, undefined, Array, true); var skeletonImageData = new ArrayBuffer(64 * 1024); _subImageWrapper = new image_wrapper(_patchSize, new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y)); _skelImageWrapper = new image_wrapper(_patchSize, new Uint8Array(skeletonImageData, _patchSize.x * _patchSize.y * 3, _patchSize.x * _patchSize.y), undefined, true); _skeletonizer = skeletonizer({ Math: Math, Uint8Array: Uint8Array }, { size: _patchSize.x }, skeletonImageData); _imageToPatchGrid = new image_wrapper({ // eslint-disable-next-line no-bitwise x: _currentImageWrapper.size.x / _subImageWrapper.size.x | 0, // eslint-disable-next-line no-bitwise y: _currentImageWrapper.size.y / _subImageWrapper.size.y | 0 }, undefined, Array, true); _patchGrid = new image_wrapper(_imageToPatchGrid.size, undefined, undefined, true); _patchLabelGrid = new image_wrapper(_imageToPatchGrid.size, undefined, Int32Array, true); } function barcode_locator_initCanvas() { var _config$debug; if (barcode_locator_config.useWorker || typeof document === 'undefined') { return; } _canvasContainer.dom.binary = document.createElement('canvas'); _canvasContainer.dom.binary.className = 'binaryBuffer'; if ( true && barcode_locator_config.debug.showCanvas === true) { document.querySelector('#debug').appendChild(_canvasContainer.dom.binary); } var willReadFrequently = !!barcode_locator_config.willReadFrequently; if ( true && (_config$debug = barcode_locator_config.debug) !== null && _config$debug !== void 0 && _config$debug.showCanvas) { console.warn('* initCanvas willReadFrequently', willReadFrequently, barcode_locator_config); } _canvasContainer.ctx.binary = _canvasContainer.dom.binary.getContext('2d', { willReadFrequently: willReadFrequently }); _canvasContainer.dom.binary.width = _binaryImageWrapper.size.x; _canvasContainer.dom.binary.height = _binaryImageWrapper.size.y; } /** * Creates a bounding box which encloses all the given patches * @returns {Array} The minimal bounding box */ function boxFromPatches(patches) { var overAvg; var i; var j; var patch; var transMat; var minx = _binaryImageWrapper.size.x; var miny = _binaryImageWrapper.size.y; var maxx = -_binaryImageWrapper.size.x; var maxy = -_binaryImageWrapper.size.y; var box; var scale; // draw all patches which are to be taken into consideration overAvg = 0; for (i = 0; i < patches.length; i++) { patch = patches[i]; overAvg += patch.rad; if ( true && barcode_locator_config.debug.showPatches) { image_debug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: 'red' }); } } overAvg /= patches.length; overAvg = (overAvg * 180 / Math.PI + 90) % 180 - 90; if (overAvg < 0) { overAvg += 180; } overAvg = (180 - overAvg) * Math.PI / 180; transMat = mat2_namespaceObject.copy(mat2_namespaceObject.create(), [Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]); // iterate over patches and rotate by angle for (i = 0; i < patches.length; i++) { patch = patches[i]; for (j = 0; j < 4; j++) { vec2_namespaceObject.transformMat2(patch.box[j], patch.box[j], transMat); } if ( true && barcode_locator_config.debug.boxFromPatches.showTransformed) { image_debug.drawPath(patch.box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#99ff00', lineWidth: 2 }); } } // find bounding box for (i = 0; i < patches.length; i++) { patch = patches[i]; for (j = 0; j < 4; j++) { if (patch.box[j][0] < minx) { minx = patch.box[j][0]; } if (patch.box[j][0] > maxx) { maxx = patch.box[j][0]; } if (patch.box[j][1] < miny) { miny = patch.box[j][1]; } if (patch.box[j][1] > maxy) { maxy = patch.box[j][1]; } } } box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]]; if ( true && barcode_locator_config.debug.boxFromPatches.showTransformedBox) { image_debug.drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); } scale = barcode_locator_config.halfSample ? 2 : 1; // reverse rotation; transMat = mat2_namespaceObject.invert(transMat, transMat); for (j = 0; j < 4; j++) { vec2_namespaceObject.transformMat2(box[j], box[j], transMat); } if ( true && barcode_locator_config.debug.boxFromPatches.showBB) { image_debug.drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); } for (j = 0; j < 4; j++) { vec2_namespaceObject.scale(box[j], box[j], scale); } return box; } /** * Creates a binary image of the current image */ function binarizeImage() { otsuThreshold(_currentImageWrapper, _binaryImageWrapper); _binaryImageWrapper.zeroBorder(); if ( true && barcode_locator_config.debug.showCanvas) { _binaryImageWrapper.show(_canvasContainer.dom.binary, 255); } } /** * Iterate over the entire image * extract patches */ function findPatches() { var i; var j; var x; var y; var moments; var patchesFound = []; var rasterizer; var rasterResult; var patch; for (i = 0; i < _numPatches.x; i++) { for (j = 0; j < _numPatches.y; j++) { x = _subImageWrapper.size.x * i; y = _subImageWrapper.size.y * j; // seperate parts skeletonize(x, y); // Rasterize, find individual bars _skelImageWrapper.zeroBorder(); array_helper.init(_labelImageWrapper.data, 0); rasterizer = locator_rasterizer.create(_skelImageWrapper, _labelImageWrapper); rasterResult = rasterizer.rasterize(0); if ( true && barcode_locator_config.debug.showLabels) { _labelImageWrapper.overlay(_canvasContainer.dom.binary, Math.floor(360 / rasterResult.count), { x: x, y: y }); } // calculate moments from the skeletonized patch moments = _labelImageWrapper.moments(rasterResult.count); // extract eligible patches patchesFound = patchesFound.concat(describePatch(moments, [i, j], x, y)); } } if ( true && barcode_locator_config.debug.showFoundPatches) { for (i = 0; i < patchesFound.length; i++) { patch = patchesFound[i]; image_debug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: '#99ff00', lineWidth: 2 }); } } return patchesFound; } /** * Finds those connected areas which contain at least 6 patches * and returns them ordered DESC by the number of contained patches * @param {Number} maxLabel */ function findBiggestConnectedAreas(maxLabel) { var i; var sum; var labelHist = []; var topLabels = []; for (i = 0; i < maxLabel; i++) { labelHist.push(0); } sum = _patchLabelGrid.data.length; while (sum--) { if (_patchLabelGrid.data[sum] > 0) { labelHist[_patchLabelGrid.data[sum] - 1]++; } } labelHist = labelHist.map(function (val, idx) { return { val: val, label: idx + 1 }; }); labelHist.sort(function (a, b) { return b.val - a.val; }); // extract top areas with at least 6 patches present topLabels = labelHist.filter(function (el) { return el.val >= 5; }); return topLabels; } /** * */ function findBoxes(topLabels, maxLabel) { var i; var j; var sum; var patches = []; var patch; var box; var boxes = []; var hsv = [0, 1, 1]; var rgb = [0, 0, 0]; for (i = 0; i < topLabels.length; i++) { sum = _patchLabelGrid.data.length; patches.length = 0; while (sum--) { if (_patchLabelGrid.data[sum] === topLabels[i].label) { patch = _imageToPatchGrid.data[sum]; patches.push(patch); } } box = boxFromPatches(patches); if (box) { boxes.push(box); // draw patch-labels if requested if ( true && barcode_locator_config.debug.showRemainingPatchLabels) { for (j = 0; j < patches.length; j++) { patch = patches[j]; hsv[0] = topLabels[i].label / (maxLabel + 1) * 360; hsv2rgb(hsv, rgb); image_debug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "rgb(".concat(rgb.join(','), ")"), lineWidth: 2 }); } } } } return boxes; } /** * Find similar moments (via cluster) * @param {Object} moments */ function similarMoments(moments) { var clusters = cv_utils_cluster(moments, 0.90); var topCluster = topGeneric(clusters, 1, function (e) { return e.getPoints().length; }); var points = []; var result = []; if (topCluster.length === 1) { points = topCluster[0].item.getPoints(); for (var i = 0; i < points.length; i++) { result.push(points[i].point); } } return result; } function skeletonize(x, y) { _binaryImageWrapper.subImageAsCopy(_subImageWrapper, imageRef(x, y)); _skeletonizer.skeletonize(); // Show skeleton if requested if ( true && barcode_locator_config.debug.showSkeleton) { _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, imageRef(x, y)); } } /** * Extracts and describes those patches which seem to contain a barcode pattern * @param {Array} moments * @param {Object} patchPos, * @param {Number} x * @param {Number} y * @returns {Array} list of patches */ function describePatch(moments, patchPos, x, y) { var k; var avg; var eligibleMoments = []; var matchingMoments; var patch; var patchesFound = []; var minComponentWeight = Math.ceil(_patchSize.x / 3); if (moments.length >= 2) { // only collect moments which's area covers at least minComponentWeight pixels. for (k = 0; k < moments.length; k++) { if (moments[k].m00 > minComponentWeight) { eligibleMoments.push(moments[k]); } } // if at least 2 moments are found which have at least minComponentWeights covered if (eligibleMoments.length >= 2) { matchingMoments = similarMoments(eligibleMoments); avg = 0; // determine the similarity of the moments for (k = 0; k < matchingMoments.length; k++) { var _matchingMoments$k$ra, _matchingMoments$k; avg += (_matchingMoments$k$ra = (_matchingMoments$k = matchingMoments[k]) === null || _matchingMoments$k === void 0 ? void 0 : _matchingMoments$k.rad) !== null && _matchingMoments$k$ra !== void 0 ? _matchingMoments$k$ra : 0; } // Only two of the moments are allowed not to fit into the equation // add the patch to the set if (matchingMoments.length > 1 && matchingMoments.length >= eligibleMoments.length / 4 * 3 && matchingMoments.length > moments.length / 4) { avg /= matchingMoments.length; patch = { index: patchPos[1] * _numPatches.x + patchPos[0], pos: { x: x, y: y }, box: [vec2_namespaceObject.clone([x, y]), vec2_namespaceObject.clone([x + _subImageWrapper.size.x, y]), vec2_namespaceObject.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]), vec2_namespaceObject.clone([x, y + _subImageWrapper.size.y])], moments: matchingMoments, rad: avg, vec: vec2_namespaceObject.clone([Math.cos(avg), Math.sin(avg)]) }; patchesFound.push(patch); } } } return patchesFound; } /** * finds patches which are connected and share the same orientation * @param {Object} patchesFound */ function rasterizeAngularSimilarity(patchesFound) { var label = 0; var threshold = 0.95; var currIdx = 0; var j; var patch; var hsv = [0, 1, 1]; var rgb = [0, 0, 0]; function notYetProcessed() { var i; for (i = 0; i < _patchLabelGrid.data.length; i++) { if (_patchLabelGrid.data[i] === 0 && _patchGrid.data[i] === 1) { return i; } } return _patchLabelGrid.data.length; } function trace(currentIdx) { var x; var y; var currentPatch; var idx; var dir; var current = { x: currentIdx % _patchLabelGrid.size.x, y: currentIdx / _patchLabelGrid.size.x | 0 }; var similarity; if (currentIdx < _patchLabelGrid.data.length) { currentPatch = _imageToPatchGrid.data[currentIdx]; // assign label _patchLabelGrid.data[currentIdx] = label; for (dir = 0; dir < locator_tracer.searchDirections.length; dir++) { y = current.y + locator_tracer.searchDirections[dir][0]; x = current.x + locator_tracer.searchDirections[dir][1]; idx = y * _patchLabelGrid.size.x + x; // continue if patch empty if (_patchGrid.data[idx] === 0) { _patchLabelGrid.data[idx] = Number.MAX_VALUE; // eslint-disable-next-line no-continue continue; } if (_patchLabelGrid.data[idx] === 0) { similarity = Math.abs(vec2_namespaceObject.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec)); if (similarity > threshold) { trace(idx); } } } } } // prepare for finding the right patches array_helper.init(_patchGrid.data, 0); array_helper.init(_patchLabelGrid.data, 0); array_helper.init(_imageToPatchGrid.data, null); for (j = 0; j < patchesFound.length; j++) { patch = patchesFound[j]; _imageToPatchGrid.data[patch.index] = patch; _patchGrid.data[patch.index] = 1; } // rasterize the patches found to determine area _patchGrid.zeroBorder(); // eslint-disable-next-line no-cond-assign while ((currIdx = notYetProcessed()) < _patchLabelGrid.data.length) { label++; trace(currIdx); } // draw patch-labels if requested if ( true && barcode_locator_config.debug.showPatchLabels) { for (j = 0; j < _patchLabelGrid.data.length; j++) { if (_patchLabelGrid.data[j] > 0 && _patchLabelGrid.data[j] <= label) { patch = _imageToPatchGrid.data[j]; hsv[0] = _patchLabelGrid.data[j] / (label + 1) * 360; hsv2rgb(hsv, rgb); image_debug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "rgb(".concat(rgb.join(','), ")"), lineWidth: 2 }); } } } return label; } /* harmony default export */ var barcode_locator = ({ init: function init(inputImageWrapper, config) { barcode_locator_config = config; _inputImageWrapper = inputImageWrapper; barcode_locator_initBuffers(); barcode_locator_initCanvas(); }, locate: function locate() { if (barcode_locator_config.halfSample) { halfSample(_inputImageWrapper, _currentImageWrapper); } binarizeImage(); var patchesFound = findPatches(); // return unless 5% or more patches are found if (patchesFound.length < _numPatches.x * _numPatches.y * 0.05) { return null; } // rasterrize area by comparing angular similarity; var maxLabel = rasterizeAngularSimilarity(patchesFound); if (maxLabel < 1) { return null; } // search for area with the most patches (biggest connected area) var topLabels = findBiggestConnectedAreas(maxLabel); if (topLabels.length === 0) { return null; } var boxes = findBoxes(topLabels, maxLabel); return boxes; }, checkImageConstraints: function checkImageConstraints(inputStream, config) { var _config$debug2; var patchSize; var width = inputStream.getWidth(); var height = inputStream.getHeight(); var thisHalfSample = config.halfSample ? 0.5 : 1; var area; // calculate width and height based on area if (inputStream.getConfig().area) { area = computeImageArea(width, height, inputStream.getConfig().area); inputStream.setTopRight({ x: area.sx, y: area.sy }); inputStream.setCanvasSize({ x: width, y: height }); width = area.sw; height = area.sh; } var size = { x: Math.floor(width * thisHalfSample), y: Math.floor(height * thisHalfSample) }; patchSize = calculatePatchSize(config.patchSize, size); if ( true && (_config$debug2 = config.debug) !== null && _config$debug2 !== void 0 && _config$debug2.showPatchSize) { console.log("Patch-Size: ".concat(JSON.stringify(patchSize))); } inputStream.setWidth(Math.max(Math.floor(Math.floor(size.x / patchSize.x) * (1 / thisHalfSample) * patchSize.x), patchSize.x)); inputStream.setHeight(Math.max(Math.floor(Math.floor(size.y / patchSize.y) * (1 / thisHalfSample) * patchSize.y), patchSize.y)); if (inputStream.getWidth() % patchSize.x === 0 && inputStream.getHeight() % patchSize.y === 0) { return true; } throw new Error("Image dimensions do not comply with the current settings: Width (".concat(width, " )and height (").concat(height, ") must a multiple of ").concat(patchSize.x)); } }); // CONCATENATED MODULE: ./src/QuaggaContext.ts var QuaggaContext_QuaggaContext = /*#__PURE__*/createClass_default()(function QuaggaContext() { classCallCheck_default()(this, QuaggaContext); defineProperty_default()(this, "config", void 0); defineProperty_default()(this, "inputStream", void 0); defineProperty_default()(this, "framegrabber", void 0); defineProperty_default()(this, "inputImageWrapper", void 0); defineProperty_default()(this, "stopped", false); defineProperty_default()(this, "boxSize", void 0); defineProperty_default()(this, "resultCollector", void 0); defineProperty_default()(this, "decoder", void 0); defineProperty_default()(this, "workerPool", []); defineProperty_default()(this, "onUIThread", true); defineProperty_default()(this, "canvasContainer", new QuaggaContext_CanvasContainer()); }); var QuaggaContext_CanvasInfo = /*#__PURE__*/createClass_default()(function CanvasInfo() { classCallCheck_default()(this, CanvasInfo); defineProperty_default()(this, "image", void 0); defineProperty_default()(this, "overlay", void 0); }); var QuaggaContext_CanvasContainer = /*#__PURE__*/createClass_default()(function CanvasContainer() { classCallCheck_default()(this, CanvasContainer); defineProperty_default()(this, "ctx", void 0); defineProperty_default()(this, "dom", void 0); this.ctx = new QuaggaContext_CanvasInfo(); this.dom = new QuaggaContext_CanvasInfo(); }); // CONCATENATED MODULE: ./src/quagga/getViewPort.ts function getViewPort_getViewPort(target) { if (typeof document === 'undefined') { return null; } // Check if target is already a DOM element if (target instanceof HTMLElement && target.nodeName && target.nodeType === 1) { return target; } // Use '#interactive.viewport' as a fallback selector (backwards compatibility) var selector = typeof target === 'string' ? target : '#interactive.viewport'; return document.querySelector(selector); } // CONCATENATED MODULE: ./src/quagga/initBuffers.ts // TODO: need typescript def for BarcodeLocator function initBuffers_initBuffers(inputStream, imageWrapper, locator) { var _config, _config$debug; var inputImageWrapper = imageWrapper || new image_wrapper({ x: inputStream.getWidth(), y: inputStream.getHeight(), type: 'XYSize' }); if ( true && (_config = locator.config) !== null && _config !== void 0 && (_config$debug = _config.debug) !== null && _config$debug !== void 0 && _config$debug.showImageDetails) { console.log("image wrapper size ".concat(inputImageWrapper.size)); } var boxSize = [vec2_namespaceObject.clone([0, 0]), vec2_namespaceObject.clone([0, inputImageWrapper.size.y]), vec2_namespaceObject.clone([inputImageWrapper.size.x, inputImageWrapper.size.y]), vec2_namespaceObject.clone([inputImageWrapper.size.x, 0])]; barcode_locator.init(inputImageWrapper, locator); return { inputImageWrapper: inputImageWrapper, boxSize: boxSize }; } // CONCATENATED MODULE: ./src/quagga/initCanvas.ts function findOrCreateCanvas(selector, className) { var canvas = document.querySelector(selector); if (!canvas) { canvas = document.createElement('canvas'); canvas.className = className; } return canvas; } function getCanvasAndContext(selector, className, options) { var _options$debug; var canvas = findOrCreateCanvas(selector, className); if ( true && (_options$debug = options.debug) !== null && _options$debug !== void 0 && _options$debug.showImageDetails) { console.warn('* initCanvas getCanvasAndContext'); } var context = canvas.getContext('2d', { willReadFrequently: options.willReadFrequently }); return { canvas: canvas, context: context }; } function initCanvases(canvasSize, _ref) { var willReadFrequently = _ref.willReadFrequently, debug = _ref.debug; if (typeof document !== 'undefined') { var image = getCanvasAndContext('canvas.imgBuffer', 'imgBuffer', { willReadFrequently: willReadFrequently, debug: debug }); var overlay = getCanvasAndContext('canvas.drawingBuffer', 'drawingBuffer', { willReadFrequently: willReadFrequently, debug: debug }); // eslint-disable-next-line no-multi-assign image.canvas.width = overlay.canvas.width = canvasSize.x; // eslint-disable-next-line no-multi-assign image.canvas.height = overlay.canvas.height = canvasSize.y; return { dom: { image: image.canvas, overlay: overlay.canvas }, ctx: { image: image.context, overlay: overlay.context } }; } return null; } function initCanvas_initCanvas(context) { var _context$config, _context$config$input, _context$config2, _context$config2$inpu, _context$config3, _context$config3$inpu, _context$config4, _context$config4$loca; var viewport = getViewPort_getViewPort(context === null || context === void 0 ? void 0 : (_context$config = context.config) === null || _context$config === void 0 ? void 0 : (_context$config$input = _context$config.inputStream) === null || _context$config$input === void 0 ? void 0 : _context$config$input.target); var type = context === null || context === void 0 ? void 0 : (_context$config2 = context.config) === null || _context$config2 === void 0 ? void 0 : (_context$config2$inpu = _context$config2.inputStream) === null || _context$config2$inpu === void 0 ? void 0 : _context$config2$inpu.type; if (!type) return null; var container = initCanvases(context.inputStream.getCanvasSize(), { willReadFrequently: !!(context !== null && context !== void 0 && (_context$config3 = context.config) !== null && _context$config3 !== void 0 && (_context$config3$inpu = _context$config3.inputStream) !== null && _context$config3$inpu !== void 0 && _context$config3$inpu.willReadFrequently), debug: context === null || context === void 0 ? void 0 : (_context$config4 = context.config) === null || _context$config4 === void 0 ? void 0 : (_context$config4$loca = _context$config4.locator) === null || _context$config4$loca === void 0 ? void 0 : _context$config4$loca.debug }); if (!container) return { dom: { image: null, overlay: null }, ctx: { image: null, overlay: null } }; var dom = container.dom; if (typeof document !== 'undefined') { if (viewport) { if (type === 'ImageStream' && !viewport.contains(dom.image)) { viewport.appendChild(dom.image); } if (!viewport.contains(dom.overlay)) { viewport.appendChild(dom.overlay); } } } return container; } // CONCATENATED MODULE: ./src/quagga/qworker.ts function qworker_ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function qworker_objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? qworker_ownKeys(Object(t), !0).forEach(function (r) { defineProperty_default()(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : qworker_ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /* Worker functions. These are straight from the original quagga.js file. * Not presently used, as worker support is non-functional. Keeping them around temporarily * to refer to until it is re-implemented. We may be able to fix/use some of this. */ // TODO: need a typescript interface for FrameGrabber var workerPool = []; function updateWorkers(frameGrabber) { var availableWorker; if (workerPool.length) { availableWorker = workerPool.filter(function (workerThread) { return !workerThread.busy; })[0]; if (availableWorker) { frameGrabber.attachData(availableWorker.imageData); if (frameGrabber.grab()) { availableWorker.busy = true; availableWorker.worker.postMessage({ cmd: 'process', imageData: availableWorker.imageData }, [availableWorker.imageData.buffer]); } return true; } else { return false; } } return null; } function configForWorker(config) { return qworker_objectSpread(qworker_objectSpread({}, config), {}, { inputStream: qworker_objectSpread(qworker_objectSpread({}, config.inputStream), {}, { target: null }) }); } // @ts-ignore function workerInterface(factory) { if (factory) { var Quagga = factory()["default"]; if (!Quagga) { // @ts-ignore self.postMessage({ 'event': 'error', message: 'Quagga could not be created' }); return; } } // @ts-ignore var imageWrapper; // @ts-ignore function onProcessed(result) { self.postMessage({ 'event': 'processed', // @ts-ignore imageData: imageWrapper.data, result: result // @ts-ignore }, [imageWrapper.data.buffer]); } function workerInterfaceReady() { self.postMessage({ 'event': 'initialized', // @ts-ignore imageData: imageWrapper.data // @ts-ignore }, [imageWrapper.data.buffer]); } // @ts-ignore self.onmessage = function (e) { if (e.data.cmd === 'init') { var config = e.data.config; config.numOfWorkers = 0; imageWrapper = new Quagga.ImageWrapper({ x: e.data.size.x, y: e.data.size.y }, new Uint8Array(e.data.imageData)); Quagga.init(config, workerInterfaceReady, imageWrapper); Quagga.onProcessed(onProcessed); } else if (e.data.cmd === 'process') { // @ts-ignore imageWrapper.data = new Uint8Array(e.data.imageData); Quagga.start(); } else if (e.data.cmd === 'setReaders') { Quagga.setReaders(e.data.readers); } else if (e.data.cmd === 'registerReader') { Quagga.registerReader(e.data.name, e.data.reader); } }; } function generateWorkerBlob() { var blob, factorySource; /* jshint ignore:start */ // @ts-ignore if (typeof __factorySource__ !== 'undefined') { // @ts-ignore factorySource = __factorySource__; // eslint-disable-line no-undef } /* jshint ignore:end */ blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'], { type: 'text/javascript' }); return window.URL.createObjectURL(blob); } function initWorker(config, inputStream, cb) { var blobURL = generateWorkerBlob(); var worker = new Worker(blobURL); var workerThread = { worker: worker, imageData: new Uint8Array(inputStream.getWidth() * inputStream.getHeight()), busy: true }; workerThread.worker.onmessage = function (e) { if (e.data.event === 'initialized') { URL.revokeObjectURL(blobURL); workerThread.busy = false; workerThread.imageData = new Uint8Array(e.data.imageData); if (true) { console.log('Worker initialized'); } cb(workerThread); } else if (e.data.event === 'processed') { workerThread.imageData = new Uint8Array(e.data.imageData); workerThread.busy = false; // TODO: how to thread publishResult into here? TypeScript says it's not here. https://github.com/ericblade/quagga2/issues/466#issuecomment-1724248080 says it's necessary? // @ts-ignore if (typeof publishResult !== 'undefined') { // @ts-ignore publishResult(e.data.result, workerThread.imageData); } } else if (e.data.event === 'error') { if (true) { console.log('Worker error: ' + e.data.message); } } }; workerThread.worker.postMessage({ cmd: 'init', size: { x: inputStream.getWidth(), y: inputStream.getHeight() }, imageData: workerThread.imageData, config: configForWorker(config) }, [workerThread.imageData.buffer]); } function adjustWorkerPool(capacity, config, inputStream, cb) { var increaseBy = capacity - workerPool.length; if (increaseBy === 0 && cb) { cb(); } else if (increaseBy < 0) { var workersToTerminate = workerPool.slice(increaseBy); workersToTerminate.forEach(function (workerThread) { workerThread.worker.terminate(); if (true) { console.log('Worker terminated!'); } }); workerPool = workerPool.slice(0, increaseBy); if (cb) { cb(); } } else { var workerInitialized = function workerInitialized(workerThread) { workerPool.push(workerThread); if (workerPool.length >= capacity && cb) { cb(); } }; if (config) { for (var i = 0; i < increaseBy; i++) { initWorker(config, inputStream, workerInitialized); } } } } function qworker_setReaders(readers) { workerPool.forEach(function (workerThread) { return workerThread.worker.postMessage({ cmd: 'setReaders', readers: readers }); }); } function qworker_registerReader(name, reader) { workerPool.forEach(function (workerThread) { return workerThread.worker.postMessage({ cmd: 'registerReader', name: name, reader: reader }); }); } // CONCATENATED MODULE: ./src/quagga/setupInputStream.ts // TODO: need to create an InputStream typescript interface, so we don't have an "any" in the next line function setupInputStream() { var type = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'LiveStream'; var viewport = arguments.length > 1 ? arguments[1] : undefined; var inputStreamFactory = arguments.length > 2 ? arguments[2] : undefined; switch (type) { case 'VideoStream': { var video = document.createElement('video'); return { video: video, inputStream: inputStreamFactory.createVideoStream(video) }; } case 'ImageStream': return { inputStream: inputStreamFactory.createImageStream() }; case 'LiveStream': { var _video = null; if (viewport) { _video = viewport.querySelector('video'); if (!_video) { _video = document.createElement('video'); viewport.appendChild(_video); } } return { video: _video, inputStream: inputStreamFactory.createLiveStream(_video) }; } default: console.error("* setupInputStream invalid type ".concat(type)); return { video: null, inputStream: null }; } } // CONCATENATED MODULE: ./src/quagga/transform.ts /* eslint-disable no-param-reassign */ function moveBox(box, xOffset, yOffset) { var corner = box.length; while (corner--) { box[corner][0] += xOffset; box[corner][1] += yOffset; } } function moveLine(line, xOffset, yOffset) { line[0].x += xOffset; line[0].y += yOffset; line[1].x += xOffset; line[1].y += yOffset; } // CONCATENATED MODULE: ./src/quagga/quagga.ts var quagga_Quagga = /*#__PURE__*/function () { function Quagga() { var _this = this; classCallCheck_default()(this, Quagga); defineProperty_default()(this, "context", new QuaggaContext_QuaggaContext()); defineProperty_default()(this, "canRecord", function (callback) { var _this$context$config; if (!_this.context.config) { return; } barcode_locator.checkImageConstraints(_this.context.inputStream, (_this$context$config = _this.context.config) === null || _this$context$config === void 0 ? void 0 : _this$context$config.locator); _this.initCanvas(); _this.context.framegrabber = frame_grabber_browser.create(_this.context.inputStream, _this.context.canvasContainer.dom.image); if (_this.context.config.numOfWorkers === undefined) { _this.context.config.numOfWorkers = 0; } adjustWorkerPool(_this.context.config.numOfWorkers, _this.context.config, _this.context.inputStream, function () { var _this$context$config2; if (((_this$context$config2 = _this.context.config) === null || _this$context$config2 === void 0 ? void 0 : _this$context$config2.numOfWorkers) === 0) { _this.initializeData(); } _this.ready(callback); }); }); defineProperty_default()(this, "update", function () { if (_this.context.onUIThread) { var workersUpdated = updateWorkers(_this.context.framegrabber); if (!workersUpdated) { var _this$context$inputIm; _this.context.framegrabber.attachData((_this$context$inputIm = _this.context.inputImageWrapper) === null || _this$context$inputIm === void 0 ? void 0 : _this$context$inputIm.data); if (_this.context.framegrabber.grab()) { if (!workersUpdated) { _this.locateAndDecode(); } } } } else { var _this$context$inputIm2; _this.context.framegrabber.attachData((_this$context$inputIm2 = _this.context.inputImageWrapper) === null || _this$context$inputIm2 === void 0 ? void 0 : _this$context$inputIm2.data); _this.context.framegrabber.grab(); _this.locateAndDecode(); } }); } return createClass_default()(Quagga, [{ key: "initBuffers", value: function initBuffers(imageWrapper) { if (!this.context.config) { return; } var _initBuffers2 = initBuffers_initBuffers(this.context.inputStream, imageWrapper, this.context.config.locator), inputImageWrapper = _initBuffers2.inputImageWrapper, boxSize = _initBuffers2.boxSize; this.context.inputImageWrapper = inputImageWrapper; this.context.boxSize = boxSize; } }, { key: "initializeData", value: function initializeData(imageWrapper) { if (!this.context.config) { return; } this.initBuffers(imageWrapper); this.context.decoder = barcode_decoder.create(this.context.config.decoder, this.context.inputImageWrapper); } }, { key: "getViewPort", value: function getViewPort() { if (!this.context.config || !this.context.config.inputStream) { return null; } var target = this.context.config.inputStream.target; return getViewPort_getViewPort(target); } }, { key: "ready", value: function ready(callback) { this.context.inputStream.play(); callback(); } }, { key: "initCanvas", value: function initCanvas() { var container = initCanvas_initCanvas(this.context); if (!container) { return; } var ctx = container.ctx, dom = container.dom; this.context.canvasContainer.dom.image = dom.image; this.context.canvasContainer.dom.overlay = dom.overlay; this.context.canvasContainer.ctx.image = ctx.image; this.context.canvasContainer.ctx.overlay = ctx.overlay; } }, { key: "initInputStream", value: function initInputStream(callback) { if (!this.context.config || !this.context.config.inputStream) { return; } var _this$context$config$ = this.context.config.inputStream, inputType = _this$context$config$.type, constraints = _this$context$config$.constraints; var _setupInputStream = setupInputStream(inputType, this.getViewPort(), input_stream_browser), video = _setupInputStream.video, inputStream = _setupInputStream.inputStream; if (inputType === 'LiveStream' && video) { camera_access.request(video, constraints).then(function () { return inputStream.trigger('canrecord'); })["catch"](function (err) { return callback(err); }); } if (inputStream) { inputStream.setAttribute('preload', 'auto'); inputStream.setInputStream(this.context.config.inputStream); inputStream.addEventListener('canrecord', this.canRecord.bind(undefined, callback)); } this.context.inputStream = inputStream; } }, { key: "getBoundingBoxes", value: function getBoundingBoxes() { var _this$context$config3; return (_this$context$config3 = this.context.config) !== null && _this$context$config3 !== void 0 && _this$context$config3.locate ? barcode_locator.locate() : [[vec2_namespaceObject.clone(this.context.boxSize[0]), vec2_namespaceObject.clone(this.context.boxSize[1]), vec2_namespaceObject.clone(this.context.boxSize[2]), vec2_namespaceObject.clone(this.context.boxSize[3])]]; } // TODO: need a typescript type for result here. // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types }, { key: "transformResult", value: function transformResult(result) { var _this2 = this; var topRight = this.context.inputStream.getTopRight(); var xOffset = topRight.x; var yOffset = topRight.y; if (xOffset === 0 && yOffset === 0) { return; } if (result.barcodes) { // TODO: BarcodeInfo may not be the right type here. result.barcodes.forEach(function (barcode) { return _this2.transformResult(barcode); }); } if (result.line && result.line.length === 2) { moveLine(result.line, xOffset, yOffset); } if (result.box) { moveBox(result.box, xOffset, yOffset); } if (result.boxes && result.boxes.length > 0) { for (var i = 0; i < result.boxes.length; i++) { moveBox(result.boxes[i], xOffset, yOffset); } } } }, { key: "addResult", value: function addResult(result, imageData) { var _this3 = this; if (!imageData || !this.context.resultCollector) { return; } // TODO: Figure out what data structure holds a "barcodes" result, if any... if (result.barcodes) { result.barcodes.filter(function (barcode) { return barcode.codeResult; }).forEach(function (barcode) { return _this3.addResult(barcode, imageData); }); } else if (result.codeResult) { this.context.resultCollector.addResult(imageData, this.context.inputStream.getCanvasSize(), result.codeResult); } } // eslint-disable-next-line class-methods-use-this }, { key: "hasCodeResult", value: function hasCodeResult(result) { return !!(result && (result.barcodes ? result.barcodes.some(function (barcode) { return barcode.codeResult; }) : result.codeResult)); } // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types }, { key: "publishResult", value: function publishResult() { var result = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; var imageData = arguments.length > 1 ? arguments[1] : undefined; var resultToPublish = result; if (result && this.context.onUIThread) { var _result$barcodes; this.transformResult(result); this.addResult(result, imageData); // @ts-ignore resultToPublish = (result === null || result === void 0 ? void 0 : (_result$barcodes = result.barcodes) === null || _result$barcodes === void 0 ? void 0 : _result$barcodes.length) > 0 ? result.barcodes : result; } events.publish('processed', resultToPublish); if (this.hasCodeResult(result)) { events.publish('detected', resultToPublish); } } }, { key: "locateAndDecode", value: function () { var _locateAndDecode = asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee() { var boxes, _this$context$inputIm3, decodeResult, imageResult, _this$context$inputIm4, _t; return regenerator_default.a.wrap(function (_context) { while (1) switch (_context.prev = _context.next) { case 0: boxes = this.getBoundingBoxes(); if (!boxes) { _context.next = 3; break; } _context.next = 1; return this.context.decoder.decodeFromBoundingBoxes(boxes); case 1: _t = _context.sent; if (_t) { _context.next = 2; break; } _t = {}; case 2: decodeResult = _t; decodeResult.boxes = boxes; this.publishResult(decodeResult, (_this$context$inputIm3 = this.context.inputImageWrapper) === null || _this$context$inputIm3 === void 0 ? void 0 : _this$context$inputIm3.data); _context.next = 5; break; case 3: _context.next = 4; return this.context.decoder.decodeFromImage(this.context.inputImageWrapper); case 4: imageResult = _context.sent; if (imageResult) { this.publishResult(imageResult, (_this$context$inputIm4 = this.context.inputImageWrapper) === null || _this$context$inputIm4 === void 0 ? void 0 : _this$context$inputIm4.data); } else { this.publishResult(); } case 5: case "end": return _context.stop(); } }, _callee, this); })); function locateAndDecode() { return _locateAndDecode.apply(this, arguments); } return locateAndDecode; }() }, { key: "startContinuousUpdate", value: function startContinuousUpdate() { var _this$context$config4, _this4 = this; var next = null; var delay = 1000 / (((_this$context$config4 = this.context.config) === null || _this$context$config4 === void 0 ? void 0 : _this$context$config4.frequency) || 60); this.context.stopped = false; var context = this.context; var _newFrame = function newFrame(timestamp) { next = next || timestamp; if (!context.stopped) { if (timestamp >= next) { next += delay; _this4.update(); } window.requestAnimationFrame(_newFrame); } }; _newFrame(performance.now()); } }, { key: "start", value: function start() { var _this$context$config5, _this$context$config6; if (this.context.onUIThread && ((_this$context$config5 = this.context.config) === null || _this$context$config5 === void 0 ? void 0 : (_this$context$config6 = _this$context$config5.inputStream) === null || _this$context$config6 === void 0 ? void 0 : _this$context$config6.type) === 'LiveStream') { this.startContinuousUpdate(); } else { this.update(); } } }, { key: "stop", value: function () { var _stop = asyncToGenerator_default()(/*#__PURE__*/regenerator_default.a.mark(function _callee2() { var _this$context$config7; return regenerator_default.a.wrap(function (_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: this.context.stopped = true; adjustWorkerPool(0); if (!((_this$context$config7 = this.context.config) !== null && _this$context$config7 !== void 0 && _this$context$config7.inputStream && this.context.config.inputStream.type === 'LiveStream')) { _context2.next = 2; break; } _context2.next = 1; return camera_access.release(); case 1: this.context.inputStream.clearEventHandlers(); case 2: case "end": return _context2.stop(); } }, _callee2, this); })); function stop() { return _stop.apply(this, arguments); } return stop; }() }, { key: "setReaders", value: function setReaders(readers) { if (this.context.decoder) { this.context.decoder.setReaders(readers); } qworker_setReaders(readers); } }, { key: "registerReader", value: function registerReader(name, reader) { barcode_decoder.registerReader(name, reader); if (this.context.decoder) { this.context.decoder.registerReader(name, reader); } qworker_registerReader(name, reader); } }]); }(); // CONCATENATED MODULE: ./src/quagga.js // eslint-disable-line no-unused-vars var instance = new quagga_Quagga(); var _context = instance.context; var QuaggaJSStaticInterface = { init: function init(config, cb, imageWrapper) { var quaggaInstance = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : instance; var promise; if (!cb) { promise = new Promise(function (resolve, reject) { cb = function cb(err) { err ? reject(err) : resolve(); }; }); } quaggaInstance.context.config = merge_default()({}, config_config, config); // TODO #179: pending restructure in Issue #179, we are temp disabling workers if (quaggaInstance.context.config.numOfWorkers > 0) { quaggaInstance.context.config.numOfWorkers = 0; } if (imageWrapper) { quaggaInstance.context.onUIThread = false; quaggaInstance.initializeData(imageWrapper); if (cb) { cb(); } } else { quaggaInstance.initInputStream(cb); } return promise; }, start: function start() { return instance.start(); }, stop: function stop() { return instance.stop(); }, pause: function pause() { _context.stopped = true; }, onDetected: function onDetected(callback) { if (!callback || typeof callback !== 'function' && (typeof_default()(callback) !== 'object' || !callback.callback)) { console.trace('* warning: Quagga.onDetected called with invalid callback, ignoring'); return; } events.subscribe('detected', callback); }, offDetected: function offDetected(callback) { events.unsubscribe('detected', callback); }, onProcessed: function onProcessed(callback) { if (!callback || typeof callback !== 'function' && (typeof_default()(callback) !== 'object' || !callback.callback)) { console.trace('* warning: Quagga.onProcessed called with invalid callback, ignoring'); return; } events.subscribe('processed', callback); }, offProcessed: function offProcessed(callback) { events.unsubscribe('processed', callback); }, setReaders: function setReaders(readers) { if (!readers) { console.trace('* warning: Quagga.setReaders called with no readers, ignoring'); return; } instance.setReaders(readers); }, registerReader: function registerReader(name, reader) { if (!name) { console.trace('* warning: Quagga.registerReader called with no name, ignoring'); return; } if (!reader) { console.trace('* warning: Quagga.registerReader called with no reader, ignoring'); return; } instance.registerReader(name, reader); }, registerResultCollector: function registerResultCollector(resultCollector) { if (resultCollector && typeof resultCollector.addResult === 'function') { _context.resultCollector = resultCollector; } }, get canvas() { return _context.canvasContainer; }, decodeSingle: function decodeSingle(config, resultCallback) { var _this = this; var quaggaInstance = new quagga_Quagga(); config = merge_default()({ inputStream: { type: 'ImageStream', sequence: false, size: 800, src: config.src }, numOfWorkers: true && config.debug ? 0 : 1, locator: { halfSample: false } }, config); // TODO #175: restructure worker support so that it will work with typescript using worker-loader // https://webpack.js.org/loaders/worker-loader/ if (config.numOfWorkers > 0) { config.numOfWorkers = 0; } // workers require Worker and Blob support presently, so if no Blob or Worker then set // workers to 0. if (config.numOfWorkers > 0 && (typeof Blob === 'undefined' || typeof Worker === 'undefined')) { console.warn('* no Worker and/or Blob support - forcing numOfWorkers to 0'); config.numOfWorkers = 0; } return new Promise(function (resolve, reject) { try { _this.init(config, function () { events.once('processed', function (result) { quaggaInstance.stop(); if (resultCallback) { resultCallback.call(null, result); } resolve(result); }, true); quaggaInstance.start(); }, null, quaggaInstance); } catch (err) { reject(err); } }); }, // add the usually expected "default" for use with require, build step won't allow us to // write to module.exports so do it here. get default() { return QuaggaJSStaticInterface; }, Readers: reader_namespaceObject, CameraAccess: camera_access, ImageDebug: image_debug, ImageWrapper: image_wrapper, ResultCollector: result_collector }; /* harmony default export */ var quagga = __webpack_exports__["default"] = (QuaggaJSStaticInterface); // export BarcodeReader and other utilities for external plugins /***/ }) /******/ ])["default"]; }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://Quagga/webpack/universalModuleDefinition","webpack://Quagga/webpack/bootstrap","webpack://Quagga/./node_modules/@babel/runtime/helpers/defineProperty.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/getPrototypeOf.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/classCallCheck.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/createClass.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/inherits.js","webpack://Quagga/./node_modules/@babel/runtime/regenerator/index.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/asyncToGenerator.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/typeof.js","webpack://Quagga/./node_modules/lodash/isObject.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/get.js","webpack://Quagga/./node_modules/lodash/isArray.js","webpack://Quagga/./node_modules/lodash/merge.js","webpack://Quagga/./node_modules/lodash/_root.js","webpack://Quagga/./node_modules/lodash/isObjectLike.js","webpack://Quagga/./node_modules/lodash/_baseGetTag.js","webpack://Quagga/./node_modules/lodash/_ListCache.js","webpack://Quagga/./node_modules/lodash/_assocIndexOf.js","webpack://Quagga/./node_modules/lodash/eq.js","webpack://Quagga/./node_modules/lodash/_Symbol.js","webpack://Quagga/./node_modules/lodash/_nativeCreate.js","webpack://Quagga/./node_modules/lodash/_getMapData.js","webpack://Quagga/./node_modules/lodash/isArguments.js","webpack://Quagga/./node_modules/lodash/_isIndex.js","webpack://Quagga/./node_modules/lodash/_castPath.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/toConsumableArray.js","webpack://Quagga/./node_modules/lodash/_getNative.js","webpack://Quagga/./node_modules/lodash/isFunction.js","webpack://Quagga/./node_modules/lodash/_baseAssignValue.js","webpack://Quagga/(webpack)/buildin/module.js","webpack://Quagga/./node_modules/lodash/isArrayLike.js","webpack://Quagga/./node_modules/lodash/isLength.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/setPrototypeOf.js","webpack://Quagga/./node_modules/lodash/isSymbol.js","webpack://Quagga/./node_modules/lodash/_toKey.js","webpack://Quagga/./node_modules/lodash/_Map.js","webpack://Quagga/./node_modules/lodash/_freeGlobal.js","webpack://Quagga/./node_modules/lodash/_MapCache.js","webpack://Quagga/./node_modules/lodash/_assignMergeValue.js","webpack://Quagga/./node_modules/lodash/_defineProperty.js","webpack://Quagga/./node_modules/lodash/_getPrototype.js","webpack://Quagga/./node_modules/lodash/_isPrototype.js","webpack://Quagga/./node_modules/lodash/isBuffer.js","webpack://Quagga/./node_modules/lodash/isTypedArray.js","webpack://Quagga/./node_modules/lodash/_safeGet.js","webpack://Quagga/./node_modules/lodash/_assignValue.js","webpack://Quagga/./node_modules/lodash/keysIn.js","webpack://Quagga/./node_modules/lodash/identity.js","webpack://Quagga/./node_modules/lodash/_overRest.js","webpack://Quagga/./node_modules/lodash/_setToString.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/arrayLikeToArray.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/toPropertyKey.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/OverloadYield.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/regenerator.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/regeneratorDefine.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/regeneratorAsyncGen.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/regeneratorAsyncIterator.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/slicedToArray.js","webpack://Quagga/./node_modules/lodash/pick.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/wrapNativeSuper.js","webpack://Quagga/./node_modules/lodash/_baseMerge.js","webpack://Quagga/./node_modules/lodash/_Stack.js","webpack://Quagga/./node_modules/lodash/_listCacheClear.js","webpack://Quagga/./node_modules/lodash/_listCacheDelete.js","webpack://Quagga/./node_modules/lodash/_listCacheGet.js","webpack://Quagga/./node_modules/lodash/_listCacheHas.js","webpack://Quagga/./node_modules/lodash/_listCacheSet.js","webpack://Quagga/./node_modules/lodash/_stackClear.js","webpack://Quagga/./node_modules/lodash/_stackDelete.js","webpack://Quagga/./node_modules/lodash/_stackGet.js","webpack://Quagga/./node_modules/lodash/_stackHas.js","webpack://Quagga/./node_modules/lodash/_stackSet.js","webpack://Quagga/./node_modules/lodash/_baseIsNative.js","webpack://Quagga/(webpack)/buildin/global.js","webpack://Quagga/./node_modules/lodash/_getRawTag.js","webpack://Quagga/./node_modules/lodash/_objectToString.js","webpack://Quagga/./node_modules/lodash/_isMasked.js","webpack://Quagga/./node_modules/lodash/_coreJsData.js","webpack://Quagga/./node_modules/lodash/_toSource.js","webpack://Quagga/./node_modules/lodash/_getValue.js","webpack://Quagga/./node_modules/lodash/_mapCacheClear.js","webpack://Quagga/./node_modules/lodash/_Hash.js","webpack://Quagga/./node_modules/lodash/_hashClear.js","webpack://Quagga/./node_modules/lodash/_hashDelete.js","webpack://Quagga/./node_modules/lodash/_hashGet.js","webpack://Quagga/./node_modules/lodash/_hashHas.js","webpack://Quagga/./node_modules/lodash/_hashSet.js","webpack://Quagga/./node_modules/lodash/_mapCacheDelete.js","webpack://Quagga/./node_modules/lodash/_isKeyable.js","webpack://Quagga/./node_modules/lodash/_mapCacheGet.js","webpack://Quagga/./node_modules/lodash/_mapCacheHas.js","webpack://Quagga/./node_modules/lodash/_mapCacheSet.js","webpack://Quagga/./node_modules/lodash/_baseFor.js","webpack://Quagga/./node_modules/lodash/_createBaseFor.js","webpack://Quagga/./node_modules/lodash/_baseMergeDeep.js","webpack://Quagga/./node_modules/lodash/_cloneBuffer.js","webpack://Quagga/./node_modules/lodash/_cloneTypedArray.js","webpack://Quagga/./node_modules/lodash/_cloneArrayBuffer.js","webpack://Quagga/./node_modules/lodash/_Uint8Array.js","webpack://Quagga/./node_modules/lodash/_copyArray.js","webpack://Quagga/./node_modules/lodash/_initCloneObject.js","webpack://Quagga/./node_modules/lodash/_baseCreate.js","webpack://Quagga/./node_modules/lodash/_overArg.js","webpack://Quagga/./node_modules/lodash/_baseIsArguments.js","webpack://Quagga/./node_modules/lodash/isArrayLikeObject.js","webpack://Quagga/./node_modules/lodash/stubFalse.js","webpack://Quagga/./node_modules/lodash/isPlainObject.js","webpack://Quagga/./node_modules/lodash/_baseIsTypedArray.js","webpack://Quagga/./node_modules/lodash/_baseUnary.js","webpack://Quagga/./node_modules/lodash/_nodeUtil.js","webpack://Quagga/./node_modules/lodash/toPlainObject.js","webpack://Quagga/./node_modules/lodash/_copyObject.js","webpack://Quagga/./node_modules/lodash/_arrayLikeKeys.js","webpack://Quagga/./node_modules/lodash/_baseTimes.js","webpack://Quagga/./node_modules/lodash/_baseKeysIn.js","webpack://Quagga/./node_modules/lodash/_nativeKeysIn.js","webpack://Quagga/./node_modules/lodash/_createAssigner.js","webpack://Quagga/./node_modules/lodash/_baseRest.js","webpack://Quagga/./node_modules/lodash/_apply.js","webpack://Quagga/./node_modules/lodash/_baseSetToString.js","webpack://Quagga/./node_modules/lodash/constant.js","webpack://Quagga/./node_modules/lodash/_shortOut.js","webpack://Quagga/./node_modules/lodash/_isIterateeCall.js","webpack://Quagga/./src/common/typedefs.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/arrayWithHoles.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/nonIterableRest.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/toPrimitive.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/regeneratorRuntime.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/regeneratorAsync.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/regeneratorKeys.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/regeneratorValues.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/assertThisInitialized.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/superPropBase.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/iterableToArray.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/nonIterableSpread.js","webpack://Quagga/./node_modules/lodash/_basePick.js","webpack://Quagga/./node_modules/lodash/_basePickBy.js","webpack://Quagga/./node_modules/lodash/_baseGet.js","webpack://Quagga/./node_modules/lodash/_isKey.js","webpack://Quagga/./node_modules/lodash/_stringToPath.js","webpack://Quagga/./node_modules/lodash/_memoizeCapped.js","webpack://Quagga/./node_modules/lodash/memoize.js","webpack://Quagga/./node_modules/lodash/toString.js","webpack://Quagga/./node_modules/lodash/_baseToString.js","webpack://Quagga/./node_modules/lodash/_arrayMap.js","webpack://Quagga/./node_modules/lodash/_baseSet.js","webpack://Quagga/./node_modules/lodash/hasIn.js","webpack://Quagga/./node_modules/lodash/_baseHasIn.js","webpack://Quagga/./node_modules/lodash/_hasPath.js","webpack://Quagga/./node_modules/lodash/_flatRest.js","webpack://Quagga/./node_modules/lodash/flatten.js","webpack://Quagga/./node_modules/lodash/_baseFlatten.js","webpack://Quagga/./node_modules/lodash/_arrayPush.js","webpack://Quagga/./node_modules/lodash/_isFlattenable.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/isNativeFunction.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/construct.js","webpack://Quagga/./node_modules/@babel/runtime/helpers/isNativeReflectConstruct.js","webpack://Quagga/./node_modules/gl-matrix/esm/common.js","webpack://Quagga/./node_modules/gl-matrix/esm/mat2.js","webpack://Quagga/./node_modules/gl-matrix/esm/vec2.js","webpack://Quagga/./node_modules/gl-matrix/esm/vec3.js","webpack://Quagga/./node_modules/gl-matrix/esm/index.js","webpack://Quagga/./src/common/array_helper.ts","webpack://Quagga/./src/common/cluster.js","webpack://Quagga/./src/common/cv_utils.js","webpack://Quagga/./src/common/image_wrapper.ts","webpack://Quagga/./src/common/image_debug.ts","webpack://Quagga/./src/reader/barcode_reader.ts","webpack://Quagga/./src/reader/2of5_reader.ts","webpack://Quagga/./src/reader/codabar_reader.ts","webpack://Quagga/./src/reader/code_128_reader.ts","webpack://Quagga/./src/reader/code_39_reader.ts","webpack://Quagga/./src/reader/code_32_reader.ts","webpack://Quagga/./src/reader/code_39_vin_reader.ts","webpack://Quagga/./src/reader/code_93_reader.ts","webpack://Quagga/./src/reader/ean_reader.ts","webpack://Quagga/./src/reader/ean_2_reader.ts","webpack://Quagga/./src/reader/ean_5_reader.ts","webpack://Quagga/./src/reader/ean_8_reader.ts","webpack://Quagga/./src/reader/i2of5_reader.ts","webpack://Quagga/./src/reader/upc_e_reader.ts","webpack://Quagga/./src/reader/upc_reader.ts","webpack://Quagga/./src/decoder/bresenham.js","webpack://Quagga/./src/decoder/barcode_decoder.js","webpack://Quagga/./src/reader/index.ts","webpack://Quagga/./src/common/events.ts","webpack://Quagga/./src/quagga/Exception.ts","webpack://Quagga/./src/common/mediaDevices.ts","webpack://Quagga/./src/input/camera_access.ts","webpack://Quagga/./src/analytics/result_collector.ts","webpack://Quagga/./src/config/config.dev.ts","webpack://Quagga/./src/config/config.node.ts","webpack://Quagga/./src/config/config.prod.ts","webpack://Quagga/./src/config/config.ts","webpack://Quagga/./src/input/frame_grabber_browser.js","webpack://Quagga/./src/input/exif_helper.js","webpack://Quagga/./src/input/image_loader.js","webpack://Quagga/./src/input/input_stream/input_stream_browser.ts","webpack://Quagga/./src/locator/tracer.js","webpack://Quagga/./src/locator/rasterizer.js","webpack://Quagga/./src/locator/skeletonizer.js","webpack://Quagga/./src/locator/barcode_locator.js","webpack://Quagga/./src/QuaggaContext.ts","webpack://Quagga/./src/quagga/getViewPort.ts","webpack://Quagga/./src/quagga/initBuffers.ts","webpack://Quagga/./src/quagga/initCanvas.ts","webpack://Quagga/./src/quagga/qworker.ts","webpack://Quagga/./src/quagga/setupInputStream.ts","webpack://Quagga/./src/quagga/transform.ts","webpack://Quagga/./src/quagga/quagga.ts","webpack://Quagga/./src/quagga.js"],"names":["window","requestAnimationFrame","webkitRequestAnimationFrame","mozRequestAnimationFrame","oRequestAnimationFrame","msRequestAnimationFrame","callback","setTimeout","Math","imul","a","b","ah","al","bh","bl","Object","assign","target","TypeError","to","index","arguments","length","nextSource","nextKey","prototype","hasOwnProperty","call","init","arr","val","fill","shuffle","i","j","floor","random","_ref","toPointList","rows","reduce","p","n","row","concat","join","push","threshold","scoreFunc","queue","prev","next","apply","maxIndex","max","sum","create","point","points","center","rad","vec","vec2","clone","pointMap","add","pointToAdd","id","updateCenter","cos","sin","fits","otherPoint","similarity","abs","dot","getPoints","getCenter","createPoint","newPoint","property","imageRef","x","y","that","toVec2","toVec3","vec3","round","computeIntegralImage2","imageWrapper","integralWrapper","imageData","data","width","size","height","integralImageData","posA","posB","posC","posD","computeIntegralImage","v","u","thresholdImage","targetWrapper","targetData","computeHistogram","bitsPerPixel","bitShift","bucketCnt","hist","Int32Array","sharpenLine","line","left","right","determineOtsuThreshold","undefined","px","end","mx","determineThreshold","vet","p1","p2","p12","m1","m2","m12","k","ArrayHelper","otsuThreshold","computeBinaryImage","kernel","A","B","C","D","avg","cluster","thisCluster","clusters","addToCluster","found","Cluster2","Tracer","trace","iteration","maxIterations","top","result","centerPos","currentPos","idx","forward","toIdx","predictedPos","thresholdX","thresholdY","match","pos","predicted","from","DILATE","ERODE","dilate","inImageWrapper","outImageWrapper","inImageData","outImageData","yStart1","yStart2","xStart1","xStart2","erode","subtract","aImageWrapper","bImageWrapper","resultImageWrapper","aImageData","bImageData","cImageData","bitwiseOr","countNonZero","topGeneric","list","minIdx","min","score","hit","item","Number","MAX_VALUE","grayArrayFromImage","htmlImage","offsetX","ctx","array","drawImage","ctxData","getImageData","computeGray","grayArrayFromContext","offset","grayAndHalfSampleFromCanvasData","canvasData","outArray","topRowIdx","bottomRowIdx","endIdx","outWidth","outImgIdx","inWidth","config","l","singleChannel","loadImageArray","src","canvas","document","createElement","img","Image","onload","console","warn","getContext","Uint8Array","_ctx$getImageData","halfSample","inImgWrapper","outImgWrapper","inImg","outImg","hsv2rgb","hsv","rgb","h","s","c","m","r","g","_computeDivisors","largeDivisors","divisors","sqrt","unshift","_computeIntersection","arr1","arr2","calculatePatchSize","patchSize","imgSize","divisorsX","divisorsY","wideSide","common","nrOfPatchesList","nrOfPatchesMap","small","medium","large","nrOfPatchesIdx","nrOfPatches","desiredPatchSize","optimalPatchSize","findPatchSizeForDivisors","_parseCSSDimensionValues","value","dimension","parseFloat","unit","indexOf","_dimensionsConverters","context","bottom","computeImageArea","inputWidth","inputHeight","area","parsedArea","keys","key","parsed","calculated","sx","sy","sw","sh","assertNumberPositive","Error","ImageWrapper","ArrayType","initialize","_classCallCheck","_defineProperty","_createClass","inImageWithBorder","imgRef","border","subImageAsCopy","_imageWrapper$size","sizeX","sizeY","get","getSafe","indexMapping","set","zeroBorder","_this$size","moments","labelCount","ysq","labelSum","label","mu11","mu02","mu20","x_","y_","tmp","PI","PI_4","m00","m01","m10","m11","m02","m20","theta","isNaN","atan","getAsRGBA","scale","ret","Uint8ClampedArray","pixel","current","show","frame","newFrame","ImageData","putImageData","overlay","inScale","adjustedScale","whiteRgb","blackRgb","_result","_result2","_slicedToArray","drawRect","style","strokeStyle","color","fillStyle","lineWidth","beginPath","strokeRect","drawPath","path","def","moveTo","lineTo","closePath","stroke","canvasDataPos","imageDataPos","BarcodeDirection","BarcodeReader","supplements","_row","_nextUnset","start","_matchPattern","counter","code","maxSingleError","SINGLE_CODE_ERROR","error","singleError","modulo","barWidth","count","scaled","_nextSet","_correctBars","correction","indices","decodePattern","pattern","decode","reverse","direction","Reverse","Forward","format","FORMAT","_matchRange","_fillCounters","isWhite","counters","counterPos","_toCounters","numCounters","decodeImage","StartNotFoundException","CodeNotFoundException","PatternNotFoundException","N","W","START_PATTERN","STOP_PATTERN","CODE_PATTERN","START_PATTERN_LENGTH","TwoOfFiveReader","_BarcodeReader","_this","_len","args","Array","_key","_callSuper","_inherits","_findPattern","tryHarder","bestMatch","epsilon","AVG_CODE_ERROR","_findStart","startInfo","narrowBarWidth","leadingWhitespaceStart","_verifyTrailingWhitespace","endInfo","trailingWhitespaceEnd","_findEnd","_verifyCounterLength","_decodeCode","_decodePayload","decodedCodes","counterLength","barSpaceRatio","ALPHABET","CHARACTER_ENCODINGS","START_END","MIN_ENCODED_CHARS","MAX_ACCEPTABLE","PADDING","NewCodabarReader","_computeAlternatingThreshold","_counters","_toPattern","barThreshold","spaceThreshold","bitmask","_isStartEnd","_sumCounters","startCounter","endCounter","_patternToChar","String","fromCharCode","_calculatePatternLength","_verifyWhitespace","_charToPattern","char","charCode","charCodeAt","_thresholdResultPattern","categorization","space","narrow","counts","wide","bar","kind","cat","forEach","newkind","ceil","_validateResult","thresholds","nextStart","decodedChar","Code128Reader","_correct","calculateCorrection","MODULE_INDICES","START_CODE_A","START_CODE_C","_this2","checksum","codeset","CODE_A","START_CODE_B","CODE_B","CODE_C","done","shiftNext","removeLastCharacter","multiplier","rawResult","STOP_CODE","CODE_SHIFT","splice","self","expected","normalized","sumNormalized","sumExpected","ALPHABETH_STRING","Uint16Array","_toConsumableArray","map","ASTERISK","Code39Reader","patternStart","whiteSpaceMustStart","maxNarrowWidth","numWideBars","wideBarWidth","_findNextWidth","minWidth","lastStart","patternSize","pop","patterns","AEIO","AZ09","code32set","Code32Reader","_Code39Reader","_decodeCode32","test","res","code32","slice","_checkChecksum","_superPropGet","replace","IOQ","Code39VINReader","ENV","log","Code93Reader","_verifyEnd","_decodeExtended","charArray","nextChar","nextCharCode","_matchCheckChar","maxWeight","arrayToCheck","weightedSums","weight","checkChar","_verifyChecksums","CODE_G_START","MIDDLE_PATTERN","EXTENSION_START_PATTERN","CODE_FREQUENCY","EANReader","merge","coderange","_calculateFirstDigit","codeFrequency","inCode","outCode","_objectSpread","firstDigit","middlePattern","_checksum","_decodeExtensions","err","resultInfo","supplement","lastCode","EAN2Reader","_EANReader","parseInt","CHECK_DIGIT_ENCODINGS","determineCheckDigit","extensionChecksum","EAN5Reader","EAN8Reader","I2of5Reader","opts","normalizeBarSpaceWidth","_possibleConstructorReturn","counterSum","codeSum","correctionRatio","MAX_CORRECTION_FACTOR","correctionRatioInverse","_decodePair","counterPair","codes","UPCEReader","_determineParity","nrSystem","_convertToUPCA","upca","lastDigit","UPCReader","charAt","substring","Bresenham","Slope","DIR","UP","DOWN","getBarcodeLine","x0","y0","x1","y1","steep","read","deltaX","deltaY","yStep","toBinaryLine","slope","slope2","extrema","currentDir","dir","rThreshold","debug","printFrequency","printPattern","fillColor","fillRect","READERS","code_128_reader","ean_reader","ean_5_reader","ean_2_reader","ean_8_reader","code_39_reader","code_39_vin_reader","codabar_reader","CodabarReader","upc_reader","upc_e_reader","i2of5_reader","code_93_reader","code_32_reader","registerReader","name","reader","inputImageWrapper","_canvas","frequency","dom","_barcodeReaders","initCanvas","initReaders","initConfig","_config$debug","$debug","querySelector","className","appendChild","printReaderInfo","_config$debug3","readers","readerConfig","_config$debug2","configuration","_typeof","readerObj","JSON","stringify","vis","node","prop","showFrequency","showPattern","display","getExtendedLine","angle","ext","extendLine","amount","extension","getLine","box","tryDecode","barcodeLine","ImageDebug","codeResult","tryDecodeBruteForce","lineAngle","sideLength","pow","slices","xdir","ydir","getLineLength","decodeFromImage","_x","_decodeFromImage","_asyncToGenerator","_regeneratorRuntime","mark","_callee2","_iterator","_step","_t","wrap","_context2","_createForOfIteratorHelper","sent","abrupt","e","f","finish","stop","decodeFromBoundingBox","drawBoundingBox","lineLength","atan2","drawScanline","decodeFromBoundingBoxes","boxes","barcodes","multiple","imageWrapperIn","_callee","_context","setReaders","EventInterface","events","getEvent","eventName","subscribers","clearEvents","publishSubscription","subscription","async","_subscribe","event","subscribe","publish","filter","subscriber","once","unsubscribe","Exception","_Error","setPrototypeOf","_wrapNativeSuper","ERROR_DESC","enumerateDevices","navigator","mediaDevices","Promise","reject","getUserMedia","constraints","streamRef","waitForVideo","video","resolve","attempts","checkVideo","videoWidth","videoHeight","initCamera","_x2","_initCamera","_callee4","stream","_context4","setAttribute","srcObject","addEventListener","play","deprecatedConstraints","videoConstraints","pick","minAspectRatio","aspectRatio","facing","facingMode","pickConstraints","deviceId","audio","enumerateVideoDevices","_enumerateVideoDevices","_callee5","devices","_context5","device","getActiveTrack","tracks","getVideoTracks","QuaggaJSCameraAccess","requestedVideoElement","request","newConstraints","release","pause","track","getActiveStreamLabel","disableTorch","applyConstraints","advanced","torch","OverconstrainedError","enableTorch","_callee3","_t2","_context3","contains","some","every","passesFilter","_config$capacity","willReadFrequently","results","capacity","capture","matchesConstraints","blacklist","addResult","imageSize","toDataURL","getResults","DevConfig","inputStream","type","showImageDetails","locate","numOfWorkers","decoder","locator","showCanvas","showPatches","showFoundPatches","showSkeleton","showLabels","showPatchLabels","showRemainingPatchLabels","showPatchSize","boxFromPatches","showTransformed","showTransformedBox","showBB","NodeConfig","sequence","ProdConfig","ExportConfig","QuaggaConfig","TO_RADIANS","adjustCanvasSize","targetSize","FrameGrabber","_streamConfig$debug","_streamConfig$debug2","_that","_streamConfig","getConfig","_videoSize","getRealWidth","getRealHeight","_canvasSize","getCanvasSize","_size","getWidth","getHeight","topRight","getTopRight","_sx","_sy","_ctx","_data","videoSize","canvasSize","attachData","getData","grab","doHalfSample","getFrame","drawable","drawAngle","tags","orientation","translate","rotate","getSize","ExifTags","AvailableTags","findTagsInObjectURL","objectURLToBlob","then","readToBuffer","buffer","findTagsInBuffer","base64ToArrayBuffer","dataUrl","base64","binary","atob","len","ArrayBuffer","view","blob","fileReader","FileReader","readAsArrayBuffer","url","http","XMLHttpRequest","open","responseType","onreadystatechange","readyState","DONE","status","response","onerror","send","file","selectedTags","dataView","DataView","byteLength","exifTags","selectedTag","exifTag","tag","marker","getUint8","readEXIFData","getUint16","getStringFromBuffer","tiffOffset","bigEnd","firstIFDOffset","getUint32","readTags","tiffStart","dirStart","strings","entries","entryOffset","readTagValue","numValues","outstr","ImageLoader","load","directory","htmlImagesSrcArray","htmlImagesArray","num","notLoaded","addImage","image","loaded","loadedImg","notloadedImgs","imgName","substr","lastIndexOf","addOnloadHandler","inputStreamFactory","createVideoStream","_config","_eventNames","_eventHandlers","_calculatedWidth","_calculatedHeight","_topRight","initSize","_config2","_config3","setWidth","setHeight","setInputStream","ended","setCurrentTime","time","_config4","toString","bool","clearEventHandlers","handlers","handler","removeEventListener","trigger","setTopRight","setCanvasSize","createLiveStream","createImageStream","frameIdx","paused","imgArray","baseUrl","calculatedWidth","calculatedHeight","loadImages","_config7","imgs","_config5","_config6","publishEvent","newWidth","newHeight","ind","_imgArray","searchDirections","labelWrapper","labelData","edgelabel","cy","cx","vertex2D","contourTracing","Fv","Cv","P","ldir","totalPixelCount","pixelCounter","Rasterizer","createContour2D","firstVertex","insideContours","nextpeer","prevpeer","CONTOUR_DIR","CW_DIR","CCW_DIR","UNKNOWN_DIR","OUTSIDE_EDGE","INSIDE_EDGE","tracer","rasterize","depthlabel","bc","lc","labelindex","colorMap","vertex","cc","sc","connectedCount","drawContour","firstContour","pq","iq","q","Skeletonizer","stdlib","foreign","images","inImagePtr","outImagePtr","aImagePtr","bImagePtr","imagePtr","memcpy","srcImagePtr","dstImagePtr","skeletonize","subImagePtr","erodedImagePtr","tempImagePtr","skelImagePtr","_currentImageWrapper","_skelImageWrapper","_subImageWrapper","_labelImageWrapper","_patchGrid","_patchLabelGrid","_imageToPatchGrid","_binaryImageWrapper","_patchSize","_canvasContainer","_numPatches","_inputImageWrapper","_skeletonizer","initBuffers","skeletonImageData","skeletonizer","useWorker","patches","overAvg","patch","transMat","minx","miny","maxx","maxy","mat2","copy","transformMat2","invert","binarizeImage","findPatches","patchesFound","rasterizer","rasterResult","describePatch","findBiggestConnectedAreas","maxLabel","labelHist","topLabels","sort","el","findBoxes","similarMoments","topCluster","patchPos","eligibleMoments","matchingMoments","minComponentWeight","_matchingMoments$k$ra","_matchingMoments$k","rasterizeAngularSimilarity","currIdx","notYetProcessed","currentIdx","currentPatch","checkImageConstraints","thisHalfSample","QuaggaContext","CanvasContainer","CanvasInfo","getViewPort","HTMLElement","nodeName","nodeType","selector","boxSize","BarcodeLocator","findOrCreateCanvas","getCanvasAndContext","options","_options$debug","initCanvases","_context$config","_context$config$input","_context$config2","_context$config2$inpu","_context$config3","_context$config3$inpu","_context$config4","_context$config4$loca","viewport","container","workerPool","updateWorkers","frameGrabber","availableWorker","workerThread","busy","worker","postMessage","cmd","configForWorker","workerInterface","factory","Quagga","message","onProcessed","workerInterfaceReady","onmessage","generateWorkerBlob","factorySource","__factorySource__","Blob","URL","createObjectURL","initWorker","cb","blobURL","Worker","revokeObjectURL","publishResult","adjustWorkerPool","increaseBy","workersToTerminate","terminate","workerInitialized","setupInputStream","moveBox","xOffset","yOffset","corner","moveLine","_this$context$config","framegrabber","canvasContainer","QWorkers","_this$context$config2","initializeData","ready","onUIThread","workersUpdated","_this$context$inputIm","locateAndDecode","_this$context$inputIm2","_initBuffers2","_initBuffers","BarcodeDecoder","_getViewPort","_initCanvas","initInputStream","_this$context$config$","inputType","_setupInputStream","InputStream","CameraAccess","canRecord","bind","getBoundingBoxes","_this$context$config3","transformResult","barcode","_this3","resultCollector","hasCodeResult","resultToPublish","_result$barcodes","Events","_locateAndDecode","_this$context$inputIm3","decodeResult","imageResult","_this$context$inputIm4","startContinuousUpdate","_this$context$config4","_this4","delay","stopped","timestamp","update","performance","now","_this$context$config5","_this$context$config6","_stop","_this$context$config7","instance","QuaggaJSStaticInterface","quaggaInstance","promise","Config","onDetected","offDetected","offProcessed","registerResultCollector","decodeSingle","resultCallback","default","Readers","ResultCollector"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;QCVA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;AClFA,oBAAoB,mBAAO,CAAC,EAAoB;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,+G;;;;;;ACTA;AACA;AACA;AACA,GAAG;AACH;AACA,+G;;;;;;ACLA;AACA;AACA;AACA,+G;;;;;;ACHA,oBAAoB,mBAAO,CAAC,EAAoB;AAChD;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,4G;;;;;;ACZA,cAAc,mBAAO,CAAC,CAAa;AACnC,4BAA4B,mBAAO,CAAC,GAA4B;AAChE;AACA;AACA;AACA;AACA;AACA,0H;;;;;;ACPA,qBAAqB,mBAAO,CAAC,EAAqB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,yG;;;;;;ACbA;;AAEA,cAAc,mBAAO,CAAC,GAA+B;AACrD;;AAEA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA,GAAG;AACH;AACA;AACA;;;;;;;ACdA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,iH;;;;;;ACzBA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,uG;;;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC9BA,oBAAoB,mBAAO,CAAC,GAAoB;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,oG;;;;;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA,gBAAgB,mBAAO,CAAC,EAAc;AACtC,qBAAqB,mBAAO,CAAC,GAAmB;;AAEhD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,UAAU;AACrB,aAAa,OAAO;AACpB;AACA;AACA;AACA,YAAY,SAAS,GAAG,SAAS;AACjC;AACA;AACA;AACA,YAAY,SAAS,GAAG,SAAS;AACjC;AACA;AACA;AACA,UAAU,QAAQ,iBAAiB,GAAG,iBAAiB;AACvD;AACA;AACA;AACA,CAAC;;AAED;;;;;;;ACtCA,iBAAiB,mBAAO,CAAC,EAAe;;AAExC;AACA;;AAEA;AACA;;AAEA;;;;;;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA,aAAa,mBAAO,CAAC,EAAW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W,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;;AAEA;;;;;;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;;;;;;ACrBA,iBAAiB,mBAAO,CAAC,EAAc;AACvC,eAAe,mBAAO,CAAC,EAAY;;AAEnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClCA;AACA;AACA;AACA,GAAG;AACH;AACA,+G;;;;;;ACLA,iBAAiB,mBAAO,CAAC,EAAe;AACxC,mBAAmB,mBAAO,CAAC,EAAgB;;AAE3C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA,eAAe,mBAAO,CAAC,EAAY;;AAEnC;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,cAAc;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA,gBAAgB,mBAAO,CAAC,EAAc;AACtC,WAAW,mBAAO,CAAC,EAAS;;AAE5B;AACA;;AAEA;;;;;;;ACNA;AACA;;AAEA;;;;;;;;ACHA,oBAAoB,mBAAO,CAAC,EAAkB;AAC9C,qBAAqB,mBAAO,CAAC,EAAmB;AAChD,kBAAkB,mBAAO,CAAC,EAAgB;AAC1C,kBAAkB,mBAAO,CAAC,EAAgB;AAC1C,kBAAkB,mBAAO,CAAC,EAAgB;;AAE1C;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA,sBAAsB,mBAAO,CAAC,EAAoB;AAClD,SAAS,mBAAO,CAAC,EAAM;;AAEvB;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA,gBAAgB,mBAAO,CAAC,EAAc;;AAEtC;AACA;AACA;AACA,WAAW,QAAQ;AACnB;AACA,GAAG;AACH,CAAC;;AAED;;;;;;;ACVA,cAAc,mBAAO,CAAC,GAAY;;AAElC;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACjBA,yDAAW,mBAAO,CAAC,EAAS;AAC5B,gBAAgB,mBAAO,CAAC,GAAa;;AAErC;AACA,kBAAkB,KAA0B;;AAE5C;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;ACrCA,uBAAuB,mBAAO,CAAC,GAAqB;AACpD,gBAAgB,mBAAO,CAAC,GAAc;AACtC,eAAe,mBAAO,CAAC,GAAa;;AAEpC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACpBA,sBAAsB,mBAAO,CAAC,EAAoB;AAClD,SAAS,mBAAO,CAAC,EAAM;;AAEvB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA,oBAAoB,mBAAO,CAAC,GAAkB;AAC9C,iBAAiB,mBAAO,CAAC,GAAe;AACxC,kBAAkB,mBAAO,CAAC,EAAe;;AAEzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,EAAE;AACf;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA,YAAY,mBAAO,CAAC,GAAU;;AAE9B;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnCA,sBAAsB,mBAAO,CAAC,GAAoB;AAClD,eAAe,mBAAO,CAAC,GAAa;;AAEpC;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;;AAEA;;;;;;;ACbA,uBAAuB,mBAAO,CAAC,EAAuB;AACtD;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA,2H;;;;;;ACRA;AACA;AACA,+BAA+B,OAAO;AACtC;AACA;AACA,iH;;;;;;ACLA,cAAc,mBAAO,CAAC,CAAa;AACnC,kBAAkB,mBAAO,CAAC,GAAkB;AAC5C;AACA;AACA;AACA;AACA,6G;;;;;;ACNA;AACA;AACA;AACA,8G;;;;;;ACHA,wBAAwB,mBAAO,CAAC,EAAwB;AACxD;AACA;AACA;AACA;AACA,iDAAiD;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,+BAA+B;AAChE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD,2BAA2B;AAC9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA,aAAa;AACb,WAAW;AACX;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,2DAA2D;AAC3D;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,4G;;;;;;ACxFA;AACA;AACA;AACA,QAAQ,QAAQ;AAChB,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA,kH;;;;;;ACrBA,kBAAkB,mBAAO,CAAC,EAAkB;AAC5C,+BAA+B,mBAAO,CAAC,EAA+B;AACtE;AACA;AACA;AACA,oH;;;;;;ACLA,oBAAoB,mBAAO,CAAC,EAAoB;AAChD,wBAAwB,mBAAO,CAAC,EAAwB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,GAAG;AACH;AACA,6G;;;;;;AChCA,qBAAqB,mBAAO,CAAC,GAAqB;AAClD,2BAA2B,mBAAO,CAAC,GAA2B;AAC9D,iCAAiC,mBAAO,CAAC,EAAiC;AAC1E,sBAAsB,mBAAO,CAAC,GAAsB;AACpD;AACA;AACA;AACA,8G;;;;;;ACPA,eAAe,mBAAO,CAAC,GAAa;AACpC,eAAe,mBAAO,CAAC,GAAa;;AAEpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,qBAAqB;AAChC,aAAa,OAAO;AACpB;AACA;AACA,iBAAiB;AACjB;AACA;AACA,UAAU;AACV;AACA;AACA,4BAA4B;AAC5B,CAAC;;AAED;;;;;;;ACxBA,qBAAqB,mBAAO,CAAC,CAAqB;AAClD,qBAAqB,mBAAO,CAAC,EAAqB;AAClD,uBAAuB,mBAAO,CAAC,GAAuB;AACtD,gBAAgB,mBAAO,CAAC,GAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA,gH;;;;;;;;;;;;;;;;;;;AC1BA,YAAY,mBAAO,CAAC,EAAU;AAC9B,uBAAuB,mBAAO,CAAC,EAAqB;AACpD,cAAc,mBAAO,CAAC,GAAY;AAClC,oBAAoB,mBAAO,CAAC,GAAkB;AAC9C,eAAe,mBAAO,CAAC,CAAY;AACnC,aAAa,mBAAO,CAAC,EAAU;AAC/B,cAAc,mBAAO,CAAC,EAAY;;AAElC;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACzCA,gBAAgB,mBAAO,CAAC,EAAc;AACtC,iBAAiB,mBAAO,CAAC,EAAe;AACxC,kBAAkB,mBAAO,CAAC,EAAgB;AAC1C,eAAe,mBAAO,CAAC,EAAa;AACpC,eAAe,mBAAO,CAAC,EAAa;AACpC,eAAe,mBAAO,CAAC,EAAa;;AAEpC;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACZA,mBAAmB,mBAAO,CAAC,EAAiB;;AAE5C;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClCA,mBAAmB,mBAAO,CAAC,EAAiB;;AAE5C;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA,mBAAmB,mBAAO,CAAC,EAAiB;;AAE5C;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA,mBAAmB,mBAAO,CAAC,EAAiB;;AAE5C;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA,gBAAgB,mBAAO,CAAC,EAAc;;AAEtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACbA,gBAAgB,mBAAO,CAAC,EAAc;AACtC,UAAU,mBAAO,CAAC,EAAQ;AAC1B,eAAe,mBAAO,CAAC,EAAa;;AAEpC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjCA,iBAAiB,mBAAO,CAAC,EAAc;AACvC,eAAe,mBAAO,CAAC,EAAa;AACpC,eAAe,mBAAO,CAAC,CAAY;AACnC,eAAe,mBAAO,CAAC,EAAa;;AAEpC;AACA;AACA;AACA;AACA,oCAAoC;;AAEpC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC9CA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;;AAEA;AACA;AACA,4CAA4C;;AAE5C;;;;;;;ACnBA,aAAa,mBAAO,CAAC,EAAW;;AAEhC;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7CA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA,iBAAiB,mBAAO,CAAC,EAAe;;AAExC;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA,WAAW,mBAAO,CAAC,EAAS;;AAE5B;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACZA,WAAW,mBAAO,CAAC,EAAS;AAC5B,gBAAgB,mBAAO,CAAC,EAAc;AACtC,UAAU,mBAAO,CAAC,EAAQ;;AAE1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA,gBAAgB,mBAAO,CAAC,EAAc;AACtC,iBAAiB,mBAAO,CAAC,EAAe;AACxC,cAAc,mBAAO,CAAC,EAAY;AAClC,cAAc,mBAAO,CAAC,EAAY;AAClC,cAAc,mBAAO,CAAC,EAAY;;AAElC;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA,mBAAmB,mBAAO,CAAC,EAAiB;;AAE5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChBA,mBAAmB,mBAAO,CAAC,EAAiB;;AAE5C;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA,mBAAmB,mBAAO,CAAC,EAAiB;;AAE5C;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA,mBAAmB,mBAAO,CAAC,EAAiB;;AAE5C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA,iBAAiB,mBAAO,CAAC,EAAe;;AAExC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA,iBAAiB,mBAAO,CAAC,EAAe;;AAExC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACfA,iBAAiB,mBAAO,CAAC,EAAe;;AAExC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA,iBAAiB,mBAAO,CAAC,EAAe;;AAExC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA,oBAAoB,mBAAO,CAAC,GAAkB;;AAE9C;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;;AAEA;;;;;;;ACfA;AACA;AACA;AAC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ACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA,iBAAiB,mBAAO,CAAC,EAAe;AACxC,mBAAmB,mBAAO,CAAC,EAAiB;AAC5C,mBAAmB,mBAAO,CAAC,EAAgB;;AAE3C;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7DA,iBAAiB,mBAAO,CAAC,EAAe;AACxC,eAAe,mBAAO,CAAC,EAAY;AACnC,mBAAmB,mBAAO,CAAC,EAAgB;;AAE3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3DA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA,+DAAiB,mBAAO,CAAC,EAAe;;AAExC;AACA,kBAAkB,KAA0B;;AAE5C;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH,CAAC;;AAED;;;;;;;;AC7BA,iBAAiB,mBAAO,CAAC,GAAe;AACxC,aAAa,mBAAO,CAAC,EAAU;;AAE/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS;AACtB,UAAU;AACV;AACA,aAAa,SAAS;AACtB,UAAU;AACV;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA,kBAAkB,mBAAO,CAAC,EAAgB;AAC1C,sBAAsB,mBAAO,CAAC,EAAoB;;AAElD;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,MAAM;AACjB,WAAW,OAAO,WAAW;AAC7B,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA,wBAAwB;;AAExB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvCA,gBAAgB,mBAAO,CAAC,GAAc;AACtC,kBAAkB,mBAAO,CAAC,EAAe;AACzC,cAAc,mBAAO,CAAC,EAAW;AACjC,eAAe,mBAAO,CAAC,EAAY;AACnC,cAAc,mBAAO,CAAC,EAAY;AAClC,mBAAmB,mBAAO,CAAC,EAAgB;;AAE3C;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,QAAQ;AACnB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChDA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA,eAAe,mBAAO,CAAC,CAAY;AACnC,kBAAkB,mBAAO,CAAC,EAAgB;AAC1C,mBAAmB,mBAAO,CAAC,GAAiB;;AAE5C;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA,eAAe,mBAAO,CAAC,GAAa;AACpC,qBAAqB,mBAAO,CAAC,GAAmB;;AAEhD;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACpCA,eAAe,mBAAO,CAAC,EAAY;AACnC,eAAe,mBAAO,CAAC,EAAa;AACpC,kBAAkB,mBAAO,CAAC,EAAgB;;AAE1C;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,EAAE;AACb,WAAW,MAAM;AACjB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA,eAAe,mBAAO,CAAC,GAAY;AACnC,qBAAqB,mBAAO,CAAC,EAAmB;AAChD,eAAe,mBAAO,CAAC,EAAY;;AAEnC;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACrBA;AACA;AACA;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AACA,2G;;;;;;ACXA,oBAAoB,mBAAO,CAAC,EAAoB;AAChD,kBAAkB,mBAAO,CAAC,EAAkB;AAC5C,uBAAuB,mBAAO,CAAC,GAAuB;AACtD,0BAA0B,mBAAO,CAAC,EAA0B;AAC5D,+BAA+B,mBAAO,CAAC,EAA+B;AACtE,sBAAsB,mBAAO,CAAC,GAAsB;AACpD,wBAAwB,mBAAO,CAAC,GAAwB;AACxD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH;AACA,mH;;;;;;AC5EA,0BAA0B,mBAAO,CAAC,EAA0B;AAC5D;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,iH;;;;;;ACPA;AACA;AACA;AACA;AACA;AACA,UAAU,UAAU;AACpB;AACA;AACA;AACA,gH;;;;;;ACTA,cAAc,mBAAO,CAAC,CAAa;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kH;;;;;;AClBA;AACA;AACA;AACA;AACA,sH;;;;;;ACJA,qBAAqB,mBAAO,CAAC,CAAqB;AAClD;AACA,QAAQ,IAAI,+DAA+D;AAC3E;AACA;AACA,8G;;;;;;ACLA,uBAAuB,mBAAO,CAAC,EAAuB;AACtD;AACA;AACA;AACA,kH;;;;;;ACJA;AACA;AACA;AACA,gH;;;;;;ACHA;AACA;AACA;AACA,kH;;;;;;ACHA,iBAAiB,mBAAO,CAAC,GAAe;AACxC,YAAY,mBAAO,CAAC,GAAS;;AAE7B;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;AClBA,cAAc,mBAAO,CAAC,GAAY;AAClC,cAAc,mBAAO,CAAC,GAAY;AAClC,eAAe,mBAAO,CAAC,EAAa;;AAEpC;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA,eAAe,mBAAO,CAAC,EAAa;AACpC,YAAY,mBAAO,CAAC,EAAU;;AAE9B;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,EAAE;AACf;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvBA,cAAc,mBAAO,CAAC,EAAW;AACjC,eAAe,mBAAO,CAAC,EAAY;;AAEnC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA,oBAAoB,mBAAO,CAAC,GAAkB;;AAE9C;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,CAAC;;AAED;;;;;;;AC1BA,cAAc,mBAAO,CAAC,GAAW;;AAEjC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;;;;;;;ACzBA,eAAe,mBAAO,CAAC,EAAa;;AAEpC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA,iBAAiB;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACxEA,mBAAmB,mBAAO,CAAC,GAAiB;;AAE5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA,aAAa,mBAAO,CAAC,EAAW;AAChC,eAAe,mBAAO,CAAC,GAAa;AACpC,cAAc,mBAAO,CAAC,EAAW;AACjC,eAAe,mBAAO,CAAC,EAAY;;AAEnC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,SAAS;AACpB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA,kBAAkB,mBAAO,CAAC,EAAgB;AAC1C,eAAe,mBAAO,CAAC,EAAa;AACpC,cAAc,mBAAO,CAAC,EAAY;AAClC,eAAe,mBAAO,CAAC,CAAY;AACnC,YAAY,mBAAO,CAAC,EAAU;;AAE9B;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,WAAW,EAAE;AACb,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClDA,gBAAgB,mBAAO,CAAC,GAAc;AACtC,cAAc,mBAAO,CAAC,GAAY;;AAElC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACA;AACA,0BAA0B,gBAAgB,SAAS,GAAG;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjCA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACZA,eAAe,mBAAO,CAAC,EAAa;AACpC,kBAAkB,mBAAO,CAAC,EAAe;AACzC,cAAc,mBAAO,CAAC,EAAW;AACjC,cAAc,mBAAO,CAAC,EAAY;AAClC,eAAe,mBAAO,CAAC,EAAY;AACnC,YAAY,mBAAO,CAAC,EAAU;;AAE9B;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,WAAW,SAAS;AACpB,aAAa,QAAQ;AACrB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtCA,cAAc,mBAAO,CAAC,GAAW;AACjC,eAAe,mBAAO,CAAC,EAAa;AACpC,kBAAkB,mBAAO,CAAC,EAAgB;;AAE1C;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA,kBAAkB,mBAAO,CAAC,GAAgB;;AAE1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA,gBAAgB,mBAAO,CAAC,GAAc;AACtC,oBAAoB,mBAAO,CAAC,GAAkB;;AAE9C;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrCA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA,aAAa,mBAAO,CAAC,EAAW;AAChC,kBAAkB,mBAAO,CAAC,EAAe;AACzC,cAAc,mBAAO,CAAC,EAAW;;AAEjC;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,iH;;;;;;ACPA,+BAA+B,mBAAO,CAAC,GAA+B;AACtE,qBAAqB,mBAAO,CAAC,EAAqB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0G;;;;;;ACTA;AACA;AACA,yFAAyF;AACzF,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA,yH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACRA;AACA;AACA;AACA;;AAEA;AACO;AACA;AACA;AACA;;AAEP;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB;AACO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,2CAA2C;AACtD;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACO;AACP;AACA;AACA,C;;AChEwC;;AAExC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa,KAAK;AAClB;AACO,SAAS,WAAM;AACtB,gBAAgB,UAAmB;AACnC,MAAM,UAAmB;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP,gBAAgB,UAAmB;AACnC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP,gBAAgB,UAAmB;AACnC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,YAAY;AACzB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;;AAEA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB;;AAEO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACO,SAAS,WAAM;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,OAAgB,qEAAqE,OAAgB,qEAAqE,OAAgB,qEAAqE,OAAgB;AAC7S;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,cAAc;AACd;AACA;AACO;;AAEP;AACA,cAAc;AACd;AACA;AACO,mB;;AC5aiC;;AAExC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa,KAAK;AAClB;AACO,SAAS,WAAM;AACtB,gBAAgB,UAAmB;AACnC,MAAM,UAAmB;AACzB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB,gBAAgB,UAAmB;AACnC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,eAAU;AAC1B,gBAAgB,UAAmB;AACnC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,SAAI;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,QAAG;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,QAAG;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,aAAQ;AACxB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,aAAQ;AACxB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,QAAG;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB,WAAW,KAAc;AACzB,WAAW,KAAc;AACzB;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,WAAM;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA,UAAU,MAAe;AACzB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,cAAc;AACzB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,WAAM;AACtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,QAAG;AACnB;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACO,SAAS,gBAAW;AAC3B;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACO,SAAS,WAAM;AACtB;AACA;AACA;AACA;AACA,8BAA8B,OAAgB,qEAAqE,OAAgB;AACnI;;AAEA;AACA,cAAc;AACd;AACA;AACO,UAAU,WAAM;;AAEvB;AACA,cAAc;AACd;AACA;AACO,IAAI,QAAG,GAAG,aAAQ;;AAEzB;AACA,cAAc;AACd;AACA;AACO,IAAI,QAAG,GAAG,aAAQ;;AAEzB;AACA,cAAc;AACd;AACA;AACO;;AAEP;AACA,cAAc;AACd;AACA;AACO;;AAEP;AACA,cAAc;AACd;AACA;AACO;;AAEP;AACA,cAAc;AACd;AACA;AACO;;AAEP;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACO;AACP,YAAY,WAAM;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,oBAAoB,OAAO;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,G;;ACjnBuC;;AAExC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa,KAAK;AAClB;AACO,SAAS,WAAM;AACtB,gBAAgB,UAAmB;AACnC,MAAM,UAAmB;AACzB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB,gBAAgB,UAAmB;AACnC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,WAAM;AACtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,eAAU;AAC1B,gBAAgB,UAAmB;AACnC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,SAAI;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,QAAG;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,QAAG;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,aAAQ;AACxB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,aAAQ;AACxB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,WAAM;AACtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,SAAI;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,QAAG;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,QAAG;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB,WAAW,KAAc;AACzB,WAAW,KAAc;AACzB,WAAW,KAAc;AACzB;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,gBAAW;AAC3B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,aAAQ;AACxB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,oBAAe;AAC/B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,kBAAa;AAC7B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,WAAM;AACtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,YAAO;AACvB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,cAAS;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,QAAG;AACnB;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,UAAK;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,SAAI;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP,0CAA0C,QAAG;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO,SAAS,WAAM;AACtB;AACA,UAAU,MAAe;AACzB,UAAU,MAAe;AACzB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,kBAAa;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO,SAAS,kBAAa;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,KAAK;AAClB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,UAAK;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,QAAG;AACvB;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACO,SAAS,SAAI;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,aAAa,OAAO;AACpB;AACO,SAAS,QAAG;AACnB;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACO,SAAS,gBAAW;AAC3B;AACA;;AAEA;AACA;AACA;AACA,WAAW,aAAa;AACxB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACO,SAAS,WAAM;AACtB;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,OAAgB,qEAAqE,OAAgB,qEAAqE,OAAgB;AACxN;;AAEA;AACA,cAAc;AACd;AACA;AACO,IAAI,QAAG,GAAG,aAAQ;;AAEzB;AACA,cAAc;AACd;AACA;AACO,IAAI,QAAG,GAAG,aAAQ;;AAEzB;AACA,cAAc;AACd;AACA;AACO,IAAI,QAAG,GAAG,WAAM;;AAEvB;AACA,cAAc;AACd;AACA;AACO,IAAI,SAAI,GAAG,aAAQ;;AAE1B;AACA,cAAc;AACd;AACA;AACO,IAAI,YAAO,GAAG,oBAAe;;AAEpC;AACA,cAAc;AACd;AACA;AACO,IAAI,QAAG,GAAG,WAAM;;AAEvB;AACA,cAAc;AACd;AACA;AACO,IAAI,WAAM,GAAG,kBAAa;;AAEjC;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACO,IAAI,YAAO;AAClB,YAAY,WAAM;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,oBAAoB,OAAO;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;A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CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,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","file":"quagga.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[\"Quagga\"] = factory();\n\telse\n\t\troot[\"Quagga\"] = factory();\n})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// 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, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\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\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 67);\n","var toPropertyKey = require(\"./toPropertyKey.js\");\nfunction _defineProperty(e, r, t) {\n  return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n    value: t,\n    enumerable: !0,\n    configurable: !0,\n    writable: !0\n  }) : e[r] = t, e;\n}\nmodule.exports = _defineProperty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _getPrototypeOf(t) {\n  return module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) {\n    return t.__proto__ || Object.getPrototypeOf(t);\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _getPrototypeOf(t);\n}\nmodule.exports = _getPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _classCallCheck(a, n) {\n  if (!(a instanceof n)) throw new TypeError(\"Cannot call a class as a function\");\n}\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var toPropertyKey = require(\"./toPropertyKey.js\");\nfunction _defineProperties(e, r) {\n  for (var t = 0; t < r.length; t++) {\n    var o = r[t];\n    o.enumerable = o.enumerable || !1, o.configurable = !0, \"value\" in o && (o.writable = !0), Object.defineProperty(e, toPropertyKey(o.key), o);\n  }\n}\nfunction _createClass(e, r, t) {\n  return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, \"prototype\", {\n    writable: !1\n  }), e;\n}\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar assertThisInitialized = require(\"./assertThisInitialized.js\");\nfunction _possibleConstructorReturn(t, e) {\n  if (e && (\"object\" == _typeof(e) || \"function\" == typeof e)) return e;\n  if (void 0 !== e) throw new TypeError(\"Derived constructors may only return object or undefined\");\n  return assertThisInitialized(t);\n}\nmodule.exports = _possibleConstructorReturn, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\nfunction _inherits(t, e) {\n  if (\"function\" != typeof e && null !== e) throw new TypeError(\"Super expression must either be null or a function\");\n  t.prototype = Object.create(e && e.prototype, {\n    constructor: {\n      value: t,\n      writable: !0,\n      configurable: !0\n    }\n  }), Object.defineProperty(t, \"prototype\", {\n    writable: !1\n  }), e && setPrototypeOf(t, e);\n}\nmodule.exports = _inherits, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","// TODO(Babel 8): Remove this file.\n\nvar runtime = require(\"../helpers/regeneratorRuntime\")();\nmodule.exports = runtime;\n\n// Copied from https://github.com/facebook/regenerator/blob/main/packages/runtime/runtime.js#L736=\ntry {\n  regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n  if (typeof globalThis === \"object\") {\n    globalThis.regeneratorRuntime = runtime;\n  } else {\n    Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n  }\n}\n","function asyncGeneratorStep(n, t, e, r, o, a, c) {\n  try {\n    var i = n[a](c),\n      u = i.value;\n  } catch (n) {\n    return void e(n);\n  }\n  i.done ? t(u) : Promise.resolve(u).then(r, o);\n}\nfunction _asyncToGenerator(n) {\n  return function () {\n    var t = this,\n      e = arguments;\n    return new Promise(function (r, o) {\n      var a = n.apply(t, e);\n      function _next(n) {\n        asyncGeneratorStep(a, r, o, _next, _throw, \"next\", n);\n      }\n      function _throw(n) {\n        asyncGeneratorStep(a, r, o, _next, _throw, \"throw\", n);\n      }\n      _next(void 0);\n    });\n  };\n}\nmodule.exports = _asyncToGenerator, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(o) {\n  \"@babel/helpers - typeof\";\n\n  return module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n    return typeof o;\n  } : function (o) {\n    return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _typeof(o);\n}\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n  var type = typeof value;\n  return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","var superPropBase = require(\"./superPropBase.js\");\nfunction _get() {\n  return module.exports = _get = \"undefined\" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) {\n    var p = superPropBase(e, t);\n    if (p) {\n      var n = Object.getOwnPropertyDescriptor(p, t);\n      return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value;\n    }\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _get.apply(null, arguments);\n}\nmodule.exports = _get, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","var baseMerge = require('./_baseMerge'),\n    createAssigner = require('./_createAssigner');\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n *   'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n *   'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\nvar merge = createAssigner(function(object, source, srcIndex) {\n  baseMerge(object, source, srcIndex);\n});\n\nmodule.exports = merge;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var Symbol = require('./_Symbol'),\n    getRawTag = require('./_getRawTag'),\n    objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n    undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n  if (value == null) {\n    return value === undefined ? undefinedTag : nullTag;\n  }\n  return (symToStringTag && symToStringTag in Object(value))\n    ? getRawTag(value)\n    : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","var listCacheClear = require('./_listCacheClear'),\n    listCacheDelete = require('./_listCacheDelete'),\n    listCacheGet = require('./_listCacheGet'),\n    listCacheHas = require('./_listCacheHas'),\n    listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n  var length = array.length;\n  while (length--) {\n    if (eq(array[length][0], key)) {\n      return length;\n    }\n  }\n  return -1;\n}\n\nmodule.exports = assocIndexOf;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n  var data = map.__data__;\n  return isKeyable(key)\n    ? data[typeof key == 'string' ? 'string' : 'hash']\n    : data.map;\n}\n\nmodule.exports = getMapData;\n","var baseIsArguments = require('./_baseIsArguments'),\n    isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n *  else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n  return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n    !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  var type = typeof value;\n  length = length == null ? MAX_SAFE_INTEGER : length;\n\n  return !!length &&\n    (type == 'number' ||\n      (type != 'symbol' && reIsUint.test(value))) &&\n        (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","var isArray = require('./isArray'),\n    isKey = require('./_isKey'),\n    stringToPath = require('./_stringToPath'),\n    toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n  if (isArray(value)) {\n    return value;\n  }\n  return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n","var arrayWithoutHoles = require(\"./arrayWithoutHoles.js\");\nvar iterableToArray = require(\"./iterableToArray.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableSpread = require(\"./nonIterableSpread.js\");\nfunction _toConsumableArray(r) {\n  return arrayWithoutHoles(r) || iterableToArray(r) || unsupportedIterableToArray(r) || nonIterableSpread();\n}\nmodule.exports = _toConsumableArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var baseIsNative = require('./_baseIsNative'),\n    getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n  var value = getValue(object, key);\n  return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","var baseGetTag = require('./_baseGetTag'),\n    isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  if (!isObject(value)) {\n    return false;\n  }\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 9 which returns 'object' for typed arrays and other constructors.\n  var tag = baseGetTag(value);\n  return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","var defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n  if (key == '__proto__' && defineProperty) {\n    defineProperty(object, key, {\n      'configurable': true,\n      'enumerable': true,\n      'value': value,\n      'writable': true\n    });\n  } else {\n    object[key] = value;\n  }\n}\n\nmodule.exports = baseAssignValue;\n","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","var isFunction = require('./isFunction'),\n    isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n  return typeof value == 'number' &&\n    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","function _setPrototypeOf(t, e) {\n  return module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) {\n    return t.__proto__ = e, t;\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _setPrototypeOf(t, e);\n}\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var baseGetTag = require('./_baseGetTag'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n  return typeof value == 'symbol' ||\n    (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n  if (typeof value == 'string' || isSymbol(value)) {\n    return value;\n  }\n  var result = (value + '');\n  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var mapCacheClear = require('./_mapCacheClear'),\n    mapCacheDelete = require('./_mapCacheDelete'),\n    mapCacheGet = require('./_mapCacheGet'),\n    mapCacheHas = require('./_mapCacheHas'),\n    mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n","var baseAssignValue = require('./_baseAssignValue'),\n    eq = require('./eq');\n\n/**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignMergeValue(object, key, value) {\n  if ((value !== undefined && !eq(object[key], value)) ||\n      (value === undefined && !(key in object))) {\n    baseAssignValue(object, key, value);\n  }\n}\n\nmodule.exports = assignMergeValue;\n","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n  try {\n    var func = getNative(Object, 'defineProperty');\n    func({}, '', {});\n    return func;\n  } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\nmodule.exports = isPrototype;\n","var root = require('./_root'),\n    stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n    baseUnary = require('./_baseUnary'),\n    nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","/**\n * Gets the value at `key`, unless `key` is \"__proto__\" or \"constructor\".\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction safeGet(object, key) {\n  if (key === 'constructor' && typeof object[key] === 'function') {\n    return;\n  }\n\n  if (key == '__proto__') {\n    return;\n  }\n\n  return object[key];\n}\n\nmodule.exports = safeGet;\n","var baseAssignValue = require('./_baseAssignValue'),\n    eq = require('./eq');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n  var objValue = object[key];\n  if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n      (value === undefined && !(key in object))) {\n    baseAssignValue(object, key, value);\n  }\n}\n\nmodule.exports = assignValue;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n    baseKeysIn = require('./_baseKeysIn'),\n    isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nmodule.exports = keysIn;\n","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n  return value;\n}\n\nmodule.exports = identity;\n","var apply = require('./_apply');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\nfunction overRest(func, start, transform) {\n  start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n  return function() {\n    var args = arguments,\n        index = -1,\n        length = nativeMax(args.length - start, 0),\n        array = Array(length);\n\n    while (++index < length) {\n      array[index] = args[start + index];\n    }\n    index = -1;\n    var otherArgs = Array(start + 1);\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = transform(array);\n    return apply(func, this, otherArgs);\n  };\n}\n\nmodule.exports = overRest;\n","var baseSetToString = require('./_baseSetToString'),\n    shortOut = require('./_shortOut');\n\n/**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar setToString = shortOut(baseSetToString);\n\nmodule.exports = setToString;\n","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _unsupportedIterableToArray(r, a) {\n  if (r) {\n    if (\"string\" == typeof r) return arrayLikeToArray(r, a);\n    var t = {}.toString.call(r).slice(8, -1);\n    return \"Object\" === t && r.constructor && (t = r.constructor.name), \"Map\" === t || \"Set\" === t ? Array.from(r) : \"Arguments\" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? arrayLikeToArray(r, a) : void 0;\n  }\n}\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayLikeToArray(r, a) {\n  (null == a || a > r.length) && (a = r.length);\n  for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];\n  return n;\n}\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar toPrimitive = require(\"./toPrimitive.js\");\nfunction toPropertyKey(t) {\n  var i = toPrimitive(t, \"string\");\n  return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nmodule.exports = toPropertyKey, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _OverloadYield(e, d) {\n  this.v = e, this.k = d;\n}\nmodule.exports = _OverloadYield, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var regeneratorDefine = require(\"./regeneratorDefine.js\");\nfunction _regenerator() {\n  /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */\n  var e,\n    t,\n    r = \"function\" == typeof Symbol ? Symbol : {},\n    n = r.iterator || \"@@iterator\",\n    o = r.toStringTag || \"@@toStringTag\";\n  function i(r, n, o, i) {\n    var c = n && n.prototype instanceof Generator ? n : Generator,\n      u = Object.create(c.prototype);\n    return regeneratorDefine(u, \"_invoke\", function (r, n, o) {\n      var i,\n        c,\n        u,\n        f = 0,\n        p = o || [],\n        y = !1,\n        G = {\n          p: 0,\n          n: 0,\n          v: e,\n          a: d,\n          f: d.bind(e, 4),\n          d: function d(t, r) {\n            return i = t, c = 0, u = e, G.n = r, a;\n          }\n        };\n      function d(r, n) {\n        for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) {\n          var o,\n            i = p[t],\n            d = G.p,\n            l = i[2];\n          r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0));\n        }\n        if (o || r > 1) return a;\n        throw y = !0, n;\n      }\n      return function (o, p, l) {\n        if (f > 1) throw TypeError(\"Generator is already running\");\n        for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) {\n          i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u);\n          try {\n            if (f = 2, i) {\n              if (c || (o = \"next\"), t = i[o]) {\n                if (!(t = t.call(i, u))) throw TypeError(\"iterator result is not an object\");\n                if (!t.done) return t;\n                u = t.value, c < 2 && (c = 0);\n              } else 1 === c && (t = i[\"return\"]) && t.call(i), c < 2 && (u = TypeError(\"The iterator does not provide a '\" + o + \"' method\"), c = 1);\n              i = e;\n            } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break;\n          } catch (t) {\n            i = e, c = 1, u = t;\n          } finally {\n            f = 1;\n          }\n        }\n        return {\n          value: t,\n          done: y\n        };\n      };\n    }(r, o, i), !0), u;\n  }\n  var a = {};\n  function Generator() {}\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n  t = Object.getPrototypeOf;\n  var c = [][n] ? t(t([][n]())) : (regeneratorDefine(t = {}, n, function () {\n      return this;\n    }), t),\n    u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c);\n  function f(e) {\n    return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, regeneratorDefine(e, o, \"GeneratorFunction\")), e.prototype = Object.create(u), e;\n  }\n  return GeneratorFunction.prototype = GeneratorFunctionPrototype, regeneratorDefine(u, \"constructor\", GeneratorFunctionPrototype), regeneratorDefine(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction), GeneratorFunction.displayName = \"GeneratorFunction\", regeneratorDefine(GeneratorFunctionPrototype, o, \"GeneratorFunction\"), regeneratorDefine(u), regeneratorDefine(u, o, \"Generator\"), regeneratorDefine(u, n, function () {\n    return this;\n  }), regeneratorDefine(u, \"toString\", function () {\n    return \"[object Generator]\";\n  }), (module.exports = _regenerator = function _regenerator() {\n    return {\n      w: i,\n      m: f\n    };\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports)();\n}\nmodule.exports = _regenerator, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _regeneratorDefine(e, r, n, t) {\n  var i = Object.defineProperty;\n  try {\n    i({}, \"\", {});\n  } catch (e) {\n    i = 0;\n  }\n  module.exports = _regeneratorDefine = function regeneratorDefine(e, r, n, t) {\n    function o(r, n) {\n      _regeneratorDefine(e, r, function (e) {\n        return this._invoke(r, n, e);\n      });\n    }\n    r ? i ? i(e, r, {\n      value: n,\n      enumerable: !t,\n      configurable: !t,\n      writable: !t\n    }) : e[r] = n : (o(\"next\", 0), o(\"throw\", 1), o(\"return\", 2));\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _regeneratorDefine(e, r, n, t);\n}\nmodule.exports = _regeneratorDefine, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var regenerator = require(\"./regenerator.js\");\nvar regeneratorAsyncIterator = require(\"./regeneratorAsyncIterator.js\");\nfunction _regeneratorAsyncGen(r, e, t, o, n) {\n  return new regeneratorAsyncIterator(regenerator().w(r, e, t, o), n || Promise);\n}\nmodule.exports = _regeneratorAsyncGen, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var OverloadYield = require(\"./OverloadYield.js\");\nvar regeneratorDefine = require(\"./regeneratorDefine.js\");\nfunction AsyncIterator(t, e) {\n  function n(r, o, i, f) {\n    try {\n      var c = t[r](o),\n        u = c.value;\n      return u instanceof OverloadYield ? e.resolve(u.v).then(function (t) {\n        n(\"next\", t, i, f);\n      }, function (t) {\n        n(\"throw\", t, i, f);\n      }) : e.resolve(u).then(function (t) {\n        c.value = t, i(c);\n      }, function (t) {\n        return n(\"throw\", t, i, f);\n      });\n    } catch (t) {\n      f(t);\n    }\n  }\n  var r;\n  this.next || (regeneratorDefine(AsyncIterator.prototype), regeneratorDefine(AsyncIterator.prototype, \"function\" == typeof Symbol && Symbol.asyncIterator || \"@asyncIterator\", function () {\n    return this;\n  })), regeneratorDefine(this, \"_invoke\", function (t, o, i) {\n    function f() {\n      return new e(function (e, r) {\n        n(t, i, e, r);\n      });\n    }\n    return r = r ? r.then(f, f) : f();\n  }, !0);\n}\nmodule.exports = AsyncIterator, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableRest = require(\"./nonIterableRest.js\");\nfunction _slicedToArray(r, e) {\n  return arrayWithHoles(r) || iterableToArrayLimit(r, e) || unsupportedIterableToArray(r, e) || nonIterableRest();\n}\nmodule.exports = _slicedToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var basePick = require('./_basePick'),\n    flatRest = require('./_flatRest');\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\nvar pick = flatRest(function(object, paths) {\n  return object == null ? {} : basePick(object, paths);\n});\n\nmodule.exports = pick;\n","var getPrototypeOf = require(\"./getPrototypeOf.js\");\nvar setPrototypeOf = require(\"./setPrototypeOf.js\");\nvar isNativeFunction = require(\"./isNativeFunction.js\");\nvar construct = require(\"./construct.js\");\nfunction _wrapNativeSuper(t) {\n  var r = \"function\" == typeof Map ? new Map() : void 0;\n  return module.exports = _wrapNativeSuper = function _wrapNativeSuper(t) {\n    if (null === t || !isNativeFunction(t)) return t;\n    if (\"function\" != typeof t) throw new TypeError(\"Super expression must either be null or a function\");\n    if (void 0 !== r) {\n      if (r.has(t)) return r.get(t);\n      r.set(t, Wrapper);\n    }\n    function Wrapper() {\n      return construct(t, arguments, getPrototypeOf(this).constructor);\n    }\n    return Wrapper.prototype = Object.create(t.prototype, {\n      constructor: {\n        value: Wrapper,\n        enumerable: !1,\n        writable: !0,\n        configurable: !0\n      }\n    }), setPrototypeOf(Wrapper, t);\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _wrapNativeSuper(t);\n}\nmodule.exports = _wrapNativeSuper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var Stack = require('./_Stack'),\n    assignMergeValue = require('./_assignMergeValue'),\n    baseFor = require('./_baseFor'),\n    baseMergeDeep = require('./_baseMergeDeep'),\n    isObject = require('./isObject'),\n    keysIn = require('./keysIn'),\n    safeGet = require('./_safeGet');\n\n/**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n  if (object === source) {\n    return;\n  }\n  baseFor(source, function(srcValue, key) {\n    stack || (stack = new Stack);\n    if (isObject(srcValue)) {\n      baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n    }\n    else {\n      var newValue = customizer\n        ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\n        : undefined;\n\n      if (newValue === undefined) {\n        newValue = srcValue;\n      }\n      assignMergeValue(object, key, newValue);\n    }\n  }, keysIn);\n}\n\nmodule.exports = baseMerge;\n","var ListCache = require('./_ListCache'),\n    stackClear = require('./_stackClear'),\n    stackDelete = require('./_stackDelete'),\n    stackGet = require('./_stackGet'),\n    stackHas = require('./_stackHas'),\n    stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n  var data = this.__data__ = new ListCache(entries);\n  this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n  this.__data__ = [];\n  this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    return false;\n  }\n  var lastIndex = data.length - 1;\n  if (index == lastIndex) {\n    data.pop();\n  } else {\n    splice.call(data, index, 1);\n  }\n  --this.size;\n  return true;\n}\n\nmodule.exports = listCacheDelete;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n  return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    ++this.size;\n    data.push([key, value]);\n  } else {\n    data[index][1] = value;\n  }\n  return this;\n}\n\nmodule.exports = listCacheSet;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n  this.__data__ = new ListCache;\n  this.size = 0;\n}\n\nmodule.exports = stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n  var data = this.__data__,\n      result = data['delete'](key);\n\n  this.size = data.size;\n  return result;\n}\n\nmodule.exports = stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n  return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n  return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n","var ListCache = require('./_ListCache'),\n    Map = require('./_Map'),\n    MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n  var data = this.__data__;\n  if (data instanceof ListCache) {\n    var pairs = data.__data__;\n    if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n      pairs.push([key, value]);\n      this.size = ++data.size;\n      return this;\n    }\n    data = this.__data__ = new MapCache(pairs);\n  }\n  data.set(key, value);\n  this.size = data.size;\n  return this;\n}\n\nmodule.exports = stackSet;\n","var isFunction = require('./isFunction'),\n    isMasked = require('./_isMasked'),\n    isObject = require('./isObject'),\n    toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n *  else `false`.\n */\nfunction baseIsNative(value) {\n  if (!isObject(value) || isMasked(value)) {\n    return false;\n  }\n  var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n  return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n  var isOwn = hasOwnProperty.call(value, symToStringTag),\n      tag = value[symToStringTag];\n\n  try {\n    value[symToStringTag] = undefined;\n    var unmasked = true;\n  } catch (e) {}\n\n  var result = nativeObjectToString.call(value);\n  if (unmasked) {\n    if (isOwn) {\n      value[symToStringTag] = tag;\n    } else {\n      delete value[symToStringTag];\n    }\n  }\n  return result;\n}\n\nmodule.exports = getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n  return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n  return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n  if (func != null) {\n    try {\n      return funcToString.call(func);\n    } catch (e) {}\n    try {\n      return (func + '');\n    } catch (e) {}\n  }\n  return '';\n}\n\nmodule.exports = toSource;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","var Hash = require('./_Hash'),\n    ListCache = require('./_ListCache'),\n    Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n  this.size = 0;\n  this.__data__ = {\n    'hash': new Hash,\n    'map': new (Map || ListCache),\n    'string': new Hash\n  };\n}\n\nmodule.exports = mapCacheClear;\n","var hashClear = require('./_hashClear'),\n    hashDelete = require('./_hashDelete'),\n    hashGet = require('./_hashGet'),\n    hashHas = require('./_hashHas'),\n    hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n  this.__data__ = nativeCreate ? nativeCreate(null) : {};\n  this.size = 0;\n}\n\nmodule.exports = hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n  var result = this.has(key) && delete this.__data__[key];\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n  var data = this.__data__;\n  if (nativeCreate) {\n    var result = data[key];\n    return result === HASH_UNDEFINED ? undefined : result;\n  }\n  return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n  var data = this.__data__;\n  return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n  var data = this.__data__;\n  this.size += this.has(key) ? 0 : 1;\n  data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n  return this;\n}\n\nmodule.exports = hashSet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n  var result = getMapData(this, key)['delete'](key);\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nmodule.exports = mapCacheDelete;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n  var type = typeof value;\n  return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n    ? (value !== '__proto__')\n    : (value === null);\n}\n\nmodule.exports = isKeyable;\n","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n  return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n  return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n  var data = getMapData(this, key),\n      size = data.size;\n\n  data.set(key, value);\n  this.size += data.size == size ? 0 : 1;\n  return this;\n}\n\nmodule.exports = mapCacheSet;\n","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n  return function(object, iteratee, keysFunc) {\n    var index = -1,\n        iterable = Object(object),\n        props = keysFunc(object),\n        length = props.length;\n\n    while (length--) {\n      var key = props[fromRight ? length : ++index];\n      if (iteratee(iterable[key], key, iterable) === false) {\n        break;\n      }\n    }\n    return object;\n  };\n}\n\nmodule.exports = createBaseFor;\n","var assignMergeValue = require('./_assignMergeValue'),\n    cloneBuffer = require('./_cloneBuffer'),\n    cloneTypedArray = require('./_cloneTypedArray'),\n    copyArray = require('./_copyArray'),\n    initCloneObject = require('./_initCloneObject'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isArrayLikeObject = require('./isArrayLikeObject'),\n    isBuffer = require('./isBuffer'),\n    isFunction = require('./isFunction'),\n    isObject = require('./isObject'),\n    isPlainObject = require('./isPlainObject'),\n    isTypedArray = require('./isTypedArray'),\n    safeGet = require('./_safeGet'),\n    toPlainObject = require('./toPlainObject');\n\n/**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n  var objValue = safeGet(object, key),\n      srcValue = safeGet(source, key),\n      stacked = stack.get(srcValue);\n\n  if (stacked) {\n    assignMergeValue(object, key, stacked);\n    return;\n  }\n  var newValue = customizer\n    ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n    : undefined;\n\n  var isCommon = newValue === undefined;\n\n  if (isCommon) {\n    var isArr = isArray(srcValue),\n        isBuff = !isArr && isBuffer(srcValue),\n        isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n    newValue = srcValue;\n    if (isArr || isBuff || isTyped) {\n      if (isArray(objValue)) {\n        newValue = objValue;\n      }\n      else if (isArrayLikeObject(objValue)) {\n        newValue = copyArray(objValue);\n      }\n      else if (isBuff) {\n        isCommon = false;\n        newValue = cloneBuffer(srcValue, true);\n      }\n      else if (isTyped) {\n        isCommon = false;\n        newValue = cloneTypedArray(srcValue, true);\n      }\n      else {\n        newValue = [];\n      }\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      newValue = objValue;\n      if (isArguments(objValue)) {\n        newValue = toPlainObject(objValue);\n      }\n      else if (!isObject(objValue) || isFunction(objValue)) {\n        newValue = initCloneObject(srcValue);\n      }\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    stack.set(srcValue, newValue);\n    mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n    stack['delete'](srcValue);\n  }\n  assignMergeValue(object, key, newValue);\n}\n\nmodule.exports = baseMergeDeep;\n","var root = require('./_root');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n    allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of  `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n  if (isDeep) {\n    return buffer.slice();\n  }\n  var length = buffer.length,\n      result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n  buffer.copy(result);\n  return result;\n}\n\nmodule.exports = cloneBuffer;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n  new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n  return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n  var index = -1,\n      length = source.length;\n\n  array || (array = Array(length));\n  while (++index < length) {\n    array[index] = source[index];\n  }\n  return array;\n}\n\nmodule.exports = copyArray;\n","var baseCreate = require('./_baseCreate'),\n    getPrototype = require('./_getPrototype'),\n    isPrototype = require('./_isPrototype');\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n  return (typeof object.constructor == 'function' && !isPrototype(object))\n    ? baseCreate(getPrototype(object))\n    : {};\n}\n\nmodule.exports = initCloneObject;\n","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n  function object() {}\n  return function(proto) {\n    if (!isObject(proto)) {\n      return {};\n    }\n    if (objectCreate) {\n      return objectCreate(proto);\n    }\n    object.prototype = proto;\n    var result = new object;\n    object.prototype = undefined;\n    return result;\n  };\n}());\n\nmodule.exports = baseCreate;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\n}\n\nmodule.exports = overArg;\n","var baseGetTag = require('./_baseGetTag'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n  return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n","var isArrayLike = require('./isArrayLike'),\n    isObjectLike = require('./isObjectLike');\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n *  else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\n}\n\nmodule.exports = isArrayLikeObject;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n  return false;\n}\n\nmodule.exports = stubFalse;\n","var baseGetTag = require('./_baseGetTag'),\n    getPrototype = require('./_getPrototype'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n  if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n    return false;\n  }\n  var proto = getPrototype(value);\n  if (proto === null) {\n    return true;\n  }\n  var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n  return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n    funcToString.call(Ctor) == objectCtorString;\n}\n\nmodule.exports = isPlainObject;\n","var baseGetTag = require('./_baseGetTag'),\n    isLength = require('./isLength'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n  return function(value) {\n    return func(value);\n  };\n}\n\nmodule.exports = baseUnary;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n  try {\n    // Use `util.types` for Node.js 10+.\n    var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n    if (types) {\n      return types;\n    }\n\n    // Legacy `process.binding('util')` for Node.js < 10.\n    return freeProcess && freeProcess.binding && freeProcess.binding('util');\n  } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n","var copyObject = require('./_copyObject'),\n    keysIn = require('./keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\nfunction toPlainObject(value) {\n  return copyObject(value, keysIn(value));\n}\n\nmodule.exports = toPlainObject;\n","var assignValue = require('./_assignValue'),\n    baseAssignValue = require('./_baseAssignValue');\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n  var isNew = !object;\n  object || (object = {});\n\n  var index = -1,\n      length = props.length;\n\n  while (++index < length) {\n    var key = props[index];\n\n    var newValue = customizer\n      ? customizer(object[key], source[key], key, object, source)\n      : undefined;\n\n    if (newValue === undefined) {\n      newValue = source[key];\n    }\n    if (isNew) {\n      baseAssignValue(object, key, newValue);\n    } else {\n      assignValue(object, key, newValue);\n    }\n  }\n  return object;\n}\n\nmodule.exports = copyObject;\n","var baseTimes = require('./_baseTimes'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isBuffer = require('./isBuffer'),\n    isIndex = require('./_isIndex'),\n    isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n  var isArr = isArray(value),\n      isArg = !isArr && isArguments(value),\n      isBuff = !isArr && !isArg && isBuffer(value),\n      isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n      skipIndexes = isArr || isArg || isBuff || isType,\n      result = skipIndexes ? baseTimes(value.length, String) : [],\n      length = result.length;\n\n  for (var key in value) {\n    if ((inherited || hasOwnProperty.call(value, key)) &&\n        !(skipIndexes && (\n           // Safari 9 has enumerable `arguments.length` in strict mode.\n           key == 'length' ||\n           // Node.js 0.10 has enumerable non-index properties on buffers.\n           (isBuff && (key == 'offset' || key == 'parent')) ||\n           // PhantomJS 2 has enumerable non-index properties on typed arrays.\n           (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n           // Skip index properties.\n           isIndex(key, length)\n        ))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = arrayLikeKeys;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n  var index = -1,\n      result = Array(n);\n\n  while (++index < n) {\n    result[index] = iteratee(index);\n  }\n  return result;\n}\n\nmodule.exports = baseTimes;\n","var isObject = require('./isObject'),\n    isPrototype = require('./_isPrototype'),\n    nativeKeysIn = require('./_nativeKeysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n  if (!isObject(object)) {\n    return nativeKeysIn(object);\n  }\n  var isProto = isPrototype(object),\n      result = [];\n\n  for (var key in object) {\n    if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = baseKeysIn;\n","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n  var result = [];\n  if (object != null) {\n    for (var key in Object(object)) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = nativeKeysIn;\n","var baseRest = require('./_baseRest'),\n    isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\nfunction createAssigner(assigner) {\n  return baseRest(function(object, sources) {\n    var index = -1,\n        length = sources.length,\n        customizer = length > 1 ? sources[length - 1] : undefined,\n        guard = length > 2 ? sources[2] : undefined;\n\n    customizer = (assigner.length > 3 && typeof customizer == 'function')\n      ? (length--, customizer)\n      : undefined;\n\n    if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n      customizer = length < 3 ? undefined : customizer;\n      length = 1;\n    }\n    object = Object(object);\n    while (++index < length) {\n      var source = sources[index];\n      if (source) {\n        assigner(object, source, index, customizer);\n      }\n    }\n    return object;\n  });\n}\n\nmodule.exports = createAssigner;\n","var identity = require('./identity'),\n    overRest = require('./_overRest'),\n    setToString = require('./_setToString');\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n  return setToString(overRest(func, start, identity), func + '');\n}\n\nmodule.exports = baseRest;\n","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n  switch (args.length) {\n    case 0: return func.call(thisArg);\n    case 1: return func.call(thisArg, args[0]);\n    case 2: return func.call(thisArg, args[0], args[1]);\n    case 3: return func.call(thisArg, args[0], args[1], args[2]);\n  }\n  return func.apply(thisArg, args);\n}\n\nmodule.exports = apply;\n","var constant = require('./constant'),\n    defineProperty = require('./_defineProperty'),\n    identity = require('./identity');\n\n/**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar baseSetToString = !defineProperty ? identity : function(func, string) {\n  return defineProperty(func, 'toString', {\n    'configurable': true,\n    'enumerable': false,\n    'value': constant(string),\n    'writable': true\n  });\n};\n\nmodule.exports = baseSetToString;\n","/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\nfunction constant(value) {\n  return function() {\n    return value;\n  };\n}\n\nmodule.exports = constant;\n","/** Used to detect hot functions by number of calls within a span of milliseconds. */\nvar HOT_COUNT = 800,\n    HOT_SPAN = 16;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeNow = Date.now;\n\n/**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\nfunction shortOut(func) {\n  var count = 0,\n      lastCalled = 0;\n\n  return function() {\n    var stamp = nativeNow(),\n        remaining = HOT_SPAN - (stamp - lastCalled);\n\n    lastCalled = stamp;\n    if (remaining > 0) {\n      if (++count >= HOT_COUNT) {\n        return arguments[0];\n      }\n    } else {\n      count = 0;\n    }\n    return func.apply(undefined, arguments);\n  };\n}\n\nmodule.exports = shortOut;\n","var eq = require('./eq'),\n    isArrayLike = require('./isArrayLike'),\n    isIndex = require('./_isIndex'),\n    isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n *  else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n  if (!isObject(object)) {\n    return false;\n  }\n  var type = typeof index;\n  if (type == 'number'\n        ? (isArrayLike(object) && isIndex(index, object.length))\n        : (type == 'string' && index in object)\n      ) {\n    return eq(object[index], value);\n  }\n  return false;\n}\n\nmodule.exports = isIterateeCall;\n","/*\n * typedefs.js\n * Normalizes browser-specific prefixes and provide some basic polyfills\n */\n\nif (typeof window !== 'undefined') {\n    if (!window.requestAnimationFrame) {\n        window.requestAnimationFrame = (function () {\n            return window.webkitRequestAnimationFrame\n                || window.mozRequestAnimationFrame\n                || window.oRequestAnimationFrame\n                || window.msRequestAnimationFrame\n                || function (/* function FrameRequestCallback */ callback) {\n                    window.setTimeout(callback, 1000 / 60);\n                };\n        }());\n    }\n}\n\nif (typeof Math.imul !== 'function') {\n    /* eslint-disable no-bitwise */\n    Math.imul = function (a, b) {\n        const ah = (a >>> 16) & 0xffff;\n        const al = a & 0xffff;\n        const bh = (b >>> 16) & 0xffff;\n        const bl = b & 0xffff;\n        // the shift by 0 fixes the sign on the high part\n        // the final |0 converts the unsigned value into a signed value\n        return ((al * bl) + (((ah * bl + al * bh) << 16) >>> 0) | 0);\n    };\n    /* eslint-enable no-bitwise */\n}\n\nif (typeof Object.assign !== 'function') {\n    Object.assign = function (target) { // .length of function is 2\n\n'use strict';\n\n        if (target === null) { // TypeError if undefined or null\n            throw new TypeError('Cannot convert undefined or null to object');\n        }\n\n        const to = Object(target);\n\n        for (let index = 1; index < arguments.length; index++) {\n            // eslint-disable-next-line prefer-rest-params\n            const nextSource = arguments[index];\n\n            if (nextSource !== null) { // Skip over if undefined or null\n                // eslint-disable-next-line no-restricted-syntax\n                for (const nextKey in nextSource) {\n                    // Avoid bugs when hasOwnProperty is shadowed\n                    if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {\n                        to[nextKey] = nextSource[nextKey];\n                    }\n                }\n            }\n        }\n        return to;\n    };\n}\n","function _arrayWithHoles(r) {\n  if (Array.isArray(r)) return r;\n}\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArrayLimit(r, l) {\n  var t = null == r ? null : \"undefined\" != typeof Symbol && r[Symbol.iterator] || r[\"@@iterator\"];\n  if (null != t) {\n    var e,\n      n,\n      i,\n      u,\n      a = [],\n      f = !0,\n      o = !1;\n    try {\n      if (i = (t = t.call(r)).next, 0 === l) {\n        if (Object(t) !== t) return;\n        f = !1;\n      } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);\n    } catch (r) {\n      o = !0, n = r;\n    } finally {\n      try {\n        if (!f && null != t[\"return\"] && (u = t[\"return\"](), Object(u) !== u)) return;\n      } finally {\n        if (o) throw n;\n      }\n    }\n    return a;\n  }\n}\nmodule.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableRest() {\n  throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction toPrimitive(t, r) {\n  if (\"object\" != _typeof(t) || !t) return t;\n  var e = t[Symbol.toPrimitive];\n  if (void 0 !== e) {\n    var i = e.call(t, r || \"default\");\n    if (\"object\" != _typeof(i)) return i;\n    throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n  }\n  return (\"string\" === r ? String : Number)(t);\n}\nmodule.exports = toPrimitive, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var OverloadYield = require(\"./OverloadYield.js\");\nvar regenerator = require(\"./regenerator.js\");\nvar regeneratorAsync = require(\"./regeneratorAsync.js\");\nvar regeneratorAsyncGen = require(\"./regeneratorAsyncGen.js\");\nvar regeneratorAsyncIterator = require(\"./regeneratorAsyncIterator.js\");\nvar regeneratorKeys = require(\"./regeneratorKeys.js\");\nvar regeneratorValues = require(\"./regeneratorValues.js\");\nfunction _regeneratorRuntime() {\n  \"use strict\";\n\n  var r = regenerator(),\n    e = r.m(_regeneratorRuntime),\n    t = (Object.getPrototypeOf ? Object.getPrototypeOf(e) : e.__proto__).constructor;\n  function n(r) {\n    var e = \"function\" == typeof r && r.constructor;\n    return !!e && (e === t || \"GeneratorFunction\" === (e.displayName || e.name));\n  }\n  var o = {\n    \"throw\": 1,\n    \"return\": 2,\n    \"break\": 3,\n    \"continue\": 3\n  };\n  function a(r) {\n    var e, t;\n    return function (n) {\n      e || (e = {\n        stop: function stop() {\n          return t(n.a, 2);\n        },\n        \"catch\": function _catch() {\n          return n.v;\n        },\n        abrupt: function abrupt(r, e) {\n          return t(n.a, o[r], e);\n        },\n        delegateYield: function delegateYield(r, o, a) {\n          return e.resultName = o, t(n.d, regeneratorValues(r), a);\n        },\n        finish: function finish(r) {\n          return t(n.f, r);\n        }\n      }, t = function t(r, _t, o) {\n        n.p = e.prev, n.n = e.next;\n        try {\n          return r(_t, o);\n        } finally {\n          e.next = n.n;\n        }\n      }), e.resultName && (e[e.resultName] = n.v, e.resultName = void 0), e.sent = n.v, e.next = n.n;\n      try {\n        return r.call(this, e);\n      } finally {\n        n.p = e.prev, n.n = e.next;\n      }\n    };\n  }\n  return (module.exports = _regeneratorRuntime = function _regeneratorRuntime() {\n    return {\n      wrap: function wrap(e, t, n, o) {\n        return r.w(a(e), t, n, o && o.reverse());\n      },\n      isGeneratorFunction: n,\n      mark: r.m,\n      awrap: function awrap(r, e) {\n        return new OverloadYield(r, e);\n      },\n      AsyncIterator: regeneratorAsyncIterator,\n      async: function async(r, e, t, o, u) {\n        return (n(e) ? regeneratorAsyncGen : regeneratorAsync)(a(r), e, t, o, u);\n      },\n      keys: regeneratorKeys,\n      values: regeneratorValues\n    };\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports)();\n}\nmodule.exports = _regeneratorRuntime, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var regeneratorAsyncGen = require(\"./regeneratorAsyncGen.js\");\nfunction _regeneratorAsync(n, e, r, t, o) {\n  var a = regeneratorAsyncGen(n, e, r, t, o);\n  return a.next().then(function (n) {\n    return n.done ? n.value : a.next();\n  });\n}\nmodule.exports = _regeneratorAsync, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _regeneratorKeys(e) {\n  var n = Object(e),\n    r = [];\n  for (var t in n) r.unshift(t);\n  return function e() {\n    for (; r.length;) if ((t = r.pop()) in n) return e.value = t, e.done = !1, e;\n    return e.done = !0, e;\n  };\n}\nmodule.exports = _regeneratorKeys, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction _regeneratorValues(e) {\n  if (null != e) {\n    var t = e[\"function\" == typeof Symbol && Symbol.iterator || \"@@iterator\"],\n      r = 0;\n    if (t) return t.call(e);\n    if (\"function\" == typeof e.next) return e;\n    if (!isNaN(e.length)) return {\n      next: function next() {\n        return e && r >= e.length && (e = void 0), {\n          value: e && e[r++],\n          done: !e\n        };\n      }\n    };\n  }\n  throw new TypeError(_typeof(e) + \" is not iterable\");\n}\nmodule.exports = _regeneratorValues, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _assertThisInitialized(e) {\n  if (void 0 === e) throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n  return e;\n}\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\nfunction _superPropBase(t, o) {\n  for (; !{}.hasOwnProperty.call(t, o) && null !== (t = getPrototypeOf(t)););\n  return t;\n}\nmodule.exports = _superPropBase, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _arrayWithoutHoles(r) {\n  if (Array.isArray(r)) return arrayLikeToArray(r);\n}\nmodule.exports = _arrayWithoutHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArray(r) {\n  if (\"undefined\" != typeof Symbol && null != r[Symbol.iterator] || null != r[\"@@iterator\"]) return Array.from(r);\n}\nmodule.exports = _iterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableSpread() {\n  throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableSpread, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var basePickBy = require('./_basePickBy'),\n    hasIn = require('./hasIn');\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, paths) {\n  return basePickBy(object, paths, function(value, path) {\n    return hasIn(object, path);\n  });\n}\n\nmodule.exports = basePick;\n","var baseGet = require('./_baseGet'),\n    baseSet = require('./_baseSet'),\n    castPath = require('./_castPath');\n\n/**\n * The base implementation of  `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\nfunction basePickBy(object, paths, predicate) {\n  var index = -1,\n      length = paths.length,\n      result = {};\n\n  while (++index < length) {\n    var path = paths[index],\n        value = baseGet(object, path);\n\n    if (predicate(value, path)) {\n      baseSet(result, castPath(path, object), value);\n    }\n  }\n  return result;\n}\n\nmodule.exports = basePickBy;\n","var castPath = require('./_castPath'),\n    toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n  path = castPath(path, object);\n\n  var index = 0,\n      length = path.length;\n\n  while (object != null && index < length) {\n    object = object[toKey(path[index++])];\n  }\n  return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","var isArray = require('./isArray'),\n    isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n    reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n  if (isArray(value)) {\n    return false;\n  }\n  var type = typeof value;\n  if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n      value == null || isSymbol(value)) {\n    return true;\n  }\n  return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n    (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n  var result = [];\n  if (string.charCodeAt(0) === 46 /* . */) {\n    result.push('');\n  }\n  string.replace(rePropName, function(match, number, quote, subString) {\n    result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n  });\n  return result;\n});\n\nmodule.exports = stringToPath;\n","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n  var result = memoize(func, function(key) {\n    if (cache.size === MAX_MEMOIZE_SIZE) {\n      cache.clear();\n    }\n    return key;\n  });\n\n  var cache = result.cache;\n  return result;\n}\n\nmodule.exports = memoizeCapped;\n","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n  if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  var memoized = function() {\n    var args = arguments,\n        key = resolver ? resolver.apply(this, args) : args[0],\n        cache = memoized.cache;\n\n    if (cache.has(key)) {\n      return cache.get(key);\n    }\n    var result = func.apply(this, args);\n    memoized.cache = cache.set(key, result) || cache;\n    return result;\n  };\n  memoized.cache = new (memoize.Cache || MapCache);\n  return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n  return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n","var Symbol = require('./_Symbol'),\n    arrayMap = require('./_arrayMap'),\n    isArray = require('./isArray'),\n    isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n  // Exit early for strings to avoid a performance hit in some environments.\n  if (typeof value == 'string') {\n    return value;\n  }\n  if (isArray(value)) {\n    // Recursively convert values (susceptible to call stack limits).\n    return arrayMap(value, baseToString) + '';\n  }\n  if (isSymbol(value)) {\n    return symbolToString ? symbolToString.call(value) : '';\n  }\n  var result = (value + '');\n  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n  var index = -1,\n      length = array == null ? 0 : array.length,\n      result = Array(length);\n\n  while (++index < length) {\n    result[index] = iteratee(array[index], index, array);\n  }\n  return result;\n}\n\nmodule.exports = arrayMap;\n","var assignValue = require('./_assignValue'),\n    castPath = require('./_castPath'),\n    isIndex = require('./_isIndex'),\n    isObject = require('./isObject'),\n    toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n  if (!isObject(object)) {\n    return object;\n  }\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length,\n      lastIndex = length - 1,\n      nested = object;\n\n  while (nested != null && ++index < length) {\n    var key = toKey(path[index]),\n        newValue = value;\n\n    if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n      return object;\n    }\n\n    if (index != lastIndex) {\n      var objValue = nested[key];\n      newValue = customizer ? customizer(objValue, key, nested) : undefined;\n      if (newValue === undefined) {\n        newValue = isObject(objValue)\n          ? objValue\n          : (isIndex(path[index + 1]) ? [] : {});\n      }\n    }\n    assignValue(nested, key, newValue);\n    nested = nested[key];\n  }\n  return object;\n}\n\nmodule.exports = baseSet;\n","var baseHasIn = require('./_baseHasIn'),\n    hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n  return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\n","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n  return object != null && key in Object(object);\n}\n\nmodule.exports = baseHasIn;\n","var castPath = require('./_castPath'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isIndex = require('./_isIndex'),\n    isLength = require('./isLength'),\n    toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length,\n      result = false;\n\n  while (++index < length) {\n    var key = toKey(path[index]);\n    if (!(result = object != null && hasFunc(object, key))) {\n      break;\n    }\n    object = object[key];\n  }\n  if (result || ++index != length) {\n    return result;\n  }\n  length = object == null ? 0 : object.length;\n  return !!length && isLength(length) && isIndex(key, length) &&\n    (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n","var flatten = require('./flatten'),\n    overRest = require('./_overRest'),\n    setToString = require('./_setToString');\n\n/**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\nfunction flatRest(func) {\n  return setToString(overRest(func, undefined, flatten), func + '');\n}\n\nmodule.exports = flatRest;\n","var baseFlatten = require('./_baseFlatten');\n\n/**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\nfunction flatten(array) {\n  var length = array == null ? 0 : array.length;\n  return length ? baseFlatten(array, 1) : [];\n}\n\nmodule.exports = flatten;\n","var arrayPush = require('./_arrayPush'),\n    isFlattenable = require('./_isFlattenable');\n\n/**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, predicate, isStrict, result) {\n  var index = -1,\n      length = array.length;\n\n  predicate || (predicate = isFlattenable);\n  result || (result = []);\n\n  while (++index < length) {\n    var value = array[index];\n    if (depth > 0 && predicate(value)) {\n      if (depth > 1) {\n        // Recursively flatten arrays (susceptible to call stack limits).\n        baseFlatten(value, depth - 1, predicate, isStrict, result);\n      } else {\n        arrayPush(result, value);\n      }\n    } else if (!isStrict) {\n      result[result.length] = value;\n    }\n  }\n  return result;\n}\n\nmodule.exports = baseFlatten;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n  var index = -1,\n      length = values.length,\n      offset = array.length;\n\n  while (++index < length) {\n    array[offset + index] = values[index];\n  }\n  return array;\n}\n\nmodule.exports = arrayPush;\n","var Symbol = require('./_Symbol'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray');\n\n/** Built-in value references. */\nvar spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;\n\n/**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\nfunction isFlattenable(value) {\n  return isArray(value) || isArguments(value) ||\n    !!(spreadableSymbol && value && value[spreadableSymbol]);\n}\n\nmodule.exports = isFlattenable;\n","function _isNativeFunction(t) {\n  try {\n    return -1 !== Function.toString.call(t).indexOf(\"[native code]\");\n  } catch (n) {\n    return \"function\" == typeof t;\n  }\n}\nmodule.exports = _isNativeFunction, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var isNativeReflectConstruct = require(\"./isNativeReflectConstruct.js\");\nvar setPrototypeOf = require(\"./setPrototypeOf.js\");\nfunction _construct(t, e, r) {\n  if (isNativeReflectConstruct()) return Reflect.construct.apply(null, arguments);\n  var o = [null];\n  o.push.apply(o, e);\n  var p = new (t.bind.apply(t, o))();\n  return r && setPrototypeOf(p, r.prototype), p;\n}\nmodule.exports = _construct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _isNativeReflectConstruct() {\n  try {\n    var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n  } catch (t) {}\n  return (module.exports = _isNativeReflectConstruct = function _isNativeReflectConstruct() {\n    return !!t;\n  }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports)();\n}\nmodule.exports = _isNativeReflectConstruct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\n * Common utilities\n * @module glMatrix\n */\n\n// Configuration Constants\nexport var EPSILON = 0.000001;\nexport var ARRAY_TYPE = typeof Float32Array !== \"undefined\" ? Float32Array : Array;\nexport var RANDOM = Math.random;\nexport var ANGLE_ORDER = \"zyx\";\n\n/**\n * Symmetric round\n * see https://www.npmjs.com/package/round-half-up-symmetric#user-content-detailed-background\n *\n * @param {Number} a value to round\n */\nexport function round(a) {\n  if (a >= 0) return Math.round(a);\n  return a % 0.5 === 0 ? Math.floor(a) : Math.round(a);\n}\n\n/**\n * Sets the type of array used when creating new vectors and matrices\n *\n * @param {Float32ArrayConstructor | ArrayConstructor} type Array type, such as Float32Array or Array\n */\nexport function setMatrixArrayType(type) {\n  ARRAY_TYPE = type;\n}\nvar degree = Math.PI / 180;\nvar radian = 180 / Math.PI;\n\n/**\n * Convert Degree To Radian\n *\n * @param {Number} a Angle in Degrees\n */\nexport function toRadian(a) {\n  return a * degree;\n}\n\n/**\n * Convert Radian To Degree\n *\n * @param {Number} a Angle in Radians\n */\nexport function toDegree(a) {\n  return a * radian;\n}\n\n/**\n * Tests whether or not the arguments have approximately the same value, within an absolute\n * or relative tolerance of glMatrix.EPSILON (an absolute tolerance is used for values less\n * than or equal to 1.0, and a relative tolerance is used for larger values)\n *\n * @param {Number} a          The first number to test.\n * @param {Number} b          The second number to test.\n * @param {Number} tolerance  Absolute or relative tolerance (default glMatrix.EPSILON)\n * @returns {Boolean} True if the numbers are approximately equal, false otherwise.\n */\nexport function equals(a, b) {\n  var tolerance = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : EPSILON;\n  return Math.abs(a - b) <= tolerance * Math.max(1, Math.abs(a), Math.abs(b));\n}","import * as glMatrix from \"./common.js\";\n\n/**\n * 2x2 Matrix\n * @module mat2\n */\n\n/**\n * Creates a new identity mat2\n *\n * @returns {mat2} a new 2x2 matrix\n */\nexport function create() {\n  var out = new glMatrix.ARRAY_TYPE(4);\n  if (glMatrix.ARRAY_TYPE != Float32Array) {\n    out[1] = 0;\n    out[2] = 0;\n  }\n  out[0] = 1;\n  out[3] = 1;\n  return out;\n}\n\n/**\n * Creates a new mat2 initialized with values from an existing matrix\n *\n * @param {ReadonlyMat2} a matrix to clone\n * @returns {mat2} a new 2x2 matrix\n */\nexport function clone(a) {\n  var out = new glMatrix.ARRAY_TYPE(4);\n  out[0] = a[0];\n  out[1] = a[1];\n  out[2] = a[2];\n  out[3] = a[3];\n  return out;\n}\n\n/**\n * Copy the values from one mat2 to another\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\nexport function copy(out, a) {\n  out[0] = a[0];\n  out[1] = a[1];\n  out[2] = a[2];\n  out[3] = a[3];\n  return out;\n}\n\n/**\n * Set a mat2 to the identity matrix\n *\n * @param {mat2} out the receiving matrix\n * @returns {mat2} out\n */\nexport function identity(out) {\n  out[0] = 1;\n  out[1] = 0;\n  out[2] = 0;\n  out[3] = 1;\n  return out;\n}\n\n/**\n * Create a new mat2 with the given values\n *\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m10 Component in column 1, row 0 position (index 2)\n * @param {Number} m11 Component in column 1, row 1 position (index 3)\n * @returns {mat2} out A new 2x2 matrix\n */\nexport function fromValues(m00, m01, m10, m11) {\n  var out = new glMatrix.ARRAY_TYPE(4);\n  out[0] = m00;\n  out[1] = m01;\n  out[2] = m10;\n  out[3] = m11;\n  return out;\n}\n\n/**\n * Set the components of a mat2 to the given values\n *\n * @param {mat2} out the receiving matrix\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m10 Component in column 1, row 0 position (index 2)\n * @param {Number} m11 Component in column 1, row 1 position (index 3)\n * @returns {mat2} out\n */\nexport function set(out, m00, m01, m10, m11) {\n  out[0] = m00;\n  out[1] = m01;\n  out[2] = m10;\n  out[3] = m11;\n  return out;\n}\n\n/**\n * Transpose the values of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\nexport function transpose(out, a) {\n  // If we are transposing ourselves we can skip a few steps but have to cache\n  // some values\n  if (out === a) {\n    var a1 = a[1];\n    out[1] = a[2];\n    out[2] = a1;\n  } else {\n    out[0] = a[0];\n    out[1] = a[2];\n    out[2] = a[1];\n    out[3] = a[3];\n  }\n  return out;\n}\n\n/**\n * Inverts a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2 | null} out, or null if source matrix is not invertible\n */\nexport function invert(out, a) {\n  var a0 = a[0],\n    a1 = a[1],\n    a2 = a[2],\n    a3 = a[3];\n\n  // Calculate the determinant\n  var det = a0 * a3 - a2 * a1;\n  if (!det) {\n    return null;\n  }\n  det = 1.0 / det;\n  out[0] = a3 * det;\n  out[1] = -a1 * det;\n  out[2] = -a2 * det;\n  out[3] = a0 * det;\n  return out;\n}\n\n/**\n * Calculates the adjugate of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\nexport function adjoint(out, a) {\n  // Caching this value is necessary if out == a\n  var a0 = a[0];\n  out[0] = a[3];\n  out[1] = -a[1];\n  out[2] = -a[2];\n  out[3] = a0;\n  return out;\n}\n\n/**\n * Calculates the determinant of a mat2\n *\n * @param {ReadonlyMat2} a the source matrix\n * @returns {Number} determinant of a\n */\nexport function determinant(a) {\n  return a[0] * a[3] - a[2] * a[1];\n}\n\n/**\n * Multiplies two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\nexport function multiply(out, a, b) {\n  var a0 = a[0],\n    a1 = a[1],\n    a2 = a[2],\n    a3 = a[3];\n  var b0 = b[0],\n    b1 = b[1],\n    b2 = b[2],\n    b3 = b[3];\n  out[0] = a0 * b0 + a2 * b1;\n  out[1] = a1 * b0 + a3 * b1;\n  out[2] = a0 * b2 + a2 * b3;\n  out[3] = a1 * b2 + a3 * b3;\n  return out;\n}\n\n/**\n * Rotates a mat2 by the given angle\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\nexport function rotate(out, a, rad) {\n  var a0 = a[0],\n    a1 = a[1],\n    a2 = a[2],\n    a3 = a[3];\n  var s = Math.sin(rad);\n  var c = Math.cos(rad);\n  out[0] = a0 * c + a2 * s;\n  out[1] = a1 * c + a3 * s;\n  out[2] = a0 * -s + a2 * c;\n  out[3] = a1 * -s + a3 * c;\n  return out;\n}\n\n/**\n * Scales the mat2 by the dimensions in the given vec2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to rotate\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\n * @returns {mat2} out\n **/\nexport function scale(out, a, v) {\n  var a0 = a[0],\n    a1 = a[1],\n    a2 = a[2],\n    a3 = a[3];\n  var v0 = v[0],\n    v1 = v[1];\n  out[0] = a0 * v0;\n  out[1] = a1 * v0;\n  out[2] = a2 * v1;\n  out[3] = a3 * v1;\n  return out;\n}\n\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n *     mat2.identity(dest);\n *     mat2.rotate(dest, dest, rad);\n *\n * @param {mat2} out mat2 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\nexport function fromRotation(out, rad) {\n  var s = Math.sin(rad);\n  var c = Math.cos(rad);\n  out[0] = c;\n  out[1] = s;\n  out[2] = -s;\n  out[3] = c;\n  return out;\n}\n\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n *     mat2.identity(dest);\n *     mat2.scale(dest, dest, vec);\n *\n * @param {mat2} out mat2 receiving operation result\n * @param {ReadonlyVec2} v Scaling vector\n * @returns {mat2} out\n */\nexport function fromScaling(out, v) {\n  out[0] = v[0];\n  out[1] = 0;\n  out[2] = 0;\n  out[3] = v[1];\n  return out;\n}\n\n/**\n * Returns a string representation of a mat2\n *\n * @param {ReadonlyMat2} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nexport function str(a) {\n  return \"mat2(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n\n/**\n * Returns Frobenius norm of a mat2\n *\n * @param {ReadonlyMat2} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nexport function frob(a) {\n  return Math.sqrt(a[0] * a[0] + a[1] * a[1] + a[2] * a[2] + a[3] * a[3]);\n}\n\n/**\n * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix\n * @param {ReadonlyMat2} L the lower triangular matrix\n * @param {ReadonlyMat2} D the diagonal matrix\n * @param {ReadonlyMat2} U the upper triangular matrix\n * @param {ReadonlyMat2} a the input matrix to factorize\n */\n\nexport function LDU(L, D, U, a) {\n  L[2] = a[2] / a[0];\n  U[0] = a[0];\n  U[1] = a[1];\n  U[3] = a[3] - L[2] * U[1];\n  return [L, D, U];\n}\n\n/**\n * Adds two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\nexport function add(out, a, b) {\n  out[0] = a[0] + b[0];\n  out[1] = a[1] + b[1];\n  out[2] = a[2] + b[2];\n  out[3] = a[3] + b[3];\n  return out;\n}\n\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\nexport function subtract(out, a, b) {\n  out[0] = a[0] - b[0];\n  out[1] = a[1] - b[1];\n  out[2] = a[2] - b[2];\n  out[3] = a[3] - b[3];\n  return out;\n}\n\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat2} a The first matrix.\n * @param {ReadonlyMat2} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\nexport function exactEquals(a, b) {\n  return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];\n}\n\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat2} a The first matrix.\n * @param {ReadonlyMat2} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\nexport function equals(a, b) {\n  var a0 = a[0],\n    a1 = a[1],\n    a2 = a[2],\n    a3 = a[3];\n  var b0 = b[0],\n    b1 = b[1],\n    b2 = b[2],\n    b3 = b[3];\n  return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3));\n}\n\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat2} out\n */\nexport function multiplyScalar(out, a, b) {\n  out[0] = a[0] * b;\n  out[1] = a[1] * b;\n  out[2] = a[2] * b;\n  out[3] = a[3] * b;\n  return out;\n}\n\n/**\n * Adds two mat2's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat2} out the receiving vector\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat2} out\n */\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n  out[0] = a[0] + b[0] * scale;\n  out[1] = a[1] + b[1] * scale;\n  out[2] = a[2] + b[2] * scale;\n  out[3] = a[3] + b[3] * scale;\n  return out;\n}\n\n/**\n * Alias for {@link mat2.multiply}\n * @function\n */\nexport var mul = multiply;\n\n/**\n * Alias for {@link mat2.subtract}\n * @function\n */\nexport var sub = subtract;","import * as glMatrix from \"./common.js\";\n\n/**\n * 2 Dimensional Vector\n * @module vec2\n */\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\nexport function create() {\n  var out = new glMatrix.ARRAY_TYPE(2);\n  if (glMatrix.ARRAY_TYPE != Float32Array) {\n    out[0] = 0;\n    out[1] = 0;\n  }\n  return out;\n}\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {ReadonlyVec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nexport function clone(a) {\n  var out = new glMatrix.ARRAY_TYPE(2);\n  out[0] = a[0];\n  out[1] = a[1];\n  return out;\n}\n\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\nexport function fromValues(x, y) {\n  var out = new glMatrix.ARRAY_TYPE(2);\n  out[0] = x;\n  out[1] = y;\n  return out;\n}\n\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the source vector\n * @returns {vec2} out\n */\nexport function copy(out, a) {\n  out[0] = a[0];\n  out[1] = a[1];\n  return out;\n}\n\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\nexport function set(out, x, y) {\n  out[0] = x;\n  out[1] = y;\n  return out;\n}\n\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\nexport function add(out, a, b) {\n  out[0] = a[0] + b[0];\n  out[1] = a[1] + b[1];\n  return out;\n}\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\nexport function subtract(out, a, b) {\n  out[0] = a[0] - b[0];\n  out[1] = a[1] - b[1];\n  return out;\n}\n\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\nexport function multiply(out, a, b) {\n  out[0] = a[0] * b[0];\n  out[1] = a[1] * b[1];\n  return out;\n}\n\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\nexport function divide(out, a, b) {\n  out[0] = a[0] / b[0];\n  out[1] = a[1] / b[1];\n  return out;\n}\n\n/**\n * Math.ceil the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to ceil\n * @returns {vec2} out\n */\nexport function ceil(out, a) {\n  out[0] = Math.ceil(a[0]);\n  out[1] = Math.ceil(a[1]);\n  return out;\n}\n\n/**\n * Math.floor the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to floor\n * @returns {vec2} out\n */\nexport function floor(out, a) {\n  out[0] = Math.floor(a[0]);\n  out[1] = Math.floor(a[1]);\n  return out;\n}\n\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\nexport function min(out, a, b) {\n  out[0] = Math.min(a[0], b[0]);\n  out[1] = Math.min(a[1], b[1]);\n  return out;\n}\n\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\nexport function max(out, a, b) {\n  out[0] = Math.max(a[0], b[0]);\n  out[1] = Math.max(a[1], b[1]);\n  return out;\n}\n\n/**\n * symmetric round the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to round\n * @returns {vec2} out\n */\nexport function round(out, a) {\n  out[0] = glMatrix.round(a[0]);\n  out[1] = glMatrix.round(a[1]);\n  return out;\n}\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nexport function scale(out, a, b) {\n  out[0] = a[0] * b;\n  out[1] = a[1] * b;\n  return out;\n}\n\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\nexport function scaleAndAdd(out, a, b, scale) {\n  out[0] = a[0] + b[0] * scale;\n  out[1] = a[1] + b[1] * scale;\n  return out;\n}\n\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} distance between a and b\n */\nexport function distance(a, b) {\n  var x = b[0] - a[0],\n    y = b[1] - a[1];\n  return Math.sqrt(x * x + y * y);\n}\n\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\nexport function squaredDistance(a, b) {\n  var x = b[0] - a[0],\n    y = b[1] - a[1];\n  return x * x + y * y;\n}\n\n/**\n * Calculates the length of a vec2\n *\n * @param {ReadonlyVec2} a vector to calculate length of\n * @returns {Number} length of a\n */\nexport function length(a) {\n  var x = a[0],\n    y = a[1];\n  return Math.sqrt(x * x + y * y);\n}\n\n/**\n * Calculates the squared length of a vec2\n *\n * @param {ReadonlyVec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nexport function squaredLength(a) {\n  var x = a[0],\n    y = a[1];\n  return x * x + y * y;\n}\n\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to negate\n * @returns {vec2} out\n */\nexport function negate(out, a) {\n  out[0] = -a[0];\n  out[1] = -a[1];\n  return out;\n}\n\n/**\n * Returns the inverse of the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to invert\n * @returns {vec2} out\n */\nexport function inverse(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  return out;\n}\n\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to normalize\n * @returns {vec2} out\n */\nexport function normalize(out, a) {\n  var x = a[0],\n    y = a[1];\n  var len = x * x + y * y;\n  if (len > 0) {\n    //TODO: evaluate use of glm_invsqrt here?\n    len = 1 / Math.sqrt(len);\n  }\n  out[0] = a[0] * len;\n  out[1] = a[1] * len;\n  return out;\n}\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nexport function dot(a, b) {\n  return a[0] * b[0] + a[1] * b[1];\n}\n\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec3} out\n */\nexport function cross(out, a, b) {\n  var z = a[0] * b[1] - a[1] * b[0];\n  out[0] = out[1] = 0;\n  out[2] = z;\n  return out;\n}\n\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec2} out\n */\nexport function lerp(out, a, b, t) {\n  var ax = a[0],\n    ay = a[1];\n  out[0] = ax + t * (b[0] - ax);\n  out[1] = ay + t * (b[1] - ay);\n  return out;\n}\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If omitted, a unit vector will be returned\n * @returns {vec2} out\n */\nexport function random(out, scale) {\n  scale = scale === undefined ? 1.0 : scale;\n  var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n  out[0] = Math.cos(r) * scale;\n  out[1] = Math.sin(r) * scale;\n  return out;\n}\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat2} m matrix to transform with\n * @returns {vec2} out\n */\nexport function transformMat2(out, a, m) {\n  var x = a[0],\n    y = a[1];\n  out[0] = m[0] * x + m[2] * y;\n  out[1] = m[1] * x + m[3] * y;\n  return out;\n}\n\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat2d} m matrix to transform with\n * @returns {vec2} out\n */\nexport function transformMat2d(out, a, m) {\n  var x = a[0],\n    y = a[1];\n  out[0] = m[0] * x + m[2] * y + m[4];\n  out[1] = m[1] * x + m[3] * y + m[5];\n  return out;\n}\n\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat3} m matrix to transform with\n * @returns {vec2} out\n */\nexport function transformMat3(out, a, m) {\n  var x = a[0],\n    y = a[1];\n  out[0] = m[0] * x + m[3] * y + m[6];\n  out[1] = m[1] * x + m[4] * y + m[7];\n  return out;\n}\n\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat4} m matrix to transform with\n * @returns {vec2} out\n */\nexport function transformMat4(out, a, m) {\n  var x = a[0];\n  var y = a[1];\n  out[0] = m[0] * x + m[4] * y + m[12];\n  out[1] = m[1] * x + m[5] * y + m[13];\n  return out;\n}\n\n/**\n * Rotate a 2D vector\n * @param {vec2} out The receiving vec2\n * @param {ReadonlyVec2} a The vec2 point to rotate\n * @param {ReadonlyVec2} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec2} out\n */\nexport function rotate(out, a, b, rad) {\n  //Translate point to the origin\n  var p0 = a[0] - b[0],\n    p1 = a[1] - b[1],\n    sinC = Math.sin(rad),\n    cosC = Math.cos(rad);\n\n  //perform rotation and translate to correct position\n  out[0] = p0 * cosC - p1 * sinC + b[0];\n  out[1] = p0 * sinC + p1 * cosC + b[1];\n  return out;\n}\n\n/**\n * Get the smallest angle between two 2D vectors\n * @param {ReadonlyVec2} a The first operand\n * @param {ReadonlyVec2} b The second operand\n * @returns {Number} The angle in radians\n */\nexport function angle(a, b) {\n  var ax = a[0],\n    ay = a[1],\n    bx = b[0],\n    by = b[1];\n  return Math.abs(Math.atan2(ay * bx - ax * by, ax * bx + ay * by));\n}\n\n/**\n * Get the signed angle in the interval [-pi,pi] between two 2D vectors (positive if `a` is to the right of `b`)\n * \n * @param {ReadonlyVec2} a The first vector\n * @param {ReadonlyVec2} b The second vector\n * @returns {number} The signed angle in radians\n */\nexport function signedAngle(a, b) {\n  var ax = a[0],\n    ay = a[1],\n    bx = b[0],\n    by = b[1];\n  return Math.atan2(ax * by - ay * bx, ax * bx + ay * by);\n}\n\n/**\n * Set the components of a vec2 to zero\n *\n * @param {vec2} out the receiving vector\n * @returns {vec2} out\n */\nexport function zero(out) {\n  out[0] = 0.0;\n  out[1] = 0.0;\n  return out;\n}\n\n/**\n * Returns a string representation of a vector\n *\n * @param {ReadonlyVec2} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\nexport function str(a) {\n  return \"vec2(\" + a[0] + \", \" + a[1] + \")\";\n}\n\n/**\n * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyVec2} a The first vector.\n * @param {ReadonlyVec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nexport function exactEquals(a, b) {\n  return a[0] === b[0] && a[1] === b[1];\n}\n\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {ReadonlyVec2} a The first vector.\n * @param {ReadonlyVec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nexport function equals(a, b) {\n  var a0 = a[0],\n    a1 = a[1];\n  var b0 = b[0],\n    b1 = b[1];\n  return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1));\n}\n\n/**\n * Alias for {@link vec2.length}\n * @function\n */\nexport var len = length;\n\n/**\n * Alias for {@link vec2.subtract}\n * @function\n */\nexport var sub = subtract;\n\n/**\n * Alias for {@link vec2.multiply}\n * @function\n */\nexport var mul = multiply;\n\n/**\n * Alias for {@link vec2.divide}\n * @function\n */\nexport var div = divide;\n\n/**\n * Alias for {@link vec2.distance}\n * @function\n */\nexport var dist = distance;\n\n/**\n * Alias for {@link vec2.squaredDistance}\n * @function\n */\nexport var sqrDist = squaredDistance;\n\n/**\n * Alias for {@link vec2.squaredLength}\n * @function\n */\nexport var sqrLen = squaredLength;\n\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nexport var forEach = function () {\n  var vec = create();\n  return function (a, stride, offset, count, fn, arg) {\n    var i, l;\n    if (!stride) {\n      stride = 2;\n    }\n    if (!offset) {\n      offset = 0;\n    }\n    if (count) {\n      l = Math.min(count * stride + offset, a.length);\n    } else {\n      l = a.length;\n    }\n    for (i = offset; i < l; i += stride) {\n      vec[0] = a[i];\n      vec[1] = a[i + 1];\n      fn(vec, vec, arg);\n      a[i] = vec[0];\n      a[i + 1] = vec[1];\n    }\n    return a;\n  };\n}();","import * as glMatrix from \"./common.js\";\n\n/**\n * 3 Dimensional Vector\n * @module vec3\n */\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\nexport function create() {\n  var out = new glMatrix.ARRAY_TYPE(3);\n  if (glMatrix.ARRAY_TYPE != Float32Array) {\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n  }\n  return out;\n}\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {ReadonlyVec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nexport function clone(a) {\n  var out = new glMatrix.ARRAY_TYPE(3);\n  out[0] = a[0];\n  out[1] = a[1];\n  out[2] = a[2];\n  return out;\n}\n\n/**\n * Calculates the length of a vec3\n *\n * @param {ReadonlyVec3} a vector to calculate length of\n * @returns {Number} length of a\n */\nexport function length(a) {\n  var x = a[0];\n  var y = a[1];\n  var z = a[2];\n  return Math.sqrt(x * x + y * y + z * z);\n}\n\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\nexport function fromValues(x, y, z) {\n  var out = new glMatrix.ARRAY_TYPE(3);\n  out[0] = x;\n  out[1] = y;\n  out[2] = z;\n  return out;\n}\n\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the source vector\n * @returns {vec3} out\n */\nexport function copy(out, a) {\n  out[0] = a[0];\n  out[1] = a[1];\n  out[2] = a[2];\n  return out;\n}\n\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\nexport function set(out, x, y, z) {\n  out[0] = x;\n  out[1] = y;\n  out[2] = z;\n  return out;\n}\n\n/**\n * Adds two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\nexport function add(out, a, b) {\n  out[0] = a[0] + b[0];\n  out[1] = a[1] + b[1];\n  out[2] = a[2] + b[2];\n  return out;\n}\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\nexport function subtract(out, a, b) {\n  out[0] = a[0] - b[0];\n  out[1] = a[1] - b[1];\n  out[2] = a[2] - b[2];\n  return out;\n}\n\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\nexport function multiply(out, a, b) {\n  out[0] = a[0] * b[0];\n  out[1] = a[1] * b[1];\n  out[2] = a[2] * b[2];\n  return out;\n}\n\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\nexport function divide(out, a, b) {\n  out[0] = a[0] / b[0];\n  out[1] = a[1] / b[1];\n  out[2] = a[2] / b[2];\n  return out;\n}\n\n/**\n * Math.ceil the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to ceil\n * @returns {vec3} out\n */\nexport function ceil(out, a) {\n  out[0] = Math.ceil(a[0]);\n  out[1] = Math.ceil(a[1]);\n  out[2] = Math.ceil(a[2]);\n  return out;\n}\n\n/**\n * Math.floor the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to floor\n * @returns {vec3} out\n */\nexport function floor(out, a) {\n  out[0] = Math.floor(a[0]);\n  out[1] = Math.floor(a[1]);\n  out[2] = Math.floor(a[2]);\n  return out;\n}\n\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\nexport function min(out, a, b) {\n  out[0] = Math.min(a[0], b[0]);\n  out[1] = Math.min(a[1], b[1]);\n  out[2] = Math.min(a[2], b[2]);\n  return out;\n}\n\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\nexport function max(out, a, b) {\n  out[0] = Math.max(a[0], b[0]);\n  out[1] = Math.max(a[1], b[1]);\n  out[2] = Math.max(a[2], b[2]);\n  return out;\n}\n\n/**\n * symmetric round the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to round\n * @returns {vec3} out\n */\nexport function round(out, a) {\n  out[0] = glMatrix.round(a[0]);\n  out[1] = glMatrix.round(a[1]);\n  out[2] = glMatrix.round(a[2]);\n  return out;\n}\n\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\nexport function scale(out, a, b) {\n  out[0] = a[0] * b;\n  out[1] = a[1] * b;\n  out[2] = a[2] * b;\n  return out;\n}\n\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\nexport function scaleAndAdd(out, a, b, scale) {\n  out[0] = a[0] + b[0] * scale;\n  out[1] = a[1] + b[1] * scale;\n  out[2] = a[2] + b[2] * scale;\n  return out;\n}\n\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} distance between a and b\n */\nexport function distance(a, b) {\n  var x = b[0] - a[0];\n  var y = b[1] - a[1];\n  var z = b[2] - a[2];\n  return Math.sqrt(x * x + y * y + z * z);\n}\n\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\nexport function squaredDistance(a, b) {\n  var x = b[0] - a[0];\n  var y = b[1] - a[1];\n  var z = b[2] - a[2];\n  return x * x + y * y + z * z;\n}\n\n/**\n * Calculates the squared length of a vec3\n *\n * @param {ReadonlyVec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nexport function squaredLength(a) {\n  var x = a[0];\n  var y = a[1];\n  var z = a[2];\n  return x * x + y * y + z * z;\n}\n\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to negate\n * @returns {vec3} out\n */\nexport function negate(out, a) {\n  out[0] = -a[0];\n  out[1] = -a[1];\n  out[2] = -a[2];\n  return out;\n}\n\n/**\n * Returns the inverse of the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to invert\n * @returns {vec3} out\n */\nexport function inverse(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  out[2] = 1.0 / a[2];\n  return out;\n}\n\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to normalize\n * @returns {vec3} out\n */\nexport function normalize(out, a) {\n  var x = a[0];\n  var y = a[1];\n  var z = a[2];\n  var len = x * x + y * y + z * z;\n  if (len > 0) {\n    //TODO: evaluate use of glm_invsqrt here?\n    len = 1 / Math.sqrt(len);\n  }\n  out[0] = a[0] * len;\n  out[1] = a[1] * len;\n  out[2] = a[2] * len;\n  return out;\n}\n\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} dot product of a and b\n */\nexport function dot(a, b) {\n  return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\nexport function cross(out, a, b) {\n  var ax = a[0],\n    ay = a[1],\n    az = a[2];\n  var bx = b[0],\n    by = b[1],\n    bz = b[2];\n  out[0] = ay * bz - az * by;\n  out[1] = az * bx - ax * bz;\n  out[2] = ax * by - ay * bx;\n  return out;\n}\n\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\nexport function lerp(out, a, b, t) {\n  var ax = a[0];\n  var ay = a[1];\n  var az = a[2];\n  out[0] = ax + t * (b[0] - ax);\n  out[1] = ay + t * (b[1] - ay);\n  out[2] = az + t * (b[2] - az);\n  return out;\n}\n\n/**\n * Performs a spherical linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\nexport function slerp(out, a, b, t) {\n  var angle = Math.acos(Math.min(Math.max(dot(a, b), -1), 1));\n  var sinTotal = Math.sin(angle);\n  var ratioA = Math.sin((1 - t) * angle) / sinTotal;\n  var ratioB = Math.sin(t * angle) / sinTotal;\n  out[0] = ratioA * a[0] + ratioB * b[0];\n  out[1] = ratioA * a[1] + ratioB * b[1];\n  out[2] = ratioA * a[2] + ratioB * b[2];\n  return out;\n}\n\n/**\n * Performs a hermite interpolation with two control points\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {ReadonlyVec3} c the third operand\n * @param {ReadonlyVec3} d the fourth operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\nexport function hermite(out, a, b, c, d, t) {\n  var factorTimes2 = t * t;\n  var factor1 = factorTimes2 * (2 * t - 3) + 1;\n  var factor2 = factorTimes2 * (t - 2) + t;\n  var factor3 = factorTimes2 * (t - 1);\n  var factor4 = factorTimes2 * (3 - 2 * t);\n  out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n  out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n  out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n  return out;\n}\n\n/**\n * Performs a bezier interpolation with two control points\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {ReadonlyVec3} c the third operand\n * @param {ReadonlyVec3} d the fourth operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\nexport function bezier(out, a, b, c, d, t) {\n  var inverseFactor = 1 - t;\n  var inverseFactorTimesTwo = inverseFactor * inverseFactor;\n  var factorTimes2 = t * t;\n  var factor1 = inverseFactorTimesTwo * inverseFactor;\n  var factor2 = 3 * t * inverseFactorTimesTwo;\n  var factor3 = 3 * factorTimes2 * inverseFactor;\n  var factor4 = factorTimes2 * t;\n  out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n  out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n  out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n  return out;\n}\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If omitted, a unit vector will be returned\n * @returns {vec3} out\n */\nexport function random(out, scale) {\n  scale = scale === undefined ? 1.0 : scale;\n  var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n  var z = glMatrix.RANDOM() * 2.0 - 1.0;\n  var zScale = Math.sqrt(1.0 - z * z) * scale;\n  out[0] = Math.cos(r) * zScale;\n  out[1] = Math.sin(r) * zScale;\n  out[2] = z * scale;\n  return out;\n}\n\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyMat4} m matrix to transform with\n * @returns {vec3} out\n */\nexport function transformMat4(out, a, m) {\n  var x = a[0],\n    y = a[1],\n    z = a[2];\n  var w = m[3] * x + m[7] * y + m[11] * z + m[15];\n  w = w || 1.0;\n  out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w;\n  out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w;\n  out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w;\n  return out;\n}\n\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyMat3} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\nexport function transformMat3(out, a, m) {\n  var x = a[0],\n    y = a[1],\n    z = a[2];\n  out[0] = x * m[0] + y * m[3] + z * m[6];\n  out[1] = x * m[1] + y * m[4] + z * m[7];\n  out[2] = x * m[2] + y * m[5] + z * m[8];\n  return out;\n}\n\n/**\n * Transforms the vec3 with a quat\n * Can also be used for dual quaternions. (Multiply it with the real part)\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyQuat} q normalized quaternion to transform with\n * @returns {vec3} out\n */\nexport function transformQuat(out, a, q) {\n  // Fast Vector Rotation using Quaternions by Robert Eisele\n  // https://raw.org/proof/vector-rotation-using-quaternions/\n\n  var qx = q[0],\n    qy = q[1],\n    qz = q[2],\n    qw = q[3];\n  var vx = a[0],\n    vy = a[1],\n    vz = a[2];\n\n  // t = q x v\n  var tx = qy * vz - qz * vy;\n  var ty = qz * vx - qx * vz;\n  var tz = qx * vy - qy * vx;\n\n  // t = 2t\n  tx = tx + tx;\n  ty = ty + ty;\n  tz = tz + tz;\n\n  // v + w t + q x t\n  out[0] = vx + qw * tx + qy * tz - qz * ty;\n  out[1] = vy + qw * ty + qz * tx - qx * tz;\n  out[2] = vz + qw * tz + qx * ty - qy * tx;\n  return out;\n}\n\n/**\n * Rotate a 3D vector around the x-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\nexport function rotateX(out, a, b, rad) {\n  var p = [],\n    r = [];\n  //Translate point to the origin\n  p[0] = a[0] - b[0];\n  p[1] = a[1] - b[1];\n  p[2] = a[2] - b[2];\n\n  //perform rotation\n  r[0] = p[0];\n  r[1] = p[1] * Math.cos(rad) - p[2] * Math.sin(rad);\n  r[2] = p[1] * Math.sin(rad) + p[2] * Math.cos(rad);\n\n  //translate to correct position\n  out[0] = r[0] + b[0];\n  out[1] = r[1] + b[1];\n  out[2] = r[2] + b[2];\n  return out;\n}\n\n/**\n * Rotate a 3D vector around the y-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\nexport function rotateY(out, a, b, rad) {\n  var p = [],\n    r = [];\n  //Translate point to the origin\n  p[0] = a[0] - b[0];\n  p[1] = a[1] - b[1];\n  p[2] = a[2] - b[2];\n\n  //perform rotation\n  r[0] = p[2] * Math.sin(rad) + p[0] * Math.cos(rad);\n  r[1] = p[1];\n  r[2] = p[2] * Math.cos(rad) - p[0] * Math.sin(rad);\n\n  //translate to correct position\n  out[0] = r[0] + b[0];\n  out[1] = r[1] + b[1];\n  out[2] = r[2] + b[2];\n  return out;\n}\n\n/**\n * Rotate a 3D vector around the z-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\nexport function rotateZ(out, a, b, rad) {\n  var p = [],\n    r = [];\n  //Translate point to the origin\n  p[0] = a[0] - b[0];\n  p[1] = a[1] - b[1];\n  p[2] = a[2] - b[2];\n\n  //perform rotation\n  r[0] = p[0] * Math.cos(rad) - p[1] * Math.sin(rad);\n  r[1] = p[0] * Math.sin(rad) + p[1] * Math.cos(rad);\n  r[2] = p[2];\n\n  //translate to correct position\n  out[0] = r[0] + b[0];\n  out[1] = r[1] + b[1];\n  out[2] = r[2] + b[2];\n  return out;\n}\n\n/**\n * Get the angle between two 3D vectors\n * @param {ReadonlyVec3} a The first operand\n * @param {ReadonlyVec3} b The second operand\n * @returns {Number} The angle in radians\n */\nexport function angle(a, b) {\n  var ax = a[0],\n    ay = a[1],\n    az = a[2],\n    bx = b[0],\n    by = b[1],\n    bz = b[2],\n    mag = Math.sqrt((ax * ax + ay * ay + az * az) * (bx * bx + by * by + bz * bz)),\n    cosine = mag && dot(a, b) / mag;\n  return Math.acos(Math.min(Math.max(cosine, -1), 1));\n}\n\n/**\n * Set the components of a vec3 to zero\n *\n * @param {vec3} out the receiving vector\n * @returns {vec3} out\n */\nexport function zero(out) {\n  out[0] = 0.0;\n  out[1] = 0.0;\n  out[2] = 0.0;\n  return out;\n}\n\n/**\n * Returns a string representation of a vector\n *\n * @param {ReadonlyVec3} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\nexport function str(a) {\n  return \"vec3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \")\";\n}\n\n/**\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyVec3} a The first vector.\n * @param {ReadonlyVec3} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nexport function exactEquals(a, b) {\n  return a[0] === b[0] && a[1] === b[1] && a[2] === b[2];\n}\n\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {ReadonlyVec3} a The first vector.\n * @param {ReadonlyVec3} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nexport function equals(a, b) {\n  var a0 = a[0],\n    a1 = a[1],\n    a2 = a[2];\n  var b0 = b[0],\n    b1 = b[1],\n    b2 = b[2];\n  return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2));\n}\n\n/**\n * Alias for {@link vec3.subtract}\n * @function\n */\nexport var sub = subtract;\n\n/**\n * Alias for {@link vec3.multiply}\n * @function\n */\nexport var mul = multiply;\n\n/**\n * Alias for {@link vec3.divide}\n * @function\n */\nexport var div = divide;\n\n/**\n * Alias for {@link vec3.distance}\n * @function\n */\nexport var dist = distance;\n\n/**\n * Alias for {@link vec3.squaredDistance}\n * @function\n */\nexport var sqrDist = squaredDistance;\n\n/**\n * Alias for {@link vec3.length}\n * @function\n */\nexport var len = length;\n\n/**\n * Alias for {@link vec3.squaredLength}\n * @function\n */\nexport var sqrLen = squaredLength;\n\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nexport var forEach = function () {\n  var vec = create();\n  return function (a, stride, offset, count, fn, arg) {\n    var i, l;\n    if (!stride) {\n      stride = 3;\n    }\n    if (!offset) {\n      offset = 0;\n    }\n    if (count) {\n      l = Math.min(count * stride + offset, a.length);\n    } else {\n      l = a.length;\n    }\n    for (i = offset; i < l; i += stride) {\n      vec[0] = a[i];\n      vec[1] = a[i + 1];\n      vec[2] = a[i + 2];\n      fn(vec, vec, arg);\n      a[i] = vec[0];\n      a[i + 1] = vec[1];\n      a[i + 2] = vec[2];\n    }\n    return a;\n  };\n}();","import * as glMatrix from \"./common.js\";\nimport * as mat2 from \"./mat2.js\";\nimport * as mat2d from \"./mat2d.js\";\nimport * as mat3 from \"./mat3.js\";\nimport * as mat4 from \"./mat4.js\";\nimport * as quat from \"./quat.js\";\nimport * as quat2 from \"./quat2.js\";\nimport * as vec2 from \"./vec2.js\";\nimport * as vec3 from \"./vec3.js\";\nimport * as vec4 from \"./vec4.js\";\nexport { glMatrix, mat2, mat2d, mat3, mat4, quat, quat2, vec2, vec3, vec4 };","/* eslint-disable no-param-reassign */\nimport { TypedArray } from '../../type-definitions/quagga';\n\nexport default {\n    init(arr: TypedArray | Array<number>, val: number) {\n        arr.fill(val);\n    },\n\n    /**\n     * IN-PLACE Shuffles the content of an array\n     */\n    shuffle(arr: Array<number>) {\n        // Durstenfeld shuffle algorithm\n        // https://stackoverflow.com/questions/2450954/how-to-randomize-shuffle-a-javascript-array\n        for (let i = arr.length - 1; i > 0; i--) {\n            const j = Math.floor(Math.random() * (i + 1));\n            [arr[i], arr[j]] = [arr[j], arr[i]];\n        }\n        return arr;\n    },\n\n    toPointList(arr: Array<Array<number>>) {\n        const rows = arr.reduce((p, n) => {\n            const row = `[${n.join(',')}]`;\n            p.push(row);\n            return p;\n        }, [] as Array<string>);\n        return `[${rows.join(',\\r\\n')}]`;\n    },\n\n    /**\n     * returns the elements which's score is bigger than the threshold\n     */\n    // eslint-disable-next-line no-unused-vars\n    threshold(arr: Array<number>, threshold: number, scoreFunc: ((score: number) => number)) {\n        const queue = arr.reduce((prev: Array<number>, next) => {\n            if (scoreFunc.apply(arr, [next]) >= threshold) {\n                prev.push(next);\n            }\n            return prev;\n        }, []);\n        return queue;\n    },\n\n    maxIndex(arr: Array<number>) {\n        let max = 0;\n        for (let i = 0; i < arr.length; i++) {\n            if (arr[i] > arr[max]) {\n                max = i;\n            }\n        }\n        return max;\n    },\n\n    max(arr: Array<number>) {\n        let max = 0;\n        for (let i = 0; i < arr.length; i++) {\n            if (arr[i] > max) {\n                max = arr[i];\n            }\n        }\n        return max;\n    },\n\n    sum(arr: Array<number> | TypedArray): number {\n        let { length } = arr;\n        let sum = 0;\n\n        while (length--) {\n            sum += arr[length];\n        }\n        return sum;\n    },\n};\n","// TODO: cluster.js and cv_utils.js are pretty tightly intertwined, making for a complex conversion\n// into typescript. be warned. :-)\n\nimport { vec2 } from 'gl-matrix';\n\n/**\n * Creates a cluster for grouping similar orientations of datapoints\n */\nexport default {\n    create(point, threshold) {\n        const points = [];\n        const center = {\n            rad: 0,\n            vec: vec2.clone([0, 0]),\n        };\n        const pointMap = {};\n\n        function add(pointToAdd) {\n            pointMap[pointToAdd.id] = pointToAdd;\n            points.push(pointToAdd);\n        }\n\n        function updateCenter() {\n            let i; let\n                sum = 0;\n            for (i = 0; i < points.length; i++) {\n                sum += points[i].rad;\n            }\n            center.rad = sum / points.length;\n            center.vec = vec2.clone([Math.cos(center.rad), Math.sin(center.rad)]);\n        }\n\n        function init() {\n            add(point);\n            updateCenter();\n        }\n\n        init();\n\n        return {\n            add(pointToAdd) {\n                if (!pointMap[pointToAdd.id]) {\n                    add(pointToAdd);\n                    updateCenter();\n                }\n            },\n            fits(otherPoint) {\n                // check cosine similarity to center-angle\n                const similarity = Math.abs(vec2.dot(otherPoint.point.vec, center.vec));\n                if (similarity > threshold) {\n                    return true;\n                }\n                return false;\n            },\n            getPoints() {\n                return points;\n            },\n            getCenter() {\n                return center;\n            },\n        };\n    },\n    createPoint(newPoint, id, property) {\n        return {\n            rad: newPoint[property],\n            point: newPoint,\n            id,\n        };\n    },\n};\n","/* eslint-disable no-mixed-operators */\n/* eslint-disable no-bitwise */\nimport { vec2, vec3 } from 'gl-matrix';\nimport ArrayHelper from './array_helper';\nimport Cluster2 from './cluster';\n\n/**\n * @param x x-coordinate\n * @param y y-coordinate\n * @return ImageReference {x,y} Coordinate\n */\nexport function imageRef(x, y) {\n    const that = {\n        x,\n        y,\n        toVec2() {\n            return vec2.clone([this.x, this.y]);\n        },\n        toVec3() {\n            return vec3.clone([this.x, this.y, 1]);\n        },\n        round() {\n            this.x = this.x > 0.0 ? Math.floor(this.x + 0.5) : Math.floor(this.x - 0.5);\n            this.y = this.y > 0.0 ? Math.floor(this.y + 0.5) : Math.floor(this.y - 0.5);\n            return this;\n        },\n    };\n    return that;\n}\n\n/**\n * Computes an integral image of a given grayscale image.\n * @param imageDataContainer {ImageDataContainer} the image to be integrated\n */\nexport function computeIntegralImage2(imageWrapper, integralWrapper) {\n    const imageData = imageWrapper.data;\n    const width = imageWrapper.size.x;\n    const height = imageWrapper.size.y;\n    const integralImageData = integralWrapper.data;\n    let sum = 0; let posA = 0; let posB = 0; let posC = 0; let posD = 0; let x; let\n        y;\n\n    // sum up first column\n    posB = width;\n    sum = 0;\n    for (y = 1; y < height; y++) {\n        sum += imageData[posA];\n        integralImageData[posB] += sum;\n        posA += width;\n        posB += width;\n    }\n\n    posA = 0;\n    posB = 1;\n    sum = 0;\n    for (x = 1; x < width; x++) {\n        sum += imageData[posA];\n        integralImageData[posB] += sum;\n        posA++;\n        posB++;\n    }\n\n    for (y = 1; y < height; y++) {\n        posA = y * width + 1;\n        posB = (y - 1) * width + 1;\n        posC = y * width;\n        posD = (y - 1) * width;\n        for (x = 1; x < width; x++) {\n            integralImageData[posA]\n                += imageData[posA] + integralImageData[posB] + integralImageData[posC] - integralImageData[posD];\n            posA++;\n            posB++;\n            posC++;\n            posD++;\n        }\n    }\n}\n\nexport function computeIntegralImage(imageWrapper, integralWrapper) {\n    const imageData = imageWrapper.data;\n    const width = imageWrapper.size.x;\n    const height = imageWrapper.size.y;\n    const integralImageData = integralWrapper.data;\n    let sum = 0;\n\n    // sum up first row\n    for (let i = 0; i < width; i++) {\n        sum += imageData[i];\n        integralImageData[i] = sum;\n    }\n\n    for (let v = 1; v < height; v++) {\n        sum = 0;\n        for (let u = 0; u < width; u++) {\n            sum += imageData[v * width + u];\n            integralImageData[((v) * width) + u] = sum + integralImageData[(v - 1) * width + u];\n        }\n    }\n}\n\nexport function thresholdImage(imageWrapper, threshold, targetWrapper) {\n    if (!targetWrapper) {\n        // eslint-disable-next-line no-param-reassign\n        targetWrapper = imageWrapper;\n    }\n    const imageData = imageWrapper.data; let { length } = imageData; const\n        targetData = targetWrapper.data;\n\n    while (length--) {\n        targetData[length] = imageData[length] < threshold ? 1 : 0;\n    }\n}\n\nexport function computeHistogram(imageWrapper, bitsPerPixel) {\n    if (!bitsPerPixel) {\n        // eslint-disable-next-line no-param-reassign\n        bitsPerPixel = 8;\n    }\n    const imageData = imageWrapper.data;\n    let { length } = imageData;\n    const bitShift = 8 - bitsPerPixel;\n    const bucketCnt = 1 << bitsPerPixel;\n    const hist = new Int32Array(bucketCnt);\n\n    while (length--) {\n        hist[imageData[length] >> bitShift]++;\n    }\n    return hist;\n}\n\nexport function sharpenLine(line) {\n    let i;\n    const { length } = line;\n    let left = line[0];\n    let center = line[1];\n    let right;\n\n    for (i = 1; i < length - 1; i++) {\n        right = line[i + 1];\n        //  -1 4 -1 kernel\n        // eslint-disable-next-line no-param-reassign\n        line[i - 1] = (((center * 2) - left - right)) & 255;\n        left = center;\n        center = right;\n    }\n    return line;\n}\n\nexport function determineOtsuThreshold(imageWrapper, bitsPerPixel = 8) {\n    let hist;\n    const bitShift = 8 - bitsPerPixel;\n\n    function px(init, end) {\n        let sum = 0;\n        for (let i = init; i <= end; i++) {\n            sum += hist[i];\n        }\n        return sum;\n    }\n\n    function mx(init, end) {\n        let sum = 0;\n\n        for (let i = init; i <= end; i++) {\n            sum += i * hist[i];\n        }\n\n        return sum;\n    }\n\n    function determineThreshold() {\n        const vet = [0];\n        let p1;\n        let p2;\n        let p12;\n        let m1;\n        let m2;\n        let m12;\n        const max = (1 << bitsPerPixel) - 1;\n\n        hist = computeHistogram(imageWrapper, bitsPerPixel);\n        for (let k = 1; k < max; k++) {\n            p1 = px(0, k);\n            p2 = px(k + 1, max);\n            p12 = p1 * p2;\n            if (p12 === 0) {\n                p12 = 1;\n            }\n            m1 = mx(0, k) * p2;\n            m2 = mx(k + 1, max) * p1;\n            m12 = m1 - m2;\n            vet[k] = m12 * m12 / p12;\n        }\n        return ArrayHelper.maxIndex(vet);\n    }\n\n    const threshold = determineThreshold();\n    return threshold << bitShift;\n}\n\nexport function otsuThreshold(imageWrapper, targetWrapper) {\n    const threshold = determineOtsuThreshold(imageWrapper);\n\n    thresholdImage(imageWrapper, threshold, targetWrapper);\n    return threshold;\n}\n\n// local thresholding\nexport function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) {\n    computeIntegralImage(imageWrapper, integralWrapper);\n\n    if (!targetWrapper) {\n        // eslint-disable-next-line no-param-reassign\n        targetWrapper = imageWrapper;\n    }\n    const imageData = imageWrapper.data;\n    const targetData = targetWrapper.data;\n    const width = imageWrapper.size.x;\n    const height = imageWrapper.size.y;\n    const integralImageData = integralWrapper.data;\n    let sum = 0; let v; let u; const kernel = 3; let A; let B; let C; let D; let avg; const\n        size = (kernel * 2 + 1) * (kernel * 2 + 1);\n\n    // clear out top & bottom-border\n    for (v = 0; v <= kernel; v++) {\n        for (u = 0; u < width; u++) {\n            targetData[((v) * width) + u] = 0;\n            targetData[(((height - 1) - v) * width) + u] = 0;\n        }\n    }\n\n    // clear out left & right border\n    for (v = kernel; v < height - kernel; v++) {\n        for (u = 0; u <= kernel; u++) {\n            targetData[((v) * width) + u] = 0;\n            targetData[((v) * width) + (width - 1 - u)] = 0;\n        }\n    }\n\n    for (v = kernel + 1; v < height - kernel - 1; v++) {\n        for (u = kernel + 1; u < width - kernel; u++) {\n            A = integralImageData[(v - kernel - 1) * width + (u - kernel - 1)];\n            B = integralImageData[(v - kernel - 1) * width + (u + kernel)];\n            C = integralImageData[(v + kernel) * width + (u - kernel - 1)];\n            D = integralImageData[(v + kernel) * width + (u + kernel)];\n            sum = D - C - B + A;\n            avg = sum / (size);\n            targetData[v * width + u] = imageData[v * width + u] > (avg + 5) ? 0 : 1;\n        }\n    }\n}\n\nexport function cluster(points, threshold, property) {\n    let i; let k; let thisCluster; let point; const\n        clusters = [];\n\n    if (!property) {\n        // eslint-disable-next-line no-param-reassign\n        property = 'rad';\n    }\n\n    function addToCluster(newPoint) {\n        let found = false;\n        for (k = 0; k < clusters.length; k++) {\n            thisCluster = clusters[k];\n            if (thisCluster.fits(newPoint)) {\n                thisCluster.add(newPoint);\n                found = true;\n            }\n        }\n        return found;\n    }\n\n    // iterate over each cloud\n    for (i = 0; i < points.length; i++) {\n        point = Cluster2.createPoint(points[i], i, property);\n        if (!addToCluster(point)) {\n            clusters.push(Cluster2.create(point, threshold));\n        }\n    }\n    return clusters;\n}\n\nexport const Tracer = {\n    trace(points, vec) {\n        let iteration;\n        const maxIterations = 10;\n        let top = [];\n        let result = [];\n        let centerPos = 0;\n        let currentPos = 0;\n\n        function trace(idx, forward) {\n            let to;\n            let toIdx;\n            let predictedPos;\n            const thresholdX = 1;\n            const thresholdY = Math.abs(vec[1] / 10);\n            let found = false;\n\n            function match(pos, predicted) {\n                if (pos.x > (predicted.x - thresholdX)\n                        && pos.x < (predicted.x + thresholdX)\n                        && pos.y > (predicted.y - thresholdY)\n                        && pos.y < (predicted.y + thresholdY)) {\n                    return true;\n                }\n                return false;\n            }\n\n            // check if the next index is within the vec specifications\n            // if not, check as long as the threshold is met\n\n            const from = points[idx];\n            if (forward) {\n                predictedPos = {\n                    x: from.x + vec[0],\n                    y: from.y + vec[1],\n                };\n            } else {\n                predictedPos = {\n                    x: from.x - vec[0],\n                    y: from.y - vec[1],\n                };\n            }\n\n            toIdx = forward ? idx + 1 : idx - 1;\n            to = points[toIdx];\n            // eslint-disable-next-line no-cond-assign\n            while (to && (found = match(to, predictedPos)) !== true && (Math.abs(to.y - from.y) < vec[1])) {\n                toIdx = forward ? toIdx + 1 : toIdx - 1;\n                to = points[toIdx];\n            }\n\n            return found ? toIdx : null;\n        }\n\n        for (iteration = 0; iteration < maxIterations; iteration++) {\n            // randomly select point to start with\n            centerPos = Math.floor(Math.random() * points.length);\n\n            // trace forward\n            top = [];\n            currentPos = centerPos;\n            top.push(points[currentPos]);\n            // eslint-disable-next-line no-cond-assign\n            while ((currentPos = trace(currentPos, true)) !== null) {\n                top.push(points[currentPos]);\n            }\n            if (centerPos > 0) {\n                currentPos = centerPos;\n                // eslint-disable-next-line no-cond-assign\n                while ((currentPos = trace(currentPos, false)) !== null) {\n                    top.push(points[currentPos]);\n                }\n            }\n\n            if (top.length > result.length) {\n                result = top;\n            }\n        }\n        return result;\n    },\n};\n\nexport const DILATE = 1;\nexport const ERODE = 2;\n\nexport function dilate(inImageWrapper, outImageWrapper) {\n    let v;\n    let u;\n    const inImageData = inImageWrapper.data;\n    const outImageData = outImageWrapper.data;\n    const height = inImageWrapper.size.y;\n    const width = inImageWrapper.size.x;\n    let sum;\n    let yStart1;\n    let yStart2;\n    let xStart1;\n    let xStart2;\n\n    for (v = 1; v < height - 1; v++) {\n        for (u = 1; u < width - 1; u++) {\n            yStart1 = v - 1;\n            yStart2 = v + 1;\n            xStart1 = u - 1;\n            xStart2 = u + 1;\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2]\n            + inImageData[v * width + u]\n            + inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\n            outImageData[v * width + u] = sum > 0 ? 1 : 0;\n        }\n    }\n}\n\nexport function erode(inImageWrapper, outImageWrapper) {\n    let v;\n    let u;\n    const inImageData = inImageWrapper.data;\n    const outImageData = outImageWrapper.data;\n    const height = inImageWrapper.size.y;\n    const width = inImageWrapper.size.x;\n    let sum;\n    let yStart1;\n    let yStart2;\n    let xStart1;\n    let xStart2;\n\n    for (v = 1; v < height - 1; v++) {\n        for (u = 1; u < width - 1; u++) {\n            yStart1 = v - 1;\n            yStart2 = v + 1;\n            xStart1 = u - 1;\n            xStart2 = u + 1;\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2]\n            + inImageData[v * width + u]\n            + inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\n            outImageData[v * width + u] = sum === 5 ? 1 : 0;\n        }\n    }\n}\n\nexport function subtract(aImageWrapper, bImageWrapper, resultImageWrapper) {\n    if (!resultImageWrapper) {\n        // eslint-disable-next-line no-param-reassign\n        resultImageWrapper = aImageWrapper;\n    }\n    let { length } = aImageWrapper.data;\n    const aImageData = aImageWrapper.data;\n    const bImageData = bImageWrapper.data;\n    const cImageData = resultImageWrapper.data;\n\n    while (length--) {\n        cImageData[length] = aImageData[length] - bImageData[length];\n    }\n}\n\nexport function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) {\n    if (!resultImageWrapper) {\n        // eslint-disable-next-line no-param-reassign\n        resultImageWrapper = aImageWrapper;\n    }\n    let { length } = aImageWrapper.data;\n    const aImageData = aImageWrapper.data;\n    const bImageData = bImageWrapper.data;\n    const cImageData = resultImageWrapper.data;\n\n    while (length--) {\n        cImageData[length] = aImageData[length] || bImageData[length];\n    }\n}\n\nexport function countNonZero(imageWrapper) {\n    let { length } = imageWrapper.data;\n    const { data } = imageWrapper;\n    let sum = 0;\n\n    while (length--) {\n        sum += data[length];\n    }\n    return sum;\n}\n\nexport function topGeneric(list, top, scoreFunc) {\n    let i; let minIdx = 0; let min = 0; const queue = []; let score; let hit; let\n        pos;\n\n    for (i = 0; i < top; i++) {\n        queue[i] = {\n            score: 0,\n            item: null,\n        };\n    }\n\n    for (i = 0; i < list.length; i++) {\n        score = scoreFunc.apply(this, [list[i]]);\n        if (score > min) {\n            hit = queue[minIdx];\n            hit.score = score;\n            hit.item = list[i];\n            min = Number.MAX_VALUE;\n            for (pos = 0; pos < top; pos++) {\n                if (queue[pos].score < min) {\n                    min = queue[pos].score;\n                    minIdx = pos;\n                }\n            }\n        }\n    }\n\n    return queue;\n}\n\nexport function grayArrayFromImage(htmlImage, offsetX, ctx, array) {\n    ctx.drawImage(htmlImage, offsetX, 0, htmlImage.width, htmlImage.height);\n    const ctxData = ctx.getImageData(offsetX, 0, htmlImage.width, htmlImage.height).data;\n    computeGray(ctxData, array);\n}\n\nexport function grayArrayFromContext(ctx, size, offset, array) {\n    const ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data;\n    computeGray(ctxData, array);\n}\n\nexport function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {\n    let topRowIdx = 0;\n    let bottomRowIdx = size.x;\n    const endIdx = Math.floor(canvasData.length / 4);\n    const outWidth = size.x / 2;\n    let outImgIdx = 0;\n    const inWidth = size.x;\n    let i;\n\n    while (bottomRowIdx < endIdx) {\n        for (i = 0; i < outWidth; i++) {\n            // eslint-disable-next-line no-param-reassign\n            outArray[outImgIdx] = (\n                (0.299 * canvasData[topRowIdx * 4 + 0]\n                 + 0.587 * canvasData[topRowIdx * 4 + 1]\n                 + 0.114 * canvasData[topRowIdx * 4 + 2])\n                + (0.299 * canvasData[(topRowIdx + 1) * 4 + 0]\n                 + 0.587 * canvasData[(topRowIdx + 1) * 4 + 1]\n                 + 0.114 * canvasData[(topRowIdx + 1) * 4 + 2])\n                + (0.299 * canvasData[(bottomRowIdx) * 4 + 0]\n                 + 0.587 * canvasData[(bottomRowIdx) * 4 + 1]\n                 + 0.114 * canvasData[(bottomRowIdx) * 4 + 2])\n                + (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0]\n                 + 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1]\n                 + 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4;\n            outImgIdx++;\n            topRowIdx += 2;\n            bottomRowIdx += 2;\n        }\n        topRowIdx += inWidth;\n        bottomRowIdx += inWidth;\n    }\n}\n\nexport function computeGray(imageData, outArray, config) {\n    const l = (imageData.length / 4) | 0;\n    const singleChannel = config && config.singleChannel === true;\n\n    if (singleChannel) {\n        for (let i = 0; i < l; i++) {\n            // eslint-disable-next-line no-param-reassign\n            outArray[i] = imageData[i * 4 + 0];\n        }\n    } else {\n        for (let i = 0; i < l; i++) {\n            // eslint-disable-next-line no-param-reassign\n            outArray[i] = 0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2];\n        }\n    }\n}\n\nexport function loadImageArray(src, callback, canvas = document && document.createElement('canvas')) {\n    const img = new Image();\n    img.callback = callback;\n    img.onload = function () {\n        // eslint-disable-next-line no-param-reassign\n        canvas.width = this.width;\n        // eslint-disable-next-line no-param-reassign\n        canvas.height = this.height;\n        console.warn('* loadImageArray getContext 2d');\n        const ctx = canvas.getContext('2d');\n        ctx.drawImage(this, 0, 0);\n        const array = new Uint8Array(this.width * this.height);\n        ctx.drawImage(this, 0, 0);\n        const { data } = ctx.getImageData(0, 0, this.width, this.height);\n        computeGray(data, array);\n        this.callback(array, {\n            x: this.width,\n            y: this.height,\n        }, this);\n    };\n    img.src = src;\n}\n\n/**\n * @param inImg {ImageWrapper} input image to be sampled\n * @param outImg {ImageWrapper} to be stored in\n */\nexport function halfSample(inImgWrapper, outImgWrapper) {\n    const inImg = inImgWrapper.data;\n    const inWidth = inImgWrapper.size.x;\n    const outImg = outImgWrapper.data;\n    let topRowIdx = 0;\n    let bottomRowIdx = inWidth;\n    const endIdx = inImg.length;\n    const outWidth = inWidth / 2;\n    let outImgIdx = 0;\n    while (bottomRowIdx < endIdx) {\n        for (let i = 0; i < outWidth; i++) {\n            outImg[outImgIdx] = Math.floor(\n                (inImg[topRowIdx] + inImg[topRowIdx + 1] + inImg[bottomRowIdx] + inImg[bottomRowIdx + 1]) / 4,\n            );\n            outImgIdx++;\n            topRowIdx += 2;\n            bottomRowIdx += 2;\n        }\n        topRowIdx += inWidth;\n        bottomRowIdx += inWidth;\n    }\n}\n\nexport function hsv2rgb(hsv, rgb = [0, 0, 0]) {\n    const h = hsv[0];\n    const s = hsv[1];\n    const v = hsv[2];\n    const c = v * s;\n    const x = c * (1 - Math.abs((h / 60) % 2 - 1));\n    const m = v - c;\n    let r = 0;\n    let g = 0;\n    let b = 0;\n\n    if (h < 60) {\n        r = c;\n        g = x;\n    } else if (h < 120) {\n        r = x;\n        g = c;\n    } else if (h < 180) {\n        g = c;\n        b = x;\n    } else if (h < 240) {\n        g = x;\n        b = c;\n    } else if (h < 300) {\n        r = x;\n        b = c;\n    } else if (h < 360) {\n        r = c;\n        b = x;\n    }\n    // eslint-disable-next-line no-param-reassign\n    rgb[0] = ((r + m) * 255) | 0;\n    // eslint-disable-next-line no-param-reassign\n    rgb[1] = ((g + m) * 255) | 0;\n    // eslint-disable-next-line no-param-reassign\n    rgb[2] = ((b + m) * 255) | 0;\n    return rgb;\n}\n\nexport function _computeDivisors(n) {\n    const largeDivisors = [];\n    const divisors = [];\n\n    for (let i = 1; i < Math.sqrt(n) + 1; i++) {\n        if (n % i === 0) {\n            divisors.push(i);\n            if (i !== n / i) {\n                largeDivisors.unshift(Math.floor(n / i));\n            }\n        }\n    }\n    return divisors.concat(largeDivisors);\n}\n\nfunction _computeIntersection(arr1, arr2) {\n    let i = 0;\n    let j = 0;\n    const result = [];\n\n    while (i < arr1.length && j < arr2.length) {\n        if (arr1[i] === arr2[j]) {\n            result.push(arr1[i]);\n            i++;\n            j++;\n        } else if (arr1[i] > arr2[j]) {\n            j++;\n        } else {\n            i++;\n        }\n    }\n    return result;\n}\n\nexport function calculatePatchSize(patchSize, imgSize) {\n    const divisorsX = _computeDivisors(imgSize.x);\n    const divisorsY = _computeDivisors(imgSize.y);\n    const wideSide = Math.max(imgSize.x, imgSize.y);\n    const common = _computeIntersection(divisorsX, divisorsY);\n    const nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80];\n    const nrOfPatchesMap = {\n        'x-small': 5,\n        small: 4,\n        medium: 3,\n        large: 2,\n        'x-large': 1,\n    };\n    const nrOfPatchesIdx = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium;\n    const nrOfPatches = nrOfPatchesList[nrOfPatchesIdx];\n    const desiredPatchSize = Math.floor(wideSide / nrOfPatches);\n    let optimalPatchSize;\n\n    function findPatchSizeForDivisors(divisors) {\n        let i = 0;\n        let found = divisors[Math.floor(divisors.length / 2)];\n\n        while (i < (divisors.length - 1) && divisors[i] < desiredPatchSize) {\n            i++;\n        }\n        if (i > 0) {\n            if (Math.abs(divisors[i] - desiredPatchSize) > Math.abs(divisors[i - 1] - desiredPatchSize)) {\n                found = divisors[i - 1];\n            } else {\n                found = divisors[i];\n            }\n        }\n        if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIdx + 1] / nrOfPatchesList[nrOfPatchesIdx]\n            && desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIdx - 1] / nrOfPatchesList[nrOfPatchesIdx]) {\n            return { x: found, y: found };\n        }\n        return null;\n    }\n\n    optimalPatchSize = findPatchSizeForDivisors(common);\n    if (!optimalPatchSize) {\n        optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide));\n        if (!optimalPatchSize) {\n            optimalPatchSize = findPatchSizeForDivisors((_computeDivisors(desiredPatchSize * nrOfPatches)));\n        }\n    }\n    return optimalPatchSize;\n}\n\nexport function _parseCSSDimensionValues(value) {\n    const dimension = {\n        value: parseFloat(value),\n        unit: value.indexOf('%') === value.length - 1 ? '%' : '%',\n    };\n\n    return dimension;\n}\n\nexport const _dimensionsConverters = {\n    top(dimension, context) {\n        return dimension.unit === '%' ? Math.floor(context.height * (dimension.value / 100)) : null;\n    },\n    right(dimension, context) {\n        return dimension.unit === '%' ? Math.floor(context.width - (context.width * (dimension.value / 100))) : null;\n    },\n    bottom(dimension, context) {\n        return dimension.unit === '%' ? Math.floor(context.height - (context.height * (dimension.value / 100))) : null;\n    },\n    left(dimension, context) {\n        return dimension.unit === '%' ? Math.floor(context.width * (dimension.value / 100)) : null;\n    },\n};\n\nexport function computeImageArea(inputWidth, inputHeight, area) {\n    const context = { width: inputWidth, height: inputHeight };\n\n    const parsedArea = Object.keys(area).reduce((result, key) => {\n        const value = area[key];\n        const parsed = _parseCSSDimensionValues(value);\n        const calculated = _dimensionsConverters[key](parsed, context);\n\n        // eslint-disable-next-line no-param-reassign\n        result[key] = calculated;\n        return result;\n    }, {});\n\n    return {\n        sx: parsedArea.left,\n        sy: parsedArea.top,\n        sw: parsedArea.right - parsedArea.left,\n        sh: parsedArea.bottom - parsedArea.top,\n    };\n}\n","import { vec2 } from 'gl-matrix';\nimport {\n    XYSize,\n    TypedArrayConstructor,\n    TypedArray,\n    WrapperIndexMapping,\n    Moment,\n    SparseImageWrapper,\n} from '../../type-definitions/quagga.d';\nimport ArrayHelper from './array_helper';\nimport { hsv2rgb } from './cv_utils';\n\ntype PositiveNumber = number;\nfunction assertNumberPositive(val: number): asserts val is PositiveNumber {\n    if (val < 0) {\n        throw new Error(`expected positive number, received ${val}`);\n    }\n}\n\nclass ImageWrapper implements SparseImageWrapper {\n    data: TypedArray | Array<number>;\n\n    size: XYSize;\n\n    indexMapping?: WrapperIndexMapping;\n\n    // Represents a basic image combining the data and size. In addition, some methods for\n    // manipulation are contained within.\n    constructor(\n        size: XYSize,\n        data?: TypedArray | Array<number>,\n        ArrayType: TypedArrayConstructor | ArrayConstructor = Uint8Array,\n        initialize?: boolean,\n    ) {\n        if (!data) {\n            this.data = new (ArrayType)(size.x * size.y);\n            if (initialize) {\n                ArrayHelper.init(this.data, 0);\n            }\n        } else {\n            this.data = data;\n        }\n        this.size = size;\n    }\n\n    // tests if a position is within the image, extended out by a border on each side\n    inImageWithBorder(imgRef: XYSize, border: PositiveNumber = 0): boolean {\n        assertNumberPositive(border);\n        return (imgRef.x >= 0)\n            && (imgRef.y >= 0)\n            && (imgRef.x < (this.size.x + (border * 2)))\n            && (imgRef.y < (this.size.y + (border * 2)));\n    }\n\n    // Copy from THIS ImageWrapper to the new imageWrapper parameter, starting at from, stopping at\n    // end of new imageWrapper size.\n    subImageAsCopy(imageWrapper: ImageWrapper, from: XYSize): ImageWrapper {\n        assertNumberPositive(from.x);\n        assertNumberPositive(from.y);\n        const { x: sizeX, y: sizeY } = imageWrapper.size;\n        for (let x = 0; x < sizeX; x++) {\n            for (let y = 0; y < sizeY; y++) {\n                // eslint-disable-next-line no-param-reassign\n                imageWrapper.data[y * sizeX + x] = this.data[(from.y + y) * this.size.x + from.x + x];\n            }\n        }\n        return imageWrapper;\n        // TODO: this function really probably should call into ImageWrapper somewhere to make\n        // sure that all of it's parameters are set properly, something like\n        // ImageWrapper.UpdateFrom()\n        // that might take a provided data and size, and make sure there's no invalid indexMapping\n        // hanging around, and such.\n    }\n\n    // Retrieve a grayscale value at the given pixel position of the image\n    get(x: number, y: number): number {\n        return this.data[y * this.size.x + x];\n    }\n\n    // Retrieve a grayscale value at the given pixel position of the image (safe, whatever that\n    // means)\n    getSafe(x: number, y: number): number {\n        // cache indexMapping because if we're using it once, we'll probably need it a bunch more\n        // too\n        if (!this.indexMapping) {\n            this.indexMapping = {\n                x: [],\n                y: [],\n            };\n            for (let i = 0; i < this.size.x; i++) {\n                this.indexMapping.x[i] = i;\n                this.indexMapping.x[i + this.size.x] = i;\n            }\n            for (let i = 0; i < this.size.y; i++) {\n                this.indexMapping.y[i] = i;\n                this.indexMapping.y[i + this.size.y] = i;\n            }\n        }\n        return this.data[(this.indexMapping.y[y + this.size.y]) * this.size.x + this.indexMapping.x[x + this.size.x]];\n    }\n\n    // Sets a given pixel position in the image to the given grayscale value\n    set(x: number, y: number, value: number): ImageWrapper {\n        this.data[y * this.size.x + x] = value;\n        delete this.indexMapping;\n        return this;\n    }\n\n    // Sets the border of the image (1 pixel) to zero\n    zeroBorder(): ImageWrapper {\n        const { x: width, y: height } = this.size;\n        for (let i = 0; i < width; i++) {\n            // eslint-disable-next-line no-multi-assign\n            this.data[i] = this.data[(height - 1) * width + i] = 0;\n        }\n        for (let i = 1; i < height - 1; i++) {\n            // eslint-disable-next-line no-multi-assign\n            this.data[i * width] = this.data[i * width + (width - 1)] = 0;\n        }\n        delete this.indexMapping;\n        return this;\n    }\n\n    // TODO: this function is entirely too large for me to reason out right at this moment that i'm handling\n    // all the rest of it, so this is a verbatim copy of the javascript source, with only tweaks\n    // necessary to get it to run, no thought put into it yet.\n    moments(labelCount: number): Array<Moment> {\n        const { data } = this;\n        let x;\n        let y;\n        const height = this.size.y;\n        const width = this.size.x;\n        let val;\n        let ysq;\n        const labelSum: Array<Moment> = [];\n        let i;\n        let label;\n        let mu11;\n        let mu02;\n        let mu20;\n        let x_;\n        let y_;\n        let tmp;\n        const result: Array<Moment> = [];\n        const { PI } = Math;\n        const PI_4 = PI / 4;\n\n        if (labelCount <= 0) {\n            return result;\n        }\n\n        for (i = 0; i < labelCount; i++) {\n            labelSum[i] = {\n                m00: 0,\n                m01: 0,\n                m10: 0,\n                m11: 0,\n                m02: 0,\n                m20: 0,\n                theta: 0,\n                rad: 0,\n            };\n        }\n\n        for (y = 0; y < height; y++) {\n            ysq = y * y;\n            for (x = 0; x < width; x++) {\n                val = data[y * width + x];\n                if (val > 0) {\n                    label = labelSum[val - 1];\n                    label.m00 += 1;\n                    label.m01 += y;\n                    label.m10 += x;\n                    label.m11 += x * y;\n                    label.m02 += ysq;\n                    label.m20 += x * x;\n                }\n            }\n        }\n\n        for (i = 0; i < labelCount; i++) {\n            label = labelSum[i];\n            // eslint-disable-next-line no-restricted-globals\n            if (!isNaN(label.m00) && label.m00 !== 0) {\n                x_ = label.m10 / label.m00;\n                y_ = label.m01 / label.m00;\n                mu11 = label.m11 / label.m00 - x_ * y_;\n                mu02 = label.m02 / label.m00 - y_ * y_;\n                mu20 = label.m20 / label.m00 - x_ * x_;\n                tmp = (mu02 - mu20) / (2 * mu11);\n                tmp = 0.5 * Math.atan(tmp) + (mu11 >= 0 ? PI_4 : -PI_4) + PI;\n                // eslint-disable-next-line no-mixed-operators\n                label.theta = (tmp * 180 / PI + 90) % 180 - 90;\n                if (label.theta < 0) {\n                    label.theta += 180;\n                }\n                label.rad = tmp > PI ? tmp - PI : tmp;\n                label.vec = vec2.clone([Math.cos(tmp), Math.sin(tmp)]);\n                result.push(label);\n            }\n        }\n        return result;\n    }\n\n    // return a Uint8ClampedArray containing this grayscale image converted to RGBA form\n    getAsRGBA(scale = 1.0): Uint8ClampedArray {\n        const ret = new Uint8ClampedArray(4 * this.size.x * this.size.y);\n        for (let y = 0; y < this.size.y; y++) {\n            for (let x = 0; x < this.size.x; x++) {\n                const pixel = y * this.size.x + x;\n                const current = this.get(x, y) * scale;\n                ret[pixel * 4 + 0] = current;\n                ret[pixel * 4 + 1] = current;\n                ret[pixel * 4 + 2] = current;\n                ret[pixel * 4 + 3] = 255;\n            }\n        }\n        return ret;\n    }\n\n    // Display this ImageWrapper in a given Canvas element at the specified scale\n    show(canvas: HTMLCanvasElement, scale = 1.0): void {\n        console.warn('* imagewrapper show getcontext 2d');\n        const ctx = canvas.getContext('2d');\n        if (!ctx) {\n            throw new Error('Unable to get canvas context');\n        }\n        const frame = ctx.getImageData(0, 0, canvas.width, canvas.height);\n        const data = this.getAsRGBA(scale);\n        // eslint-disable-next-line no-param-reassign\n        canvas.width = this.size.x;\n        // eslint-disable-next-line no-param-reassign\n        canvas.height = this.size.y;\n        const newFrame = new ImageData(data as Uint8ClampedArray<ArrayBuffer>, frame.width, frame.height);\n        ctx.putImageData(newFrame, 0, 0);\n    }\n\n    // Displays a specified SubImage area in a given canvas. This differs drastically from\n    // creating a new SubImage and using it's show() method. Why? I don't have the answer to that\n    // yet.  I suspect the HSV/RGB operations involved here are making it significantly different,\n    // but until I can visualize these functions side by side, I'm just going to copy the existing\n    // implementation.\n    overlay(canvas: HTMLCanvasElement, inScale: number, from: XYSize): void {\n        const adjustedScale = (inScale < 0 || inScale > 360) ? 360 : inScale;\n        const hsv = [0, 1, 1];\n        const rgb = [0, 0, 0];\n        const whiteRgb = [255, 255, 255];\n        const blackRgb = [0, 0, 0];\n        let result = [];\n        console.warn('* imagewrapper overlay getcontext 2d');\n        const ctx = canvas.getContext('2d');\n        if (!ctx) {\n            throw new Error('Unable to get canvas context');\n        }\n        const frame = ctx.getImageData(from.x, from.y, this.size.x, this.size.y);\n        const { data } = frame;\n        let { length } = this.data;\n        while (length--) {\n            hsv[0] = this.data[length] * adjustedScale;\n            // eslint-disable-next-line no-nested-ternary\n            result = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : hsv2rgb(hsv, rgb);\n            const pos = length * 4;\n            [data[pos], data[pos + 1], data[pos + 2]] = result;\n            data[pos + 3] = 255;\n        }\n        ctx.putImageData(frame, from.x, from.y);\n    }\n}\n\nexport default ImageWrapper;\n","import { XYSize } from '../../type-definitions/quagga.d';\n\n// TODO: XYPosition should be an XYObject, but that breaks XYDefinition, which breaks drawPath() below.\ndeclare interface XYPosition {\n    x: number;\n    y: number;\n}\n\ndeclare interface CanvasStyle {\n    color: string;\n    lineWidth: number;\n}\n\n// XYDefinition tells us which component of a given array or object is the \"X\" and which is the \"Y\".\n// Usually this is 0 for X and 1 for Y, but might be used as 'x' for x and 'y' for Y.\ndeclare interface XYDefinition {\n    x: keyof XYPosition;\n    y: keyof XYPosition;\n}\n\ndeclare type Path = Array<XYPosition>;\n\nexport default {\n    drawRect(pos: XYPosition, size: XYSize, ctx: CanvasRenderingContext2D, style: CanvasStyle): void {\n        ctx.strokeStyle = style.color;\n        ctx.fillStyle = style.color;\n        ctx.lineWidth = style.lineWidth || 1;\n        ctx.beginPath();\n        ctx.strokeRect(pos.x, pos.y, size.x, size.y);\n    },\n    drawPath(path: Path, def: XYDefinition, ctx: CanvasRenderingContext2D, style: CanvasStyle): void {\n        ctx.strokeStyle = style.color;\n        ctx.fillStyle = style.color;\n        ctx.lineWidth = style.lineWidth;\n        ctx.beginPath();\n        ctx.moveTo(path[0][def.x], path[0][def.y]);\n        for (let j = 1; j < path.length; j++) {\n            ctx.lineTo(path[j][def.x], path[j][def.y]);\n        }\n        ctx.closePath();\n        ctx.stroke();\n    },\n    drawImage(imageData: Array<number>, size: XYSize, ctx: CanvasRenderingContext2D): boolean {\n        const canvasData = ctx.getImageData(0, 0, size.x, size.y);\n        const { data } = canvasData;\n        let canvasDataPos = data.length;\n        let imageDataPos = imageData.length;\n\n        if (canvasDataPos / imageDataPos !== 4) {\n            return false;\n        }\n        while (imageDataPos--) {\n            const value = imageData[imageDataPos];\n            data[--canvasDataPos] = 255;\n            data[--canvasDataPos] = value;\n            data[--canvasDataPos] = value;\n            data[--canvasDataPos] = value;\n        }\n        ctx.putImageData(canvasData, 0, 0);\n        return true;\n    },\n};\n","/* eslint-disable no-unused-vars */\n/* eslint-disable class-methods-use-this */\n// eslint-disable-next-line import/no-cycle\nimport { ImageWrapper } from 'quagga';\nimport { QuaggaJSResultObject } from '../../type-definitions/quagga';\nimport ArrayHelper from '../common/array_helper';\n\n// for some reason this throws a shadow error on itself?!\n// eslint-disable-next-line no-shadow\nexport enum BarcodeDirection {\n    Forward = 1,\n    Reverse = -1\n}\n\nexport type BarcodeReaderType = string;\nexport type BarcodeFormat = string;\n\nexport interface BarcodeReaderConfig {\n    normalizeBarSpaceWidth?: boolean,\n    supplements?: Array<BarcodeReaderType>,\n}\n\nexport interface BarcodeCorrection {\n    bar: number,\n    space: number,\n}\n\nexport interface BarcodePosition {\n    end: number,\n    endCounter?: number,\n    error?: number,\n    start: number,\n    startCounter?: number\n}\n\nexport interface BarcodeInfo extends BarcodePosition {\n    code: number,\n    correction?: BarcodeCorrection,\n}\n\nexport interface Barcode {\n    code: string,\n    codeset?: number,\n    correction?: BarcodeCorrection,\n    decodedCodes?: Array<string | BarcodeInfo | BarcodePosition>,\n    direction?: BarcodeDirection,\n    end: number,\n    endInfo?: BarcodePosition,\n    format: BarcodeFormat,\n    start: number,\n    startInfo: BarcodePosition,\n    supplement?: Barcode,\n}\n\nexport abstract class BarcodeReader {\n    _row: Array<number> = [];\n\n    config: BarcodeReaderConfig = {};\n\n    supplements: Array<BarcodeReader> = [];\n\n    SINGLE_CODE_ERROR = 0;\n\n    FORMAT: BarcodeFormat = 'unknown';\n\n    CONFIG_KEYS: BarcodeReaderConfig = {};\n    // TODO: should add ALPHABETH_STRING, ALPHABET, CHARACTER_ENCODINGS to base class, if they\n    // are useful in most readers.\n\n    public abstract decode(row?: Array<number>, start?: BarcodePosition | number): Barcode | null;\n\n    static get Exception() {\n        return {\n            StartNotFoundException: 'Start-Info was not found!',\n            CodeNotFoundException: 'Code could not be found!',\n            PatternNotFoundException: 'Pattern could not be found!',\n        };\n    }\n\n    constructor(config: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        this._row = [];\n        this.config = config || {};\n        if (supplements) {\n            this.supplements = supplements;\n        }\n    }\n\n    protected _nextUnset(line: ReadonlyArray<number>, start = 0): number {\n        for (let i = start; i < line.length; i++) {\n            if (!line[i]) return i;\n        }\n        return line.length;\n    }\n\n    protected _matchPattern(counter: ReadonlyArray<number>, code: ReadonlyArray<number>, maxSingleError = this.SINGLE_CODE_ERROR || 1): number {\n        let error = 0;\n        let singleError = 0;\n        let sum = 0;\n        let modulo = 0;\n        let barWidth = 0;\n        let count = 0;\n        let scaled = 0;\n\n        for (let i = 0; i < counter.length; i++) {\n            sum += counter[i];\n            modulo += code[i];\n        }\n        if (sum < modulo) {\n            return Number.MAX_VALUE;\n        }\n\n        barWidth = sum / modulo;\n        // eslint-disable-next-line no-param-reassign\n        maxSingleError *= barWidth;\n        for (let i = 0; i < counter.length; i++) {\n            count = counter[i];\n            scaled = code[i] * barWidth;\n            singleError = Math.abs(count - scaled) / scaled;\n            if (singleError > maxSingleError) {\n                return Number.MAX_VALUE;\n            }\n            error += singleError;\n        }\n        return error / modulo;\n    }\n\n    protected _nextSet(line: ReadonlyArray<number>, offset = 0) {\n        for (let i = offset; i < line.length; i++) {\n            if (line[i]) return i;\n        }\n        return line.length;\n    }\n\n    protected _correctBars(counter: Array<number>, correction: number, indices: Array<number>) {\n        let { length } = indices;\n        let tmp = 0;\n        while (length--) {\n            tmp = counter[indices[length]] * (1 - ((1 - correction) / 2));\n            if (tmp > 1) {\n                // eslint-disable-next-line no-param-reassign\n                counter[indices[length]] = tmp;\n            }\n        }\n    }\n\n    public decodePattern(pattern: Array<number>) {\n        // console.warn('* decodePattern', pattern);\n        this._row = pattern;\n        // console.warn('* decodePattern calling decode', typeof this, this.constructor, this.FORMAT, JSON.stringify(this));\n        let result = this.decode();\n        // console.warn('* first result=', result);\n        if (result === null) {\n            this._row.reverse();\n            result = this.decode();\n            // console.warn('* reversed result=', result);\n            if (result) {\n                result.direction = BarcodeDirection.Reverse;\n                result.start = this._row.length - result.start;\n                result.end = this._row.length - result.end;\n            }\n        } else {\n            result.direction = BarcodeDirection.Forward;\n        }\n        if (result) {\n            result.format = this.FORMAT;\n        }\n        // console.warn('* returning', result);\n        return result;\n    }\n\n    protected _matchRange(start: number, end: number, value: number) {\n        // eslint-disable-next-line no-param-reassign\n        start = start < 0 ? 0 : start;\n        let i;\n        for (i = start; i < end; i++) {\n            if (this._row[i] !== value) {\n                return false;\n            }\n        }\n        return true;\n    }\n\n    protected _fillCounters(offset: number = this._nextUnset(this._row), end: number = this._row.length, isWhite = true) {\n        const counters: Array<number> = [];\n        let counterPos = 0;\n        counters[counterPos] = 0;\n        for (let i = offset; i < end; i++) {\n            // eslint-disable-next-line no-bitwise\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counters[counterPos]++;\n            } else {\n                counterPos++;\n                counters[counterPos] = 1;\n                // eslint-disable-next-line no-param-reassign\n                isWhite = !isWhite;\n            }\n        }\n        return counters;\n    }\n\n    protected _toCounters(start: number, counters: Uint16Array | Array<number>) {\n        const numCounters = counters.length;\n        const end = this._row.length;\n        let isWhite = !this._row[start];\n        let counterPos = 0;\n\n        ArrayHelper.init(counters, 0);\n        for (let i = start; i < end; i++) {\n            // eslint-disable-next-line no-bitwise\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                // eslint-disable-next-line no-param-reassign\n                counters[counterPos]++;\n            } else {\n                counterPos++;\n                if (counterPos === numCounters) {\n                    break;\n                } else {\n                    // eslint-disable-next-line no-param-reassign\n                    counters[counterPos] = 1;\n                    isWhite = !isWhite;\n                }\n            }\n        }\n        return counters;\n    }\n\n    // override/implement this in your custom readers.\n    protected decodeImage(imageWrapper: ImageWrapper): QuaggaJSResultObject | null {\n        // eslint-disable-next-line no-void\n        void imageWrapper;\n        return null;\n    }\n}\n\nexport default BarcodeReader;\n","import BarcodeReader, { Barcode, BarcodeInfo, BarcodePosition } from './barcode_reader';\n\nconst N = 1;\nconst W = 3;\nconst START_PATTERN = [W, N, W, N, N, N];\nconst STOP_PATTERN = [W, N, N, N, W];\nconst CODE_PATTERN = [\n    [N, N, W, W, N],\n    [W, N, N, N, W],\n    [N, W, N, N, W],\n    [W, W, N, N, N],\n    [N, N, W, N, W],\n    [W, N, W, N, N],\n    [N, W, W, N, N],\n    [N, N, N, W, W],\n    [W, N, N, W, N],\n    [N, W, N, W, N],\n];\nconst START_PATTERN_LENGTH = START_PATTERN.reduce((sum, val) => sum + val, 0);\n\nclass TwoOfFiveReader extends BarcodeReader {\n    barSpaceRatio = [1, 1];\n\n    FORMAT = '2of5';\n\n    SINGLE_CODE_ERROR = 0.78;\n\n    AVG_CODE_ERROR = 0.30;\n\n    protected _findPattern(pattern: ReadonlyArray<number>, offset: number, isWhite = false, tryHarder = false): BarcodeInfo | null {\n        const counter = [];\n        let counterPos = 0;\n        const bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0,\n        };\n        let sum = 0;\n        let error = 0;\n        const epsilon = this.AVG_CODE_ERROR;\n\n        if (!offset) {\n            offset = this._nextSet(this._row);\n        }\n\n        for (let i = 0; i < pattern.length; i++) {\n            counter[i] = 0;\n        }\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    sum = 0;\n                    for (let j = 0; j < counter.length; j++) {\n                        sum += counter[j];\n                    }\n                    error = this._matchPattern(counter, pattern);\n                    if (error < epsilon) {\n                        bestMatch.error = error;\n                        bestMatch.start = i - sum;\n                        bestMatch.end = i;\n                        return bestMatch;\n                    }\n                    if (tryHarder) {\n                        for (let j = 0; j < counter.length - 2; j++) {\n                            counter[j] = counter[j + 2];\n                        }\n                        counter[counter.length - 2] = 0;\n                        counter[counter.length - 1] = 0;\n                        counterPos--;\n                    } else {\n                        return null;\n                    }\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n        return null;\n    }\n\n    protected _findStart(): BarcodePosition | null {\n        let startInfo = null;\n        let offset = this._nextSet(this._row);\n        let narrowBarWidth = 1;\n        let leadingWhitespaceStart = 0;\n\n        while (!startInfo) {\n            startInfo = this._findPattern(START_PATTERN, offset, false, true);\n            if (!startInfo) {\n                return null;\n            }\n            narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / START_PATTERN_LENGTH);\n            leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5;\n            if (leadingWhitespaceStart >= 0) {\n                if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                    return startInfo;\n                }\n            }\n            offset = startInfo.end;\n            startInfo = null;\n        }\n        return startInfo;\n    }\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodeInfo): BarcodePosition | null {\n        const trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n        return null;\n    }\n\n    protected _findEnd(): BarcodePosition | null {\n        // TODO: reverse, followed by some calcs, followed by another reverse? really?\n        this._row.reverse();\n        const offset = this._nextSet(this._row);\n        const endInfo = this._findPattern(STOP_PATTERN, offset, false, true);\n        this._row.reverse();\n\n        if (endInfo === null) {\n            return null;\n        }\n\n        // reverse numbers\n        const tmp = endInfo.start;\n        endInfo.start = this._row.length - endInfo.end;\n        endInfo.end = this._row.length - tmp;\n\n        return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;\n    }\n\n    protected _verifyCounterLength(counters: Array<number>) {\n        return (counters.length % 10 === 0);\n    }\n\n    protected _decodeCode(counter: ReadonlyArray<number>): BarcodeInfo | null {\n        const epsilon = this.AVG_CODE_ERROR;\n        const bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0,\n        };\n\n        for (let code = 0; code < CODE_PATTERN.length; code++) {\n            const error = this._matchPattern(counter, CODE_PATTERN[code]);\n            if (error < bestMatch.error!) {\n                bestMatch.code = code;\n                bestMatch.error = error;\n            }\n        }\n        if (bestMatch.error! < epsilon) {\n            return bestMatch;\n        }\n        return null;\n    }\n\n    protected _decodePayload(counters: ReadonlyArray<number>, result: Array<string>, decodedCodes: Array<BarcodeInfo | BarcodePosition>): BarcodeInfo | null {\n        let pos = 0;\n        const counterLength = counters.length;\n        const counter = [0, 0, 0, 0, 0];\n        let code: BarcodeInfo | null = null;\n\n        while (pos < counterLength) {\n            for (let i = 0; i < 5; i++) {\n                counter[i] = counters[pos] * this.barSpaceRatio[0];\n                pos += 2;\n            }\n            code = this._decodeCode(counter);\n            if (!code) {\n                return null;\n            }\n            result.push(`${code.code}`);\n            decodedCodes.push(code);\n        }\n        return code;\n    }\n\n\n    public decode(row?: Array<number>, start?: BarcodePosition): Barcode | null {\n        const startInfo = this._findStart();\n        if (!startInfo) {\n            return null;\n        }\n\n        const endInfo = this._findEnd();\n        if (!endInfo) {\n            return null;\n        }\n\n        const counters = this._fillCounters(startInfo.end, endInfo.start, false);\n        if (!this._verifyCounterLength(counters)) {\n            return null;\n        }\n        const decodedCodes = [];\n        decodedCodes.push(startInfo);\n\n        const result: Array<string> = [];\n        const code = this._decodePayload(counters, result, decodedCodes);\n        if (!code) {\n            return null;\n        }\n        if (result.length < 5) {\n            return null;\n        }\n\n        decodedCodes.push(endInfo);\n        return {\n            code: result.join(''),\n            start: startInfo.start,\n            end: endInfo.end,\n            startInfo,\n            decodedCodes,\n            format: this.FORMAT,\n        };\n    }\n}\n\nexport default TwoOfFiveReader;\n","import BarcodeReader, { Barcode, BarcodePosition } from './barcode_reader';\n\n// const ALPHABETH_STRING = '0123456789-$:/.+ABCD';\nconst ALPHABET = [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 45, 36, 58, 47, 46, 43, 65, 66, 67, 68];\nconst CHARACTER_ENCODINGS =\n    [0x003, 0x006, 0x009, 0x060, 0x012, 0x042, 0x021, 0x024, 0x030, 0x048, 0x00c, 0x018,\n        0x045, 0x051, 0x054, 0x015, 0x01A, 0x029, 0x00B, 0x00E];\nconst START_END = [0x01A, 0x029, 0x00B, 0x00E];\nconst MIN_ENCODED_CHARS = 4;\nconst MAX_ACCEPTABLE = 2.0;\nconst PADDING = 1.5;\n\ninterface ThresholdSize {\n    size: number,\n    counts: number,\n    min: number,\n    max: number,\n};\n\ninterface Threshold {\n    space: {\n        narrow: ThresholdSize,\n        wide: ThresholdSize,\n    },\n    bar: {\n        narrow: ThresholdSize,\n        wide: ThresholdSize,\n    },\n};\n\nclass NewCodabarReader extends BarcodeReader {\n    _counters: Array<number> = [];\n    FORMAT = 'codabar';\n\n    protected _computeAlternatingThreshold(offset: number, end: number) {\n        let min = Number.MAX_VALUE;\n        let max = 0;\n        let counter = 0;\n\n        for (let i = offset; i < end; i += 2) {\n            counter = this._counters[i];\n            if (counter > max) {\n                max = counter;\n            }\n            if (counter < min) {\n                min = counter;\n            }\n        }\n\n        return ((min + max) / 2.0) | 0;\n    };\n\n    protected _toPattern(offset: number) {\n        const numCounters = 7;\n        const end = offset + numCounters;\n\n        if (end > this._counters.length) {\n            return -1;\n        }\n\n        const barThreshold = this._computeAlternatingThreshold(offset, end);\n        const spaceThreshold = this._computeAlternatingThreshold(offset + 1, end);\n\n        let bitmask = 1 << (numCounters - 1);\n        let threshold = 0;\n        let pattern = 0;\n\n        for (let i = 0; i < numCounters; i++) {\n            threshold = (i & 1) === 0 ? barThreshold : spaceThreshold;\n            if (this._counters[offset + i] > threshold) {\n                pattern |= bitmask;\n            }\n            bitmask >>= 1;\n        }\n\n        return pattern;\n    };\n\n    protected _isStartEnd(pattern: number) {\n        for (let i = 0; i < START_END.length; i++) {\n            if (START_END[i] === pattern) {\n                return true;\n            }\n        }\n        return false;\n    };\n\n    protected _sumCounters(start: number, end: number) {\n        let sum = 0;\n\n        for (let i = start; i < end; i++) {\n            sum += this._counters[i];\n        }\n        return sum;\n    };\n\n    protected _findStart(): BarcodePosition | null {\n        let start = this._nextUnset(this._row);\n        let end = start;\n\n        for (let i = 1; i < this._counters.length; i++) {\n            const pattern = this._toPattern(i);\n            if (pattern !== -1 && this._isStartEnd(pattern)) {\n                // TODO: Look for whitespace ahead\n                start += this._sumCounters(0, i);\n                end = start + this._sumCounters(i, i + 8);\n                return {\n                    start: start,\n                    end: end,\n                    startCounter: i,\n                    endCounter: i + 8,\n                };\n            }\n        }\n        return null;\n    }\n\n    protected _patternToChar(pattern: number) {\n        for (let i = 0; i < CHARACTER_ENCODINGS.length; i++) {\n            if (CHARACTER_ENCODINGS[i] === pattern) {\n                return String.fromCharCode(ALPHABET[i]);\n            }\n        }\n        return null;\n    };\n\n    protected _calculatePatternLength(offset: number) {\n        let sum = 0;\n\n        for (let i = offset; i < offset + 7; i++) {\n            sum += this._counters[i];\n        }\n\n        return sum;\n    };\n\n    protected _verifyWhitespace(startCounter: number, endCounter: number) {\n        if ((startCounter - 1 <= 0)\n            || this._counters[startCounter - 1] >= (this._calculatePatternLength(startCounter) / 2.0)) {\n            if ((endCounter + 8 >= this._counters.length)\n                || this._counters[endCounter + 7] >= (this._calculatePatternLength(endCounter) / 2.0)) {\n                return true;\n            }\n        }\n        return false;\n    };\n\n    protected _charToPattern(char: string) {\n        const charCode = char.charCodeAt(0);\n\n        for (let i = 0; i < ALPHABET.length; i++) {\n            if (ALPHABET[i] === charCode) {\n                return CHARACTER_ENCODINGS[i];\n            }\n        }\n        return 0x0;\n    };\n\n    protected _thresholdResultPattern(result: ReadonlyArray<string>, startCounter: number) {\n        const categorization: Threshold = {\n                space: {\n                    narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE },\n                    wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE },\n                },\n                bar: {\n                    narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE },\n                    wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE },\n                },\n            };\n        let pos = startCounter;\n        let pattern: number;\n\n        for (let i = 0; i < result.length; i++) {\n            pattern = this._charToPattern(result[i]);\n            for (let j = 6; j >= 0; j--) {\n                const kind = (j & 1) === 2 ? categorization.bar : categorization.space;\n                const cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\n                cat.size += this._counters[pos + j];\n                cat.counts++;\n                pattern >>= 1;\n            }\n            pos += 8;\n        }\n\n        (['space', 'bar'] as const).forEach(function (key) {\n            const newkind = categorization[key];\n            newkind.wide.min =\n                Math.floor((newkind.narrow.size / newkind.narrow.counts + newkind.wide.size / newkind.wide.counts) / 2);\n            newkind.narrow.max = Math.ceil(newkind.wide.min);\n            newkind.wide.max = Math.ceil((newkind.wide.size * MAX_ACCEPTABLE + PADDING) / newkind.wide.counts);\n        });\n\n        return categorization;\n    };\n\n    protected _validateResult(result: ReadonlyArray<string>, startCounter: number) {\n        const thresholds = this._thresholdResultPattern(result, startCounter);\n        let pos = startCounter;\n        let pattern: number;\n\n        for (let i = 0; i < result.length; i++) {\n            pattern = this._charToPattern(result[i]);\n            for (let j = 6; j >= 0; j--) {\n                const kind = (j & 1) === 0 ? thresholds.bar : thresholds.space;\n                const cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\n                const size = this._counters[pos + j];\n                if (size < cat.min || size > cat.max) {\n                    return false;\n                }\n                pattern >>= 1;\n            }\n            pos += 8;\n        }\n        return true;\n    };\n\n    public decode(row?: Array<number>, start?: BarcodePosition | number | null): Barcode | null {\n\n        this._counters = this._fillCounters();\n        start = this._findStart();\n        if (!start) {\n            return null;\n        }\n        let nextStart = start.startCounter as number;\n\n        const result: Array<string> = [];\n        let pattern: number;\n        do {\n            pattern = this._toPattern(nextStart);\n            if (pattern < 0) {\n                return null;\n            }\n            const decodedChar = this._patternToChar(pattern);\n            if (decodedChar === null) {\n                return null;\n            }\n            result.push(decodedChar);\n            nextStart += 8;\n            if (result.length > 1 && this._isStartEnd(pattern)) {\n                break;\n            }\n        } while (nextStart < this._counters.length);\n\n        // verify end\n        if ((result.length - 2) < MIN_ENCODED_CHARS || !this._isStartEnd(pattern)) {\n            return null;\n        }\n\n        // verify end white space\n        if (!this._verifyWhitespace(start.startCounter as number, nextStart - 8)) {\n            return null;\n        }\n\n        if (!this._validateResult(result, start.startCounter as number)) {\n            return null;\n        }\n\n        nextStart = nextStart > this._counters.length ? this._counters.length : nextStart;\n        const end = start.start + this._sumCounters(start.startCounter as number, nextStart - 8);\n\n        return {\n            code: result.join(''),\n            start: start.start,\n            end: end,\n            startInfo: start,\n            decodedCodes: result,\n            format: this.FORMAT, // TODO: i think it should not be required to return format from this, as barcode_reader force sets the format anyway\n        };\n    };\n}\n\nexport default NewCodabarReader;\n","import BarcodeReader, { BarcodeCorrection, BarcodePosition, Barcode, BarcodeInfo } from './barcode_reader';\n\nclass Code128Reader extends BarcodeReader {\n    CODE_SHIFT = 98;\n    CODE_C = 99;\n    CODE_B = 100;\n    CODE_A = 101;\n    START_CODE_A = 103;\n    START_CODE_B = 104;\n    START_CODE_C = 105;\n    STOP_CODE = 106;\n    CODE_PATTERN = [\n            [2, 1, 2, 2, 2, 2],\n            [2, 2, 2, 1, 2, 2],\n            [2, 2, 2, 2, 2, 1],\n            [1, 2, 1, 2, 2, 3],\n            [1, 2, 1, 3, 2, 2],\n            [1, 3, 1, 2, 2, 2],\n            [1, 2, 2, 2, 1, 3],\n            [1, 2, 2, 3, 1, 2],\n            [1, 3, 2, 2, 1, 2],\n            [2, 2, 1, 2, 1, 3],\n            [2, 2, 1, 3, 1, 2],\n            [2, 3, 1, 2, 1, 2],\n            [1, 1, 2, 2, 3, 2],\n            [1, 2, 2, 1, 3, 2],\n            [1, 2, 2, 2, 3, 1],\n            [1, 1, 3, 2, 2, 2],\n            [1, 2, 3, 1, 2, 2],\n            [1, 2, 3, 2, 2, 1],\n            [2, 2, 3, 2, 1, 1],\n            [2, 2, 1, 1, 3, 2],\n            [2, 2, 1, 2, 3, 1],\n            [2, 1, 3, 2, 1, 2],\n            [2, 2, 3, 1, 1, 2],\n            [3, 1, 2, 1, 3, 1],\n            [3, 1, 1, 2, 2, 2],\n            [3, 2, 1, 1, 2, 2],\n            [3, 2, 1, 2, 2, 1],\n            [3, 1, 2, 2, 1, 2],\n            [3, 2, 2, 1, 1, 2],\n            [3, 2, 2, 2, 1, 1],\n            [2, 1, 2, 1, 2, 3],\n            [2, 1, 2, 3, 2, 1],\n            [2, 3, 2, 1, 2, 1],\n            [1, 1, 1, 3, 2, 3],\n            [1, 3, 1, 1, 2, 3],\n            [1, 3, 1, 3, 2, 1],\n            [1, 1, 2, 3, 1, 3],\n            [1, 3, 2, 1, 1, 3],\n            [1, 3, 2, 3, 1, 1],\n            [2, 1, 1, 3, 1, 3],\n            [2, 3, 1, 1, 1, 3],\n            [2, 3, 1, 3, 1, 1],\n            [1, 1, 2, 1, 3, 3],\n            [1, 1, 2, 3, 3, 1],\n            [1, 3, 2, 1, 3, 1],\n            [1, 1, 3, 1, 2, 3],\n            [1, 1, 3, 3, 2, 1],\n            [1, 3, 3, 1, 2, 1],\n            [3, 1, 3, 1, 2, 1],\n            [2, 1, 1, 3, 3, 1],\n            [2, 3, 1, 1, 3, 1],\n            [2, 1, 3, 1, 1, 3],\n            [2, 1, 3, 3, 1, 1],\n            [2, 1, 3, 1, 3, 1],\n            [3, 1, 1, 1, 2, 3],\n            [3, 1, 1, 3, 2, 1],\n            [3, 3, 1, 1, 2, 1],\n            [3, 1, 2, 1, 1, 3],\n            [3, 1, 2, 3, 1, 1],\n            [3, 3, 2, 1, 1, 1],\n            [3, 1, 4, 1, 1, 1],\n            [2, 2, 1, 4, 1, 1],\n            [4, 3, 1, 1, 1, 1],\n            [1, 1, 1, 2, 2, 4],\n            [1, 1, 1, 4, 2, 2],\n            [1, 2, 1, 1, 2, 4],\n            [1, 2, 1, 4, 2, 1],\n            [1, 4, 1, 1, 2, 2],\n            [1, 4, 1, 2, 2, 1],\n            [1, 1, 2, 2, 1, 4],\n            [1, 1, 2, 4, 1, 2],\n            [1, 2, 2, 1, 1, 4],\n            [1, 2, 2, 4, 1, 1],\n            [1, 4, 2, 1, 1, 2],\n            [1, 4, 2, 2, 1, 1],\n            [2, 4, 1, 2, 1, 1],\n            [2, 2, 1, 1, 1, 4],\n            [4, 1, 3, 1, 1, 1],\n            [2, 4, 1, 1, 1, 2],\n            [1, 3, 4, 1, 1, 1],\n            [1, 1, 1, 2, 4, 2],\n            [1, 2, 1, 1, 4, 2],\n            [1, 2, 1, 2, 4, 1],\n            [1, 1, 4, 2, 1, 2],\n            [1, 2, 4, 1, 1, 2],\n            [1, 2, 4, 2, 1, 1],\n            [4, 1, 1, 2, 1, 2],\n            [4, 2, 1, 1, 1, 2],\n            [4, 2, 1, 2, 1, 1],\n            [2, 1, 2, 1, 4, 1],\n            [2, 1, 4, 1, 2, 1],\n            [4, 1, 2, 1, 2, 1],\n            [1, 1, 1, 1, 4, 3],\n            [1, 1, 1, 3, 4, 1],\n            [1, 3, 1, 1, 4, 1],\n            [1, 1, 4, 1, 1, 3],\n            [1, 1, 4, 3, 1, 1],\n            [4, 1, 1, 1, 1, 3],\n            [4, 1, 1, 3, 1, 1],\n            [1, 1, 3, 1, 4, 1],\n            [1, 1, 4, 1, 3, 1],\n            [3, 1, 1, 1, 4, 1],\n            [4, 1, 1, 1, 3, 1],\n            [2, 1, 1, 4, 1, 2],\n            [2, 1, 1, 2, 1, 4],\n            [2, 1, 1, 2, 3, 2],\n            [2, 3, 3, 1, 1, 1, 2],\n        ];\n    SINGLE_CODE_ERROR = 0.64;\n    AVG_CODE_ERROR = 0.30;\n    FORMAT = 'code_128';\n    MODULE_INDICES = { bar: [0, 2, 4], space: [1, 3, 5] };\n\n    protected _decodeCode(start: number, correction?: BarcodeCorrection): BarcodeInfo | null {\n        const bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: start,\n            end: start,\n            correction: {\n                bar: 1,\n                space: 1,\n            },\n        };\n        let counter = [0, 0, 0, 0, 0, 0];\n        const offset = start;\n        let isWhite = !this._row[offset];\n        let counterPos = 0;\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    if (correction) {\n                        this._correct(counter, correction);\n                    }\n                    for (let code = 0; code < this.CODE_PATTERN.length; code++) {\n                        const error = this._matchPattern(counter, this.CODE_PATTERN[code]);\n                        if (error < bestMatch.error) {\n                            bestMatch.code = code;\n                            bestMatch.error = error;\n                        }\n                    }\n                    bestMatch.end = i;\n                    if (bestMatch.code === -1 || bestMatch.error > this.AVG_CODE_ERROR) {\n                        return null;\n                    }\n                    if (this.CODE_PATTERN[bestMatch.code]) {\n                        bestMatch.correction.bar = this.calculateCorrection(\n                            this.CODE_PATTERN[bestMatch.code], counter,\n                            this.MODULE_INDICES.bar);\n                        bestMatch.correction.space = this.calculateCorrection(\n                            this.CODE_PATTERN[bestMatch.code], counter,\n                            this.MODULE_INDICES.space);\n                    }\n                    return bestMatch;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n        return null;\n    };\n\n    protected _correct(counter: Array<number>, correction: BarcodeCorrection) {\n        this._correctBars(counter, correction.bar, this.MODULE_INDICES.bar);\n        this._correctBars(counter, correction.space, this.MODULE_INDICES.space);\n    };\n\n    // TODO: _findStart and decodeCode share similar code, can we re-use some?\n    protected _findStart(): BarcodeInfo | null {\n        const counter = [0, 0, 0, 0, 0, 0];\n        const offset = this._nextSet(this._row);\n        const bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0,\n            correction: {\n                bar: 1,\n                space: 1,\n            },\n        };\n        let isWhite = false;\n        let counterPos = 0;\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    const sum = counter.reduce((prev, next) => prev + next, 0);\n                    for (let code = this.START_CODE_A; code <= this.START_CODE_C; code++) {\n                        const error = this._matchPattern(counter, this.CODE_PATTERN[code]);\n                        if (error < bestMatch.error) {\n                            bestMatch.code = code;\n                            bestMatch.error = error;\n                        }\n                    }\n                    if (bestMatch.error < this.AVG_CODE_ERROR) {\n                        bestMatch.start = i - sum;\n                        bestMatch.end = i;\n                        bestMatch.correction.bar = this.calculateCorrection(\n                            this.CODE_PATTERN[bestMatch.code], counter,\n                            this.MODULE_INDICES.bar);\n                        bestMatch.correction.space = this.calculateCorrection(\n                            this.CODE_PATTERN[bestMatch.code], counter,\n                            this.MODULE_INDICES.space);\n                        return bestMatch;\n                    }\n\n                    for (let j = 0; j < 4; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[4] = 0;\n                    counter[5] = 0;\n                    counterPos--;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n        return null;\n    };\n\n    public decode(row?: Array<number>, start?: BarcodePosition): Barcode | null {\n        const startInfo = this._findStart();\n        if (startInfo === null) {\n            return null;\n        }\n        // var self = this,\n        //     done = false,\n        //     result = [],\n        //     multiplier = 0,\n        //     checksum = 0,\n        //     codeset,\n        //     rawResult = [],\n        //     decodedCodes = [],\n        //     shiftNext = false,\n        //     unshift,\n        //     removeLastCharacter = true;\n\n        let code: BarcodeInfo | null = {\n            code: startInfo.code,\n            start: startInfo.start,\n            end: startInfo.end,\n            correction: {\n                bar: startInfo.correction!.bar,\n                space: startInfo.correction!.space,\n            },\n        };\n        const decodedCodes = [];\n        decodedCodes.push(code);\n        let checksum = code.code;\n        let codeset = ((c: number) => {\n            switch (c) {\n                case this.START_CODE_A:\n                    return this.CODE_A;\n                case this.START_CODE_B:\n                    return this.CODE_B;\n                case this.START_CODE_C:\n                    return this.CODE_C;\n                default:\n                    return null;\n            }\n        })(code.code);\n        let done = false;\n        let shiftNext = false;\n        let unshift = shiftNext;\n        let removeLastCharacter = true;\n        let multiplier = 0;\n        let rawResult: Array<number> = [];\n        let result: Array<string | number> = []; // TODO: i think this should be string only, but it creates problems if it is\n\n        while (!done) {\n            unshift = shiftNext;\n            shiftNext = false;\n            code = this._decodeCode(code!.end, code!.correction);\n            if (code !== null) {\n                if (code.code !== this.STOP_CODE) {\n                    removeLastCharacter = true;\n                }\n\n                if (code.code !== this.STOP_CODE) {\n                    rawResult.push(code.code);\n                    multiplier++;\n                    checksum += multiplier * code.code;\n                }\n                decodedCodes.push(code);\n\n                switch (codeset) {\n                case this.CODE_A:\n                    if (code.code < 64) {\n                        result.push(String.fromCharCode(32 + code.code));\n                    } else if (code.code < 96) {\n                        result.push(String.fromCharCode(code.code - 64));\n                    } else {\n                        if (code.code !== this.STOP_CODE) {\n                            removeLastCharacter = false;\n                        }\n                        switch (code.code) {\n                        case this.CODE_SHIFT:\n                            shiftNext = true;\n                            codeset = this.CODE_B;\n                            break;\n                        case this.CODE_B:\n                            codeset = this.CODE_B;\n                            break;\n                        case this.CODE_C:\n                            codeset = this.CODE_C;\n                            break;\n                        case this.STOP_CODE:\n                            done = true;\n                            break;\n                        }\n                    }\n                    break;\n                case this.CODE_B:\n                    if (code.code < 96) {\n                        result.push(String.fromCharCode(32 + code.code));\n                    } else {\n                        if (code.code !== this.STOP_CODE) {\n                            removeLastCharacter = false;\n                        }\n                        switch (code.code) {\n                            case this.CODE_SHIFT:\n                                shiftNext = true;\n                                codeset = this.CODE_A;\n                                break;\n                            case this.CODE_A:\n                                codeset = this.CODE_A;\n                                break;\n                            case this.CODE_C:\n                                codeset = this.CODE_C;\n                                break;\n                            case this.STOP_CODE:\n                                done = true;\n                                break;\n                        }\n                    }\n                    break;\n                case this.CODE_C:\n                    if (code.code < 100) {\n                        result.push(code.code < 10 ? '0' + code.code : code.code);\n                    } else {\n                        if (code.code !== this.STOP_CODE) {\n                            removeLastCharacter = false;\n                        }\n                        switch (code.code) {\n                        case this.CODE_A:\n                            codeset = this.CODE_A;\n                            break;\n                        case this.CODE_B:\n                            codeset = this.CODE_B;\n                            break;\n                        case this.STOP_CODE:\n                            done = true;\n                            break;\n                        }\n                    }\n                    break;\n                }\n            } else {\n                done = true;\n            }\n            if (unshift) {\n                codeset = codeset === this.CODE_A ? this.CODE_B : this.CODE_A;\n            }\n        }\n\n        if (code === null) {\n            return null;\n        }\n\n        code.end = this._nextUnset(this._row, code.end);\n        if (!this._verifyTrailingWhitespace(code)){\n            return null;\n        }\n\n        checksum -= multiplier * rawResult[rawResult.length - 1];\n        if (checksum % 103 !== rawResult[rawResult.length - 1]) {\n            return null;\n        }\n\n        if (!result.length) {\n            return null;\n        }\n\n        // remove last code from result (checksum)\n        if (removeLastCharacter) {\n            result.splice(result.length - 1, 1);\n        }\n\n\n        return {\n            code: result.join(''),\n            start: startInfo.start,\n            end: code.end,\n            codeset: codeset as number,\n            startInfo: startInfo,\n            decodedCodes: decodedCodes,\n            endInfo: code,\n            format: this.FORMAT,\n        };\n    };\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodeInfo): BarcodeInfo | null {\n\n        var self = this,\n            trailingWhitespaceEnd;\n\n        trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n        if (trailingWhitespaceEnd < self._row.length) {\n            if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n        return null;\n    };\n\n\n    public calculateCorrection(expected: ReadonlyArray<number>, normalized: ReadonlyArray<number>, indices: ReadonlyArray<number>): number {\n        var length = indices.length,\n            sumNormalized = 0,\n            sumExpected = 0;\n\n        while (length--) {\n            sumExpected += expected[indices[length]];\n            sumNormalized += normalized[indices[length]];\n        }\n        return sumExpected / sumNormalized;\n    }\n}\n\nexport default Code128Reader;\n","/* eslint-disable class-methods-use-this */\nimport ArrayHelper from '../common/array_helper';\nimport BarcodeReader, { type BarcodePosition, type Barcode } from './barcode_reader';\n\nconst ALPHABETH_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%';\nconst ALPHABET = new Uint16Array([...ALPHABETH_STRING].map((char) => char.charCodeAt(0)));\nconst CHARACTER_ENCODINGS = new Uint16Array([\n    0x034, 0x121, 0x061, 0x160, 0x031, 0x130, 0x070, 0x025, 0x124, 0x064, 0x109, 0x049,\n    0x148, 0x019, 0x118, 0x058, 0x00D, 0x10C, 0x04C, 0x01C, 0x103, 0x043, 0x142, 0x013, 0x112, 0x052, 0x007, 0x106,\n    0x046, 0x016, 0x181, 0x0C1, 0x1C0, 0x091, 0x190, 0x0D0, 0x085, 0x184, 0x0C4, 0x094, 0x0A8, 0x0A2, 0x08A, 0x02A,\n]);\nconst ASTERISK = 0x094;\n\nclass Code39Reader extends BarcodeReader {\n    FORMAT = 'code_39';\n\n    protected _findStart(): BarcodePosition | null {\n        const offset = this._nextSet(this._row);\n        let patternStart = offset;\n        const counter = new Uint16Array([0, 0, 0, 0, 0, 0, 0, 0, 0]);\n        let counterPos = 0;\n        let isWhite = false;\n\n        for (let i = offset; i < this._row.length; i++) {\n            // eslint-disable-next-line no-bitwise\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    // find start pattern\n                    if (this._toPattern(counter) === ASTERISK) {\n                        const whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - ((i - patternStart) / 4)));\n                        if (this._matchRange(whiteSpaceMustStart, patternStart, 0)) {\n                            return {\n                                start: patternStart,\n                                end: i,\n                            };\n                        }\n                    }\n\n                    patternStart += counter[0] + counter[1];\n                    for (let j = 0; j < 7; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[7] = 0;\n                    counter[8] = 0;\n                    counterPos--;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n        return null;\n    }\n\n    protected _toPattern(counters: Uint16Array): number {\n        const numCounters = counters.length;\n        let maxNarrowWidth = 0;\n        let numWideBars = numCounters;\n        let wideBarWidth = 0;\n\n        while (numWideBars > 3) {\n            maxNarrowWidth = this._findNextWidth(counters, maxNarrowWidth);\n            numWideBars = 0;\n            let pattern = 0;\n            for (let i = 0; i < numCounters; i++) {\n                if (counters[i] > maxNarrowWidth) {\n                    // eslint-disable-next-line no-bitwise\n                    pattern |= 1 << (numCounters - 1 - i);\n                    numWideBars++;\n                    wideBarWidth += counters[i];\n                }\n            }\n\n            if (numWideBars === 3) {\n                for (let i = 0; i < numCounters && numWideBars > 0; i++) {\n                    if (counters[i] > maxNarrowWidth) {\n                        numWideBars--;\n                        if ((counters[i] * 2) >= wideBarWidth) {\n                            return -1;\n                        }\n                    }\n                }\n                return pattern;\n            }\n        }\n        return -1;\n    }\n\n    protected _findNextWidth(counters: Uint16Array, current: number): number {\n        let minWidth = Number.MAX_VALUE;\n\n        for (let i = 0; i < counters.length; i++) {\n            if (counters[i] < minWidth && counters[i] > current) {\n                minWidth = counters[i];\n            }\n        }\n\n        return minWidth;\n    }\n\n    protected _patternToChar(pattern: number): string | null {\n        for (let i = 0; i < CHARACTER_ENCODINGS.length; i++) {\n            if (CHARACTER_ENCODINGS[i] === pattern) {\n                return String.fromCharCode(ALPHABET[i]);\n            }\n        }\n        return null;\n    }\n\n    protected _verifyTrailingWhitespace(lastStart: number, nextStart: number, counters: Uint16Array): boolean {\n        const patternSize = ArrayHelper.sum(counters);\n\n        const trailingWhitespaceEnd = nextStart - lastStart - patternSize;\n        if ((trailingWhitespaceEnd * 3) >= patternSize) {\n            return true;\n        }\n        return false;\n    }\n\n    public decode(): Barcode | null {\n        let counters = new Uint16Array([0, 0, 0, 0, 0, 0, 0, 0, 0]);\n        const result: Array<string> = [];\n        const start = this._findStart();\n\n        if (!start) {\n            return null;\n        }\n        let nextStart = this._nextSet(this._row, start.end);\n\n        let decodedChar;\n        let lastStart: number;\n        do {\n            counters = this._toCounters(nextStart, counters) as Uint16Array<ArrayBuffer>;\n            const pattern = this._toPattern(counters);\n            if (pattern < 0) {\n                return null;\n            }\n            decodedChar = this._patternToChar(pattern);\n            if (decodedChar === null) {\n                return null;\n            }\n            result.push(decodedChar);\n            lastStart = nextStart;\n            nextStart += ArrayHelper.sum(counters);\n            nextStart = this._nextSet(this._row, nextStart);\n        } while (decodedChar !== '*');\n        result.pop();\n\n        if (!result.length) {\n            return null;\n        }\n\n        if (!this._verifyTrailingWhitespace(lastStart, nextStart, counters)) {\n            return null;\n        }\n\n        return {\n            code: result.join(''),\n            start: start.start,\n            end: nextStart,\n            startInfo: start,\n            decodedCodes: result,\n            format: this.FORMAT,\n        };\n    }\n}\n\nexport default Code39Reader;\n","import Code39Reader from './code_39_reader';\n\nconst patterns = {\n    AEIO: /[AEIO]/g,\n    AZ09: /[A-Z0-9]/,\n};\n\nconst code32set = '0123456789BCDFGHJKLMNPQRSTUVWXYZ';\n\nclass Code32Reader extends Code39Reader {\n    FORMAT = 'code_32_reader';\n\n    protected _decodeCode32(code: string) {\n        if (/[^0-9BCDFGHJKLMNPQRSTUVWXYZ]/.test(code)) {\n            return null;\n        }\n        let res = 0;\n        for (let i = 0; i < code.length; i++) {\n            res = res * 32 + code32set.indexOf(code[i]);\n        }\n        let code32 = `${res}`;\n        if (code32.length < 9) {\n            code32 = ('000000000' + code32).slice(-9);\n        }\n        return 'A' + code32;\n    }\n\n    // TODO (this was todo in original repo, no text was there. sorry.)\n    protected _checkChecksum(code: string): boolean {\n        return !!code;\n    }\n\n    public decode() {\n        const result = super.decode();\n        if (!result) {\n            return null;\n        }\n\n        let code = result.code;\n\n        if (!code) {\n            return null;\n        }\n\n        code = code.replace(patterns.AEIO, '');\n\n        if (!this._checkChecksum(code)) {\n            return null;\n        }\n\n        const code32 = this._decodeCode32(code);\n\n        if (!code32) {\n            return null;\n        }\n\n        result.code = code32;\n        return result;\n    }\n}\n\nexport default Code32Reader;\n","/* eslint-disable class-methods-use-this */\nimport { Barcode } from './barcode_reader';\nimport Code39Reader from './code_39_reader';\n\nconst patterns = {\n    IOQ: /[IOQ]/g,\n    AZ09: /[A-Z0-9]{17}/,\n};\n\nclass Code39VINReader extends Code39Reader {\n    FORMAT = 'code_39_vin';\n\n    // TODO (this was todo in original repo, no text was there. sorry.)\n    protected _checkChecksum(code: string): boolean {\n        return !!code;\n    }\n\n    // Cribbed from:\n    // https://github.com/zxing/zxing/blob/master/core/src/main/java/com/google/zxing/client/result/VINResultParser.java\n    public decode(): Barcode | null {\n        const result = super.decode();\n        if (!result) {\n            return null;\n        }\n\n        let { code } = result;\n\n        if (!code) {\n            return null;\n        }\n\n        code = code.replace(patterns.IOQ, '');\n\n        if (!code.match(patterns.AZ09)) {\n            if (ENV.development) {\n                console.log('Failed AZ09 pattern code:', code);\n            }\n            return null;\n        }\n\n        if (!this._checkChecksum(code)) {\n            return null;\n        }\n\n        result.code = code;\n        return result;\n    }\n}\n\nexport default Code39VINReader;\n","import BarcodeReader, { BarcodePosition, Barcode } from './barcode_reader';\nimport ArrayHelper from '../common/array_helper';\n\nconst ALPHABETH_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*';\nconst ALPHABET = new Uint16Array([...ALPHABETH_STRING].map(char => char.charCodeAt(0)));\nconst CHARACTER_ENCODINGS = new Uint16Array([\n    0x114, 0x148, 0x144, 0x142, 0x128, 0x124, 0x122, 0x150, 0x112, 0x10A,\n    0x1A8, 0x1A4, 0x1A2, 0x194, 0x192, 0x18A, 0x168, 0x164, 0x162, 0x134,\n    0x11A, 0x158, 0x14C, 0x146, 0x12C, 0x116, 0x1B4, 0x1B2, 0x1AC, 0x1A6,\n    0x196, 0x19A, 0x16C, 0x166, 0x136, 0x13A, 0x12E, 0x1D4, 0x1D2, 0x1CA,\n    0x16E, 0x176, 0x1AE, 0x126, 0x1DA, 0x1D6, 0x132, 0x15E,\n]);\nconst ASTERISK = 0x15E;\n\nclass Code93Reader extends BarcodeReader {\n    FORMAT = 'code_93';\n    protected _patternToChar(pattern: number): string | null {\n        for (let i = 0; i < CHARACTER_ENCODINGS.length; i++) {\n            if (CHARACTER_ENCODINGS[i] === pattern) {\n                return String.fromCharCode(ALPHABET[i]);\n            }\n        }\n        return null;\n    };\n\n    protected _toPattern(counters: Uint16Array): number {\n        const numCounters = counters.length;\n        const sum = counters.reduce((prev, next) => prev + next, 0);\n        let pattern = 0;\n\n        for (let i = 0; i < numCounters; i++) {\n            let normalized = Math.round(counters[i] * 9 / sum);\n            if (normalized < 1 || normalized > 4) {\n                return -1;\n            }\n            if ((i & 1) === 0) {\n                for (let j = 0; j < normalized; j++) {\n                    pattern = (pattern << 1) | 1;\n                }\n            } else {\n                pattern <<= normalized;\n            }\n        }\n        return pattern;\n    };\n\n    protected _findStart(): BarcodePosition | null {\n        const offset = this._nextSet(this._row);\n        let patternStart = offset;\n        const counter = new Uint16Array([0, 0, 0, 0, 0, 0]);\n        let counterPos = 0;\n        let isWhite = false;\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    // find start pattern\n                    if (this._toPattern(counter) === ASTERISK) {\n                        const whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - ((i - patternStart) / 4)));\n                        if (this._matchRange(whiteSpaceMustStart, patternStart, 0)) {\n                            return {\n                                start: patternStart,\n                                end: i,\n                            };\n                        }\n                    }\n\n                    patternStart += counter[0] + counter[1];\n                    for (let j = 0; j < 4; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[4] = 0;\n                    counter[5] = 0;\n                    counterPos--;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n        return null;\n    };\n\n    protected _verifyEnd(lastStart: number, nextStart: number): boolean {\n        if (lastStart === nextStart || !this._row[nextStart]) {\n            return false;\n        }\n        return true;\n    };\n\n    protected _decodeExtended(charArray: Array<string>): string[] | null {\n        const length = charArray.length;\n        const result: Array<string> = [];\n        for (let i = 0; i < length; i++) {\n            const char = charArray[i];\n            if (char >= 'a' && char <= 'd') {\n                if (i > (length - 2)) {\n                    return null;\n                }\n                const nextChar = charArray[++i];\n                const nextCharCode = nextChar.charCodeAt(0);\n                let decodedChar;\n                switch (char) {\n                    case 'a':\n                        if (nextChar >= 'A' && nextChar <= 'Z') {\n                            decodedChar = String.fromCharCode(nextCharCode - 64);\n                        } else {\n                            return null;\n                        }\n                        break;\n                    case 'b':\n                        if (nextChar >= 'A' && nextChar <= 'E') {\n                            decodedChar = String.fromCharCode(nextCharCode - 38);\n                        } else if (nextChar >= 'F' && nextChar <= 'J') {\n                            decodedChar = String.fromCharCode(nextCharCode - 11);\n                        } else if (nextChar >= 'K' && nextChar <= 'O') {\n                            decodedChar = String.fromCharCode(nextCharCode + 16);\n                        } else if (nextChar >= 'P' && nextChar <= 'S') {\n                            decodedChar = String.fromCharCode(nextCharCode + 43);\n                        } else if (nextChar >= 'T' && nextChar <= 'Z') {\n                            decodedChar = String.fromCharCode(127);\n                        } else {\n                            return null;\n                        }\n                        break;\n                    case 'c':\n                        if (nextChar >= 'A' && nextChar <= 'O') {\n                            decodedChar = String.fromCharCode(nextCharCode - 32);\n                        } else if (nextChar === 'Z') {\n                            decodedChar = ':';\n                        } else {\n                            return null;\n                        }\n                        break;\n                    case 'd':\n                        if (nextChar >= 'A' && nextChar <= 'Z') {\n                            decodedChar = String.fromCharCode(nextCharCode + 32);\n                        } else {\n                            return null;\n                        }\n                        break;\n                    default:\n                        console.warn('* code_93_reader _decodeExtended hit default case, this may be an error', decodedChar);\n                        return null;\n                }\n                result.push(decodedChar);\n            } else {\n                result.push(char);\n            }\n        }\n        return result;\n    };\n\n    protected _matchCheckChar(charArray: Array<string>, index: number, maxWeight: number): boolean {\n        const arrayToCheck = charArray.slice(0, index);\n        const length = arrayToCheck.length;\n        const weightedSums = arrayToCheck.reduce((sum, char, i) => {\n            const weight = (((i * -1) + (length - 1)) % maxWeight) + 1;\n            const value = ALPHABET.indexOf(char.charCodeAt(0));\n            return sum + (weight * value);\n        }, 0);\n\n        const checkChar = ALPHABET[(weightedSums % 47)];\n        return checkChar === charArray[index].charCodeAt(0);\n    };\n\n    protected _verifyChecksums(charArray: Array<string>): boolean {\n        return this._matchCheckChar(charArray, charArray.length - 2, 20)\n            && this._matchCheckChar(charArray, charArray.length - 1, 15);\n    };\n\n    public decode(row?: Array<number>, start?: BarcodePosition | number | null): Barcode | null {\n        start = this._findStart();\n        if (!start) {\n            return null;\n        }\n\n        let counters = new Uint16Array([0, 0, 0, 0, 0, 0]);\n        let result: Array<string> | null = [];\n        let nextStart = this._nextSet(this._row, start.end);\n        let lastStart;\n        let decodedChar: string | null;\n        do {\n            counters = this._toCounters(nextStart, counters) as Uint16Array<ArrayBuffer>;\n            const pattern = this._toPattern(counters);\n            if (pattern < 0) {\n                return null;\n            }\n            decodedChar = this._patternToChar(pattern);\n            if (decodedChar === null) {\n                return null;\n            }\n            result.push(decodedChar);\n            lastStart = nextStart;\n            nextStart += ArrayHelper.sum(counters);\n            nextStart = this._nextSet(this._row, nextStart);\n        } while (decodedChar !== '*');\n        result.pop();\n\n        if (!result.length) {\n            return null;\n        }\n\n        if (!this._verifyEnd(lastStart, nextStart)) {\n            return null;\n        }\n\n        if (!this._verifyChecksums(result)) {\n            return null;\n        }\n\n        result = result.slice(0, result.length - 2);\n        // yes, this is an assign inside an if.\n        if ((result = this._decodeExtended(result)) === null) {\n            return null;\n        }\n\n        return {\n            code: result.join(''),\n            start: start.start,\n            end: nextStart,\n            startInfo: start,\n            decodedCodes: result,\n            format: this.FORMAT,\n        };\n\n    }\n}\n\nexport default Code93Reader;\n","import BarcodeReader, { BarcodeReaderConfig, BarcodeInfo, BarcodePosition, Barcode } from './barcode_reader';\nimport merge from 'lodash/merge';\n\n// const CODE_L_START = 0;\nconst CODE_G_START = 10;\nexport { CODE_G_START };\nconst START_PATTERN = [1, 1, 1];\nconst MIDDLE_PATTERN = [1, 1, 1, 1, 1];\nexport { MIDDLE_PATTERN };\nconst EXTENSION_START_PATTERN = [1, 1, 2];\nconst CODE_PATTERN = [\n    [3, 2, 1, 1],\n    [2, 2, 2, 1],\n    [2, 1, 2, 2],\n    [1, 4, 1, 1],\n    [1, 1, 3, 2],\n    [1, 2, 3, 1],\n    [1, 1, 1, 4],\n    [1, 3, 1, 2],\n    [1, 2, 1, 3],\n    [3, 1, 1, 2],\n    [1, 1, 2, 3],\n    [1, 2, 2, 2],\n    [2, 2, 1, 2],\n    [1, 1, 4, 1],\n    [2, 3, 1, 1],\n    [1, 3, 2, 1],\n    [4, 1, 1, 1],\n    [2, 1, 3, 1],\n    [3, 1, 2, 1],\n    [2, 1, 1, 3],\n];\nconst CODE_FREQUENCY = [0, 11, 13, 14, 19, 25, 28, 21, 22, 26];\n// const SINGLE_CODE_ERROR = 0.70;\nconst AVG_CODE_ERROR = 0.48;\n\nclass EANReader extends BarcodeReader {\n    FORMAT = 'ean_13';\n    SINGLE_CODE_ERROR = 0.70;\n    STOP_PATTERN = [1, 1, 1]; // TODO: does this need to be in the class?\n\n    constructor(config?: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        super(merge({ supplements: [] }, config), supplements);\n    }\n\n    protected _findPattern(pattern: ReadonlyArray<number>, offset: number, isWhite: boolean, tryHarder: boolean): BarcodePosition | null {\n        const counter = new Array<number>(pattern.length).fill(0);\n        const bestMatch: BarcodePosition = {\n            error: Number.MAX_VALUE,\n            start: 0,\n            end: 0\n        };\n        const epsilon = AVG_CODE_ERROR;\n        // console.warn('* findPattern', pattern, offset, isWhite, tryHarder, epsilon);\n        let counterPos = 0;\n        if (!offset) {\n            offset = this._nextSet(this._row);\n        }\n        let found = false;\n        for (let i = offset; i < this._row.length; i++) {\n            // console.warn(`* loop i=${offset} len=${this._row.length} isWhite=${isWhite} counterPos=${counterPos}`);\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counter[counterPos] += 1;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    const error = this._matchPattern(counter, pattern);\n                    // console.warn('* matchPattern', error, counter, pattern);\n                    if (error < epsilon && bestMatch.error && error < bestMatch.error) {\n                        found = true;\n                        bestMatch.error = error;\n                        bestMatch.start = i - counter.reduce((sum, value) => sum + value, 0);\n                        bestMatch.end = i;\n                        // console.warn('* return bestMatch', JSON.stringify(bestMatch));\n                        return bestMatch;\n                    }\n                    if (tryHarder) {\n                        for (let j = 0; j < counter.length - 2; j++) {\n                            counter[j] = counter[j + 2];\n                        }\n                        counter[counter.length - 2] = 0;\n                        counter[counter.length - 1] = 0;\n                        counterPos--;\n                    }\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n        if (found) {\n            // console.warn('* return bestMatch', JSON.stringify(bestMatch));\n        } else {\n            // console.warn('* return null');\n        }\n        return found ? bestMatch : null;\n    }\n\n    // TODO: findPattern and decodeCode appear to share quite similar code, can it be reduced?\n    protected _decodeCode(start: number, coderange?: number): BarcodeInfo | null {\n        // console.warn('* decodeCode', start, coderange);\n        const counter = [0, 0, 0, 0];\n        const offset = start;\n        const bestMatch: BarcodeInfo = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: start,\n            end: start\n        };\n        const epsilon = AVG_CODE_ERROR;\n        let isWhite = !this._row[offset];\n        let counterPos = 0;\n\n        if (!coderange) {\n            // console.warn('* decodeCode before length');\n            coderange = CODE_PATTERN.length;\n            // console.warn('* decodeCode after length');\n        }\n\n        let found = false;\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    for (let code = 0; code < coderange; code++) {\n                        const error = this._matchPattern(counter, CODE_PATTERN[code]);\n                        bestMatch.end = i;\n                        if (error < bestMatch.error!) {\n                            bestMatch.code = code;\n                            bestMatch.error = error;\n                        }\n                    }\n                    if (bestMatch.error! > epsilon) {\n                        // console.warn('* return null');\n                        return null;\n                    }\n                    // console.warn('* return bestMatch', JSON.stringify(bestMatch));\n                    return bestMatch;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n        return found ? bestMatch : null;\n    }\n\n    protected _findStart(): BarcodePosition | null {\n        // console.warn('* findStart');\n        let offset = this._nextSet(this._row);\n        let startInfo: BarcodePosition | null = null;\n\n        while (!startInfo) {\n            startInfo = this._findPattern(START_PATTERN, offset, false, true);\n            // console.warn('* startInfo=', JSON.stringify(startInfo));\n            if (!startInfo) {\n                return null;\n            }\n\n            const leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);\n\n            if (leadingWhitespaceStart >= 0) {\n                if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                    // console.warn('* returning startInfo');\n                    return startInfo;\n                }\n            }\n\n            offset = startInfo.end;\n            startInfo = null;\n        }\n        // console.warn('* returning null');\n        return null;\n    }\n\n    private _calculateFirstDigit(codeFrequency: number): number | null {\n        // console.warn('* calculateFirstDigit', codeFrequency);\n        for (let i = 0; i < CODE_FREQUENCY.length; i++) {\n            if (codeFrequency === CODE_FREQUENCY[i]) {\n                // console.warn('* returning', i);\n                return i;\n            }\n        }\n        // console.warn('* return null');\n        return null;\n    }\n\n    protected _decodePayload(inCode: BarcodePosition, result: Array<number>, decodedCodes: Array<BarcodePosition>): BarcodeInfo | null {\n        // console.warn('* decodePayload', inCode, result, decodedCodes);\n        let outCode: BarcodeInfo | BarcodePosition | null = { ...inCode };\n        let codeFrequency = 0x0;\n\n        for (let i = 0; i < 6; i++) {\n            outCode = this._decodeCode(outCode.end);\n            // console.warn('* decodeCode=', outCode);\n            if (!outCode) {\n                // console.warn('* return null');\n                return null;\n            }\n            if ((outCode as BarcodeInfo).code >= CODE_G_START) {\n                (outCode as BarcodeInfo).code -= CODE_G_START;\n                codeFrequency |= 1 << (5 - i);\n            } else {\n                codeFrequency |= 0 << (5 - i);\n            }\n            result.push((outCode as BarcodeInfo).code);\n            decodedCodes.push(outCode);\n        }\n\n        const firstDigit = this._calculateFirstDigit(codeFrequency);\n        // console.warn('* firstDigit=', firstDigit);\n        if (firstDigit === null) {\n            // console.warn('* return null');\n            return null;\n        }\n\n        result.unshift(firstDigit);\n\n        let middlePattern = this._findPattern(MIDDLE_PATTERN, outCode.end, true, false);\n        // console.warn('* findPattern=', JSON.stringify(middlePattern));\n\n        if (middlePattern === null || !middlePattern.end) {\n            // console.warn('* return null');\n            return null;\n        }\n\n        decodedCodes.push(middlePattern);\n\n        for (let i = 0; i < 6; i++) {\n            middlePattern = this._decodeCode(middlePattern!.end, CODE_G_START);\n            // console.warn('* decodeCode=', JSON.stringify(middlePattern));\n\n            if (!middlePattern) {\n                // console.warn('* return null');\n                return null;\n            }\n\n            decodedCodes.push(middlePattern);\n            result.push((middlePattern as BarcodeInfo).code);\n        }\n\n        // console.warn('* end code=', JSON.stringify(middlePattern));\n        // console.warn('* end result=', JSON.stringify(result));\n        // console.warn('* end decodedCodes=', decodedCodes);\n        return middlePattern as BarcodeInfo;\n    }\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodePosition): BarcodePosition | null {\n        // console.warn('* verifyTrailingWhitespace', JSON.stringify(endInfo));\n        const trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);\n\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                // console.warn('* returning', JSON.stringify(endInfo));\n                return endInfo;\n            }\n        }\n        // console.warn('* return null');\n        return null;\n    }\n\n    protected _findEnd(offset: number, isWhite: boolean): BarcodePosition | null {\n        // console.warn('* findEnd', offset, isWhite);\n        const endInfo = this._findPattern(this.STOP_PATTERN, offset, isWhite, false);\n\n        return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;\n    }\n\n    protected _checksum(result: Array<number>): boolean {\n        // console.warn('* _checksum', result);\n        let sum = 0;\n\n        for (let i = result.length - 2; i >= 0; i -= 2) {\n            sum += result[i];\n        }\n\n        sum *= 3;\n\n        for (let i = result.length - 1; i >= 0; i -= 2) {\n            sum += result[i];\n        }\n\n        // console.warn('* end checksum', sum % 10 === 0);\n        return sum % 10 === 0;\n    }\n\n    private _decodeExtensions(offset: number): Barcode | null {\n        const start = this._nextSet(this._row, offset);\n        const startInfo = this._findPattern(EXTENSION_START_PATTERN, start, false, false);\n\n        if (startInfo === null) {\n            return null;\n        }\n\n        // console.warn('* decodeExtensions', this.supplements);\n        // console.warn('* there are ', this.supplements.length, ' supplements');\n        for (let i = 0; i < this.supplements.length; i++) {\n            // console.warn('* extensions loop', i, this.supplements[i], this.supplements[i]._decode);\n            try {\n                let result = this.supplements[i].decode(this._row, startInfo.end);\n                // console.warn('* decode result=', result);\n                if (result !== null) {\n                    return {\n                        code: result.code,\n                        start,\n                        startInfo,\n                        end: result.end,\n                        decodedCodes: result.decodedCodes,\n                        format: this.supplements[i].FORMAT,\n                    };\n                }\n            } catch (err) {\n                console.error('* decodeExtensions error in ', this.supplements[i], ': ', err);\n            }\n        }\n\n        // console.warn('* end decodeExtensions');\n        return null;\n    }\n\n    public decode(row?: Array<number>, start?: BarcodePosition | number): Barcode | null {\n        // console.warn('* decode', row);\n        // console.warn('* decode', start);\n        const result = new Array<number>();\n        const decodedCodes = new Array<BarcodeInfo | BarcodePosition>();\n        let resultInfo: Barcode | {} = {};\n        let startInfo = this._findStart();\n\n        if (!startInfo) {\n            return null;\n        }\n\n        let code: BarcodePosition | BarcodeInfo | null = {\n            start: startInfo.start,\n            end: startInfo.end\n        };\n        decodedCodes.push(code);\n\n        code = this._decodePayload(code, result, decodedCodes);\n\n        if (!code) {\n            return null;\n        }\n\n        code = this._findEnd(code.end, false);\n\n        if (!code) {\n            return null;\n        }\n\n        decodedCodes.push(code);\n\n        // Checksum\n        if (!this._checksum(result)) {\n            return null;\n        }\n\n        // console.warn('* this.supplements=', this.supplements);\n        if (this.supplements.length > 0) {\n            const supplement = this._decodeExtensions(code.end);\n            // console.warn('* decodeExtensions returns', supplement);\n            if (!supplement) {\n                return null;\n            }\n\n            if (!supplement.decodedCodes) {\n                return null;\n            }\n\n            const lastCode = supplement.decodedCodes[supplement.decodedCodes.length - 1] as BarcodeInfo;\n            const endInfo = {\n                start: lastCode.start + (((lastCode.end - lastCode.start) / 2) | 0),\n                end: lastCode.end\n            };\n\n            if (!this._verifyTrailingWhitespace(endInfo)) {\n                return null;\n            }\n\n            resultInfo = {\n                supplement,\n                code: result.join('') + supplement.code\n            };\n        }\n\n        return {\n            code: result.join(''),\n            start: startInfo.start,\n            end: code.end,\n            startInfo,\n            decodedCodes,\n            ...resultInfo,\n            format: this.FORMAT,\n        };\n    }\n}\n\nexport default EANReader;\n","import EANReader, { CODE_G_START } from './ean_reader';\nimport { BarcodePosition, Barcode, BarcodeInfo } from './barcode_reader';\n\n\nclass EAN2Reader extends EANReader {\n    FORMAT = 'ean_2';\n    public decode(row?: Array<number>, start?: number): Barcode | null {\n        if (row) {\n            this._row = row;\n        }\n\n        let codeFrequency = 0;\n        let offset = start;\n        const end = this._row.length;\n        const result = [];\n        const decodedCodes = [];\n        let code: BarcodeInfo | null = null;\n\n        if (offset === undefined){\n            return null;\n        }\n\n        for (let i = 0; i < 2 && offset < end; i++) {\n            code = this._decodeCode(offset);\n            if (!code) {\n                return null;\n            }\n            decodedCodes.push(code);\n            result.push(code.code % 10);\n            if (code.code >= CODE_G_START) {\n                codeFrequency |= 1 << (1 - i);\n            }\n            if (i !== 1) {\n                offset = this._nextSet(this._row, code.end);\n                offset = this._nextUnset(this._row, offset);\n            }\n        }\n\n        if (result.length !== 2 || (parseInt(result.join('')) % 4) !== codeFrequency) {\n            return null;\n        }\n\n        const startInfo = this._findStart();\n\n        return {\n            code: result.join(''),\n            decodedCodes,\n            end: (code as BarcodeInfo).end,\n            format: this.FORMAT,\n            startInfo: startInfo as BarcodePosition,\n            start: (startInfo as BarcodePosition).start,\n        };\n    }\n};\n\nexport default EAN2Reader;\n","import EANReader, { CODE_G_START } from './ean_reader';\nimport { Barcode, BarcodePosition, BarcodeInfo } from './barcode_reader';\n\nconst CHECK_DIGIT_ENCODINGS = [24, 20, 18, 17, 12, 6, 3, 10, 9, 5];\n\nfunction determineCheckDigit(codeFrequency: number) {\n    for (let i = 0; i < 10; i++) {\n        if (codeFrequency === CHECK_DIGIT_ENCODINGS[i]) {\n            return i;\n        }\n    }\n    return null;\n}\n\nfunction extensionChecksum(result: Array<number>) {\n    const length = result.length;\n    let sum = 0;\n\n    for (let i = length - 2; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    sum *= 3;\n    for (let i = length - 1; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    sum *= 3;\n    return sum % 10;\n}\n\nclass EAN5Reader extends EANReader {\n    FORMAT = 'ean_5';\n    public decode(row?: Array<number>, start?: number): Barcode | null {\n        if (start === undefined) {\n            return null;\n        }\n\n        if (row) {\n            this._row = row;\n        }\n\n        let codeFrequency = 0;\n        let offset = start;\n        const end = this._row.length;\n        let code: BarcodeInfo | null = null;\n        const result = [];\n        const decodedCodes = [];\n\n        for (let i = 0; i < 5 && offset < end; i++) {\n            code = this._decodeCode(offset);\n            if (!code) {\n                return null;\n            }\n            decodedCodes.push(code);\n            result.push(code.code % 10);\n            if (code.code >= CODE_G_START) {\n                codeFrequency |= 1 << (4 - i);\n            }\n            if (i !== 4) {\n                offset = this._nextSet(this._row, code.end);\n                offset = this._nextUnset(this._row, offset);\n            }\n        }\n\n        if (result.length !== 5) {\n            return null;\n        }\n\n        if (extensionChecksum(result) !== determineCheckDigit(codeFrequency)) {\n            return null;\n        }\n\n        const startInfo = this._findStart();\n\n        return {\n            code: result.join(''),\n            decodedCodes,\n            end: (code as BarcodeInfo).end,\n            format: this.FORMAT,\n            startInfo: startInfo as BarcodePosition,\n            start: (startInfo as BarcodePosition).start,\n        };\n    }\n};\n\nexport default EAN5Reader;\n","import EANReader, { CODE_G_START, MIDDLE_PATTERN } from './ean_reader';\nimport { BarcodePosition, BarcodeInfo } from './barcode_reader';\n\nclass EAN8Reader extends EANReader {\n    FORMAT = 'ean_8';\n    protected _decodePayload(inCode: BarcodePosition, result: Array<number>, decodedCodes: Array<BarcodePosition>): BarcodeInfo | null {\n        let code: BarcodeInfo | BarcodePosition | null = inCode;\n\n        for (let i = 0; i < 4; i++) {\n            code = this._decodeCode(code.end, CODE_G_START);\n            if (!code) {\n                return null;\n            }\n            result.push((code as BarcodeInfo).code);\n            decodedCodes.push(code);\n        }\n\n        code = this._findPattern(MIDDLE_PATTERN, code.end, true, false);\n        if (code === null) {\n            return null;\n        }\n        decodedCodes.push(code);\n\n        for (let i = 0; i < 4; i++) {\n            code = this._decodeCode(code.end, CODE_G_START);\n            if (!code) {\n                return null;\n            }\n            decodedCodes.push(code);\n            result.push((code as BarcodeInfo).code);\n        }\n\n        return code as BarcodeInfo;\n    };\n}\n\nexport default EAN8Reader;\n","// TODO: i2of5_reader and 2of5_reader share very similar code, make use of that\n\nimport BarcodeReader, { BarcodeReaderConfig, BarcodeInfo, BarcodePosition, Barcode } from './barcode_reader';\nimport merge from 'lodash/merge';\n\nconst N = 1;\nconst W = 3;\n\nclass I2of5Reader extends BarcodeReader {\n    private barSpaceRatio = [1, 1];\n    SINGLE_CODE_ERROR = 0.78;\n    AVG_CODE_ERROR = 0.38;\n\n    START_PATTERN = [N, N, N, N];\n    STOP_PATTERN = [N, N, W];\n    CODE_PATTERN = [\n        [N, N, W, W, N],\n        [W, N, N, N, W],\n        [N, W, N, N, W],\n        [W, W, N, N, N],\n        [N, N, W, N, W],\n        [W, N, W, N, N],\n        [N, W, W, N, N],\n        [N, N, N, W, W],\n        [W, N, N, W, N],\n        [N, W, N, W, N],\n    ];\n    MAX_CORRECTION_FACTOR = 5;\n    FORMAT = 'i2of5';\n\n    constructor(opts: BarcodeReaderConfig) {\n        super(merge({ normalizeBarSpaceWidth: false }, opts));\n        if (opts.normalizeBarSpaceWidth) {\n            this.SINGLE_CODE_ERROR = 0.38;\n            this.AVG_CODE_ERROR = 0.09;\n        }\n        this.config = opts;\n        return this;\n    }\n\n    protected _matchPattern(counter: Array<number>, code: ReadonlyArray<number>): number {\n        if (this.config.normalizeBarSpaceWidth) {\n            const counterSum = [0, 0];\n            const codeSum = [0, 0];\n            const correction = [0, 0];\n            const correctionRatio = this.MAX_CORRECTION_FACTOR;\n            const correctionRatioInverse = 1 / correctionRatio;\n\n            for (let i = 0; i < counter.length; i++) {\n                counterSum[i % 2] += counter[i];\n                codeSum[i % 2] += code[i];\n            }\n            correction[0] = codeSum[0] / counterSum[0];\n            correction[1] = codeSum[1] / counterSum[1];\n\n            correction[0] = Math.max(Math.min(correction[0], correctionRatio), correctionRatioInverse);\n            correction[1] = Math.max(Math.min(correction[1], correctionRatio), correctionRatioInverse);\n            this.barSpaceRatio = correction;\n            for (let i = 0; i < counter.length; i++) {\n                counter[i] *= this.barSpaceRatio[i % 2];\n            }\n        }\n        return super._matchPattern(counter, code);\n    };\n\n    protected _findPattern(pattern: ReadonlyArray<number>, offset?: number, isWhite: boolean = false, tryHarder: boolean = false): BarcodePosition | null {\n        const counter = new Array<number>(pattern.length).fill(0);\n        let counterPos = 0;\n        const bestMatch: BarcodePosition = {\n            error: Number.MAX_VALUE,\n            start: 0,\n            end: 0,\n        };\n\n        const epsilon = this.AVG_CODE_ERROR;\n\n        isWhite = isWhite || false;\n        tryHarder = tryHarder || false;\n\n        if (!offset) {\n            offset = this._nextSet(this._row);\n        }\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ (isWhite ? 1 : 0)) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    const sum = counter.reduce((prev, next) => prev + next, 0);\n                    const error = this._matchPattern(counter, pattern);\n                    if (error < epsilon) {\n                        bestMatch.error = error;\n                        bestMatch.start = i - sum;\n                        bestMatch.end = i;\n                        return bestMatch;\n                    }\n                    if (tryHarder) {\n                        for (let j = 0; j < counter.length - 2; j++) {\n                            counter[j] = counter[j + 2];\n                        }\n                        counter[counter.length - 2] = 0;\n                        counter[counter.length - 1] = 0;\n                        counterPos--;\n                    } else {\n                        return null;\n                    }\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n        return null;\n    };\n\n    protected _findStart(): BarcodePosition | null {\n        let leadingWhitespaceStart = 0;\n        let offset = this._nextSet(this._row);\n        let startInfo: BarcodePosition | null = null;\n        let narrowBarWidth = 1;\n\n        while (!startInfo) {\n            startInfo = this._findPattern(this.START_PATTERN, offset, false, true);\n            if (!startInfo) {\n                return null;\n            }\n            narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / 4);\n            leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10;\n            if (leadingWhitespaceStart >= 0) {\n                if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                    return startInfo;\n                }\n            }\n            offset = startInfo.end;\n            startInfo = null;\n        }\n        return null;\n    };\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodePosition): BarcodePosition | null {\n        const trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n        return null;\n    };\n\n    protected _findEnd(): BarcodePosition | null {\n        this._row.reverse();\n        const endInfo = this._findPattern(this.STOP_PATTERN);\n        this._row.reverse();\n\n        if (endInfo === null) {\n            return null;\n        }\n\n        // reverse numbers\n        const tmp = endInfo.start;\n        endInfo.start = this._row.length - endInfo.end;\n        endInfo.end = this._row.length - tmp;\n\n        return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;\n    };\n\n    protected _decodePair(counterPair: Array<Array<number>>): Array<BarcodeInfo> | null {\n        const codes: Array<BarcodeInfo> = [];\n\n        for (let i = 0; i < counterPair.length; i++) {\n            const code = this._decodeCode(counterPair[i]);\n            if (!code) {\n                return null;\n            }\n            codes.push(code);\n        }\n        return codes;\n    };\n\n    protected _decodeCode(counter: Array<number>): BarcodeInfo | null {\n        const epsilon = this.AVG_CODE_ERROR;\n\n        const bestMatch: BarcodeInfo = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0,\n        };\n\n        for (let code = 0; code < this.CODE_PATTERN.length; code++) {\n            const error = this._matchPattern(counter, this.CODE_PATTERN[code]);\n            if (error < bestMatch.error!) {\n                bestMatch.code = code;\n                bestMatch.error = error;\n            }\n        }\n        if (bestMatch.error! < epsilon) {\n            return bestMatch;\n        }\n        return null;\n    };\n\n    protected _decodePayload(counters: ReadonlyArray<number>, result: Array<string>, decodedCodes: Array<BarcodeInfo | BarcodePosition>): Array<BarcodeInfo> | null {\n        let pos = 0;\n        const counterLength = counters.length;\n        const counterPair = [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0]];\n        let codes: BarcodeInfo[] | null = null;\n\n        while (pos < counterLength) {\n            for (let i = 0; i < 5; i++) {\n                counterPair[0][i] = counters[pos] * this.barSpaceRatio[0];\n                counterPair[1][i] = counters[pos + 1] * this.barSpaceRatio[1];\n                pos += 2;\n            }\n            codes = this._decodePair(counterPair);\n            if (!codes) {\n                return null;\n            }\n            for (let i = 0; i < codes.length; i++) {\n                result.push(codes[i].code + '');\n                decodedCodes.push(codes[i]);\n            }\n        }\n        return codes;\n    };\n\n    protected _verifyCounterLength(counters: Array<number>) {\n        return (counters.length % 10 === 0);\n    };\n\n    public decode(row?: Array<number>, start?: BarcodePosition | number): Barcode | null {\n        var result = new Array<string>();\n        var decodedCodes = new Array<BarcodePosition>();\n\n        const startInfo = this._findStart();\n        if (!startInfo) {\n            return null;\n        }\n        decodedCodes.push(startInfo);\n\n        const endInfo = this._findEnd();\n        if (!endInfo) {\n            return null;\n        }\n\n        const counters = this._fillCounters(startInfo.end, endInfo.start, false);\n        if (!this._verifyCounterLength(counters)) {\n            return null;\n        }\n        const code = this._decodePayload(counters, result, decodedCodes);\n        if (!code) {\n            return null;\n        }\n        if (result.length % 2 !== 0 ||\n                result.length < 6) {\n            return null;\n        }\n\n        decodedCodes.push(endInfo);\n        return {\n            code: result.join(''),\n            start: startInfo.start,\n            end: endInfo.end,\n            startInfo: startInfo,\n            decodedCodes: decodedCodes,\n            format: this.FORMAT,\n        };\n    };\n}\n\nexport default I2of5Reader;\n","import EANReader, { CODE_G_START } from './ean_reader';\nimport { BarcodePosition, BarcodeInfo } from './barcode_reader';\n\nclass UPCEReader extends EANReader {\n    CODE_FREQUENCY = [\n        [ 56, 52, 50, 49, 44, 38, 35, 42, 41, 37 ],\n        [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]];\n    STOP_PATTERN = [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7];\n    FORMAT = 'upc_e';\n    protected _decodePayload(inCode: BarcodePosition, result: Array<number>, decodedCodes: Array<BarcodePosition>): BarcodeInfo | null {\n        let outCode: BarcodeInfo | BarcodePosition | null = { ...inCode };\n        let codeFrequency = 0x0;\n\n        for (let i = 0; i < 6; i++) {\n            outCode = this._decodeCode(outCode.end);\n            if (!outCode) {\n                return null;\n            }\n            if ((outCode as BarcodeInfo).code >= CODE_G_START) {\n                (outCode as BarcodeInfo).code = (outCode as BarcodeInfo).code - CODE_G_START;\n                codeFrequency |= (1 << (5 - i));\n            }\n            result.push((outCode as BarcodeInfo).code);\n            decodedCodes.push(outCode);\n        }\n        if (!this._determineParity(codeFrequency, result)) {\n            return null;\n        }\n        return outCode as BarcodeInfo;\n    };\n\n    protected _determineParity(codeFrequency: number, result: Array<number>) {\n        for (let nrSystem = 0; nrSystem < this.CODE_FREQUENCY.length; nrSystem++){\n            for (let i = 0; i < this.CODE_FREQUENCY[nrSystem].length; i++) {\n                if (codeFrequency === this.CODE_FREQUENCY[nrSystem][i]) {\n                    result.unshift(nrSystem);\n                    result.push(i);\n                    return true;\n                }\n            }\n        }\n        return false;\n    };\n\n    protected _convertToUPCA(result: Array<number>) {\n        let upca = [result[0]];\n        const lastDigit = result[result.length - 2];\n\n        if (lastDigit <= 2) {\n            upca = upca.concat(result.slice(1, 3))\n                .concat([lastDigit, 0, 0, 0, 0])\n                .concat(result.slice(3, 6));\n        } else if (lastDigit === 3) {\n            upca = upca.concat(result.slice(1, 4))\n                .concat([0, 0, 0, 0, 0])\n                .concat(result.slice(4, 6));\n        } else if (lastDigit === 4) {\n            upca = upca.concat(result.slice(1, 5))\n                .concat([0, 0, 0, 0, 0, result[5]]);\n        } else {\n            upca = upca.concat(result.slice(1, 6))\n                .concat([0, 0, 0, 0, lastDigit]);\n        }\n\n        upca.push(result[result.length - 1]);\n        return upca;\n    };\n\n    protected _checksum(result: Array<number>): boolean {\n        return super._checksum(this._convertToUPCA(result));\n    }\n\n    protected _findEnd(offset: number, isWhite: boolean): BarcodePosition | null {\n        return super._findEnd(offset, true);\n    }\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodePosition): BarcodePosition | null {\n        const trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n        return null;\n    };\n}\n\nexport default UPCEReader;\n","import EANReader from './ean_reader';\nimport { BarcodePosition, Barcode } from './barcode_reader';\n\nclass UPCReader extends EANReader {\n    FORMAT = 'upc_a';\n    decode(row?: Array<number>, start?: BarcodePosition | number): Barcode | null {\n        const result = EANReader.prototype.decode.call(this);\n\n        if (result && result.code && result.code.length === 13 && result.code.charAt(0) === '0') {\n            result.code = result.code.substring(1);\n            return result;\n        }\n        return null;\n    }\n}\n\nexport default UPCReader;\n","const Bresenham = {};\n\nconst Slope = {\n    DIR: {\n        UP: 1,\n        DOWN: -1,\n    },\n};\n/**\n * Scans a line of the given image from point p1 to p2 and returns a result object containing\n * gray-scale values (0-255) of the underlying pixels in addition to the min\n * and max values.\n * @param {Object} imageWrapper\n * @param {Object} p1 The start point {x,y}\n * @param {Object} p2 The end point {x,y}\n * @returns {line, min, max}\n */\nBresenham.getBarcodeLine = function (imageWrapper, p1, p2) {\n    /* eslint-disable no-bitwise */\n    let x0 = p1.x | 0;\n    let y0 = p1.y | 0;\n    let x1 = p2.x | 0;\n    let y1 = p2.y | 0;\n    /* eslint-disable no-bitwise */\n    const steep = Math.abs(y1 - y0) > Math.abs(x1 - x0);\n    let error;\n    let y;\n    let tmp;\n    let x;\n    const line = [];\n    const imageData = imageWrapper.data;\n    const width = imageWrapper.size.x;\n    let val;\n    let min = 255;\n    let max = 0;\n\n    function read(a, b) {\n        val = imageData[b * width + a];\n        min = val < min ? val : min;\n        max = val > max ? val : max;\n        line.push(val);\n    }\n\n    if (steep) {\n        tmp = x0;\n        x0 = y0;\n        y0 = tmp;\n\n        tmp = x1;\n        x1 = y1;\n        y1 = tmp;\n    }\n    if (x0 > x1) {\n        tmp = x0;\n        x0 = x1;\n        x1 = tmp;\n\n        tmp = y0;\n        y0 = y1;\n        y1 = tmp;\n    }\n    const deltaX = x1 - x0;\n    const deltaY = Math.abs(y1 - y0);\n    error = (deltaX / 2) | 0;\n    y = y0;\n    const yStep = y0 < y1 ? 1 : -1;\n    for (x = x0; x < x1; x++) {\n        if (steep) {\n            read(y, x);\n        } else {\n            read(x, y);\n        }\n        error -= deltaY;\n        if (error < 0) {\n            y += yStep;\n            error += deltaX;\n        }\n    }\n\n    return {\n        line,\n        min,\n        max,\n    };\n};\n\n/**\n * Converts the result from getBarcodeLine into a binary representation\n * also considering the frequency and slope of the signal for more robust results\n * @param {Object} result {line, min, max}\n */\nBresenham.toBinaryLine = function (result) {\n    const { min } = result;\n    const { max } = result;\n    const { line } = result;\n    let slope;\n    let slope2;\n    const center = min + (max - min) / 2;\n    const extrema = [];\n    let currentDir;\n    let dir;\n    let threshold = (max - min) / 12;\n    const rThreshold = -threshold;\n    let i;\n    let j;\n\n    // 1. find extrema\n    currentDir = line[0] > center ? Slope.DIR.UP : Slope.DIR.DOWN;\n    extrema.push({\n        pos: 0,\n        val: line[0],\n    });\n    for (i = 0; i < line.length - 2; i++) {\n        slope = (line[i + 1] - line[i]);\n        slope2 = (line[i + 2] - line[i + 1]);\n        if ((slope + slope2) < rThreshold && line[i + 1] < (center * 1.5)) {\n            dir = Slope.DIR.DOWN;\n        } else if ((slope + slope2) > threshold && line[i + 1] > (center * 0.5)) {\n            dir = Slope.DIR.UP;\n        } else {\n            dir = currentDir;\n        }\n\n        if (currentDir !== dir) {\n            extrema.push({\n                pos: i,\n                val: line[i],\n            });\n            currentDir = dir;\n        }\n    }\n    extrema.push({\n        pos: line.length,\n        val: line[line.length - 1],\n    });\n\n    for (j = extrema[0].pos; j < extrema[1].pos; j++) {\n        line[j] = line[j] > center ? 0 : 1;\n    }\n\n    // iterate over extrema and convert to binary based on avg between minmax\n    for (i = 1; i < extrema.length - 1; i++) {\n        if (extrema[i + 1].val > extrema[i].val) {\n            threshold = (extrema[i].val + ((extrema[i + 1].val - extrema[i].val) / 3) * 2) | 0;\n        } else {\n            threshold = (extrema[i + 1].val + ((extrema[i].val - extrema[i + 1].val) / 3)) | 0;\n        }\n\n        for (j = extrema[i].pos; j < extrema[i + 1].pos; j++) {\n            line[j] = line[j] > threshold ? 0 : 1;\n        }\n    }\n\n    return {\n        line,\n        threshold,\n    };\n};\n\n/**\n * Used for development only\n */\nBresenham.debug = {\n    printFrequency(line, canvas) {\n        let i;\n        const ctx = canvas.getContext('2d');\n        // eslint-disable-next-line no-param-reassign\n        canvas.width = line.length;\n        // eslint-disable-next-line no-param-reassign\n        canvas.height = 256;\n\n        ctx.beginPath();\n        ctx.strokeStyle = 'blue';\n        for (i = 0; i < line.length; i++) {\n            ctx.moveTo(i, 255);\n            ctx.lineTo(i, 255 - line[i]);\n        }\n        ctx.stroke();\n        ctx.closePath();\n    },\n\n    printPattern(line, canvas) {\n        const ctx = canvas.getContext('2d'); let\n            i;\n\n        // eslint-disable-next-line no-param-reassign\n        canvas.width = line.length;\n        ctx.fillColor = 'black';\n        for (i = 0; i < line.length; i++) {\n            if (line[i] === 1) {\n                ctx.fillRect(i, 0, 1, 100);\n            }\n        }\n    },\n};\n\nexport default Bresenham;\n","/* eslint-disable import/no-cycle */\n\nimport ImageDebug from '../common/image_debug';\nimport TwoOfFiveReader from '../reader/2of5_reader';\nimport CodabarReader from '../reader/codabar_reader';\nimport Code128Reader from '../reader/code_128_reader';\nimport Code32Reader from '../reader/code_32_reader';\nimport Code39Reader from '../reader/code_39_reader';\nimport Code39VINReader from '../reader/code_39_vin_reader';\nimport Code93Reader from '../reader/code_93_reader';\nimport EAN2Reader from '../reader/ean_2_reader';\nimport EAN5Reader from '../reader/ean_5_reader';\nimport EAN8Reader from '../reader/ean_8_reader';\nimport EANReader from '../reader/ean_reader';\nimport I2of5Reader from '../reader/i2of5_reader';\nimport UPCEReader from '../reader/upc_e_reader';\nimport UPCReader from '../reader/upc_reader';\nimport Bresenham from './bresenham';\n\nconst READERS = {\n    code_128_reader: Code128Reader,\n    ean_reader: EANReader,\n    ean_5_reader: EAN5Reader,\n    ean_2_reader: EAN2Reader,\n    ean_8_reader: EAN8Reader,\n    code_39_reader: Code39Reader,\n    code_39_vin_reader: Code39VINReader,\n    codabar_reader: CodabarReader,\n    upc_reader: UPCReader,\n    upc_e_reader: UPCEReader,\n    i2of5_reader: I2of5Reader,\n    '2of5_reader': TwoOfFiveReader,\n    code_93_reader: Code93Reader,\n    code_32_reader: Code32Reader,\n};\n\nexport default {\n    registerReader: (name, reader) => {\n        READERS[name] = reader;\n    },\n    create(config, inputImageWrapper) {\n        const _canvas = {\n            ctx: {\n                frequency: null,\n                pattern: null,\n                overlay: null,\n            },\n            dom: {\n                frequency: null,\n                pattern: null,\n                overlay: null,\n            },\n        };\n        const _barcodeReaders = [];\n\n        initCanvas();\n        initReaders();\n        initConfig();\n\n        function initCanvas() {\n            if (ENV.development && typeof document !== 'undefined') {\n                const $debug = document.querySelector('#debug.detection');\n                _canvas.dom.frequency = document.querySelector('canvas.frequency');\n                if (!_canvas.dom.frequency) {\n                    _canvas.dom.frequency = document.createElement('canvas');\n                    _canvas.dom.frequency.className = 'frequency';\n                    if ($debug) {\n                        $debug.appendChild(_canvas.dom.frequency);\n                    }\n                }\n                if (ENV.development && config.debug?.printReaderInfo) {\n                    console.warn('* barcode decoder initCanvas getcontext 2d');\n                }\n                _canvas.ctx.frequency = _canvas.dom.frequency.getContext('2d');\n\n                _canvas.dom.pattern = document.querySelector('canvas.patternBuffer');\n                if (!_canvas.dom.pattern) {\n                    _canvas.dom.pattern = document.createElement('canvas');\n                    _canvas.dom.pattern.className = 'patternBuffer';\n                    if ($debug) {\n                        $debug.appendChild(_canvas.dom.pattern);\n                    }\n                }\n                _canvas.ctx.pattern = _canvas.dom.pattern.getContext('2d');\n\n                _canvas.dom.overlay = document.querySelector('canvas.drawingBuffer');\n                if (_canvas.dom.overlay) {\n                    _canvas.ctx.overlay = _canvas.dom.overlay.getContext('2d');\n                }\n            }\n        }\n\n        function initReaders() {\n            config.readers.forEach((readerConfig) => {\n                let reader;\n                let configuration = {};\n                let supplements = [];\n\n                if (typeof readerConfig === 'object') {\n                    reader = readerConfig.format;\n                    configuration = readerConfig.config;\n                } else if (typeof readerConfig === 'string') {\n                    reader = readerConfig;\n                }\n                if (ENV.development && config.debug?.printReaderInfo) {\n                    console.log('Before registering reader: ', reader);\n                }\n                if (configuration.supplements) {\n                    supplements = configuration\n                        .supplements.map((supplement) => new READERS[supplement]());\n                }\n                try {\n                    const readerObj = new READERS[reader](configuration, supplements);\n                    _barcodeReaders.push(readerObj);\n                } catch (err) {\n                    console.error('* Error constructing reader ', reader, err);\n                    throw err;\n                }\n            });\n            if (ENV.development && config.debug?.printReaderInfo) {\n                console.log(`Registered Readers: ${_barcodeReaders\n                    .map((reader) => JSON.stringify({ format: reader.FORMAT, config: reader.config }))\n                    .join(', ')}`);\n            }\n        }\n\n        function initConfig() {\n            if (ENV.development && typeof document !== 'undefined') {\n                let i;\n                const vis = [{\n                    node: _canvas.dom.frequency,\n                    prop: config.debug.showFrequency,\n                }, {\n                    node: _canvas.dom.pattern,\n                    prop: config.debug.showPattern,\n                }];\n\n                for (i = 0; i < vis.length; i++) {\n                    if (vis[i].prop === true) {\n                        vis[i].node.style.display = 'block';\n                    } else {\n                        vis[i].node.style.display = 'none';\n                    }\n                }\n            }\n        }\n\n        /**\n         * extend the line on both ends\n         * @param {Array} line\n         * @param {Number} angle\n         */\n        function getExtendedLine(line, angle, ext) {\n            function extendLine(amount) {\n                const extension = {\n                    y: amount * Math.sin(angle),\n                    x: amount * Math.cos(angle),\n                };\n                /* eslint-disable no-param-reassign */\n                line[0].y -= extension.y;\n                line[0].x -= extension.x;\n                line[1].y += extension.y;\n                line[1].x += extension.x;\n                /* eslint-enable no-param-reassign */\n            }\n\n            // check if inside image\n            extendLine(ext);\n            while (ext > 1 && (!inputImageWrapper.inImageWithBorder(line[0])\n                    || !inputImageWrapper.inImageWithBorder(line[1]))) {\n                // eslint-disable-next-line no-param-reassign\n                ext -= Math.ceil(ext / 2);\n                extendLine(-ext);\n            }\n            return line;\n        }\n\n        function getLine(box) {\n            return [{\n                x: (box[1][0] - box[0][0]) / 2 + box[0][0],\n                y: (box[1][1] - box[0][1]) / 2 + box[0][1],\n            }, {\n                x: (box[3][0] - box[2][0]) / 2 + box[2][0],\n                y: (box[3][1] - box[2][1]) / 2 + box[2][1],\n            }];\n        }\n\n        function tryDecode(line) {\n            let result = null;\n            let i;\n            const barcodeLine = Bresenham.getBarcodeLine(inputImageWrapper, line[0], line[1]);\n\n            if (ENV.development && config.debug.showFrequency) {\n                ImageDebug.drawPath(line, { x: 'x', y: 'y' }, _canvas.ctx.overlay, { color: 'red', lineWidth: 3 });\n                Bresenham.debug.printFrequency(barcodeLine.line, _canvas.dom.frequency);\n            }\n\n            Bresenham.toBinaryLine(barcodeLine);\n\n            if (ENV.development && config.debug.showPattern) {\n                Bresenham.debug.printPattern(barcodeLine.line, _canvas.dom.pattern);\n            }\n\n            for (i = 0; i < _barcodeReaders.length && result === null; i++) {\n                result = _barcodeReaders[i].decodePattern(barcodeLine.line);\n            }\n            if (result === null) {\n                return null;\n            }\n            return {\n                codeResult: result,\n                barcodeLine,\n            };\n        }\n\n        /**\n         * This method slices the given area apart and tries to detect a barcode-pattern\n         * for each slice. It returns the decoded barcode, or null if nothing was found\n         * @param {Array} box\n         * @param {Array} line\n         * @param {Number} lineAngle\n         */\n        function tryDecodeBruteForce(box, line, lineAngle) {\n            const sideLength = Math.sqrt(Math.pow(box[1][0] - box[0][0], 2) + Math.pow((box[1][1] - box[0][1]), 2));\n            let i;\n            const slices = 16;\n            let result = null;\n            let dir;\n            let extension;\n            const xdir = Math.sin(lineAngle);\n            const ydir = Math.cos(lineAngle);\n\n            for (i = 1; i < slices && result === null; i++) {\n                // move line perpendicular to angle\n                // eslint-disable-next-line no-mixed-operators\n                dir = sideLength / slices * i * (i % 2 === 0 ? -1 : 1);\n                extension = {\n                    y: dir * xdir,\n                    x: dir * ydir,\n                };\n                /* eslint-disable no-param-reassign */\n                line[0].y += extension.x;\n                line[0].x -= extension.y;\n                line[1].y += extension.x;\n                line[1].x -= extension.y;\n                /* eslint-enable no-param-reassign */\n\n                result = tryDecode(line);\n            }\n            return result;\n        }\n\n        function getLineLength(line) {\n            return Math.sqrt(\n                Math.pow(Math.abs(line[1].y - line[0].y), 2)\n                + Math.pow(Math.abs(line[1].x - line[0].x), 2),\n            );\n        }\n\n        async function decodeFromImage(imageWrapper) {\n            let result = null;\n            for (const reader of _barcodeReaders) {\n                if (reader.decodeImage) {\n                    result = await reader.decodeImage(imageWrapper);\n                    if (result) {\n                        break;\n                    }\n                }\n            }\n            return result;\n        }\n        /**\n         * With the help of the configured readers (Code128 or EAN) this function tries to detect a\n         * valid barcode pattern within the given area.\n         * @param {Object} box The area to search in\n         * @returns {Object} the result {codeResult, line, angle, pattern, threshold}\n         */\n        function decodeFromBoundingBox(box) {\n            let line;\n            const ctx = _canvas.ctx.overlay;\n            let result;\n\n            if (ENV.development) {\n                if (config.debug.drawBoundingBox && ctx) {\n                    ImageDebug.drawPath(box, { x: 0, y: 1 }, ctx, { color: 'blue', lineWidth: 2 });\n                }\n            }\n\n            line = getLine(box);\n            const lineLength = getLineLength(line);\n            const lineAngle = Math.atan2(line[1].y - line[0].y, line[1].x - line[0].x);\n            line = getExtendedLine(line, lineAngle, Math.floor(lineLength * 0.1));\n            if (line === null) {\n                return null;\n            }\n\n            result = tryDecode(line);\n            if (result === null) {\n                result = tryDecodeBruteForce(box, line, lineAngle);\n            }\n\n            if (result === null) {\n                return null;\n            }\n\n            if (ENV.development && result && config.debug.drawScanline && ctx) {\n                ImageDebug.drawPath(line, { x: 'x', y: 'y' }, ctx, { color: 'red', lineWidth: 3 });\n            }\n\n            return {\n                codeResult: result.codeResult,\n                line,\n                angle: lineAngle,\n                pattern: result.barcodeLine.line,\n                threshold: result.barcodeLine.threshold,\n            };\n        }\n\n        return {\n            decodeFromBoundingBox(box) {\n                return decodeFromBoundingBox(box);\n            },\n            decodeFromBoundingBoxes(boxes) {\n                let i; let result;\n                const barcodes = [];\n                const { multiple } = config;\n\n                for (i = 0; i < boxes.length; i++) {\n                    const box = boxes[i];\n                    result = decodeFromBoundingBox(box) || {};\n                    result.box = box;\n\n                    if (multiple) {\n                        barcodes.push(result);\n                    } else if (result.codeResult) {\n                        return result;\n                    }\n                }\n\n                return {\n                    barcodes,\n                };\n            },\n            async decodeFromImage(imageWrapperIn) {\n                const result = await decodeFromImage(imageWrapperIn);\n                return result;\n            },\n            registerReader(name, reader) {\n                if (READERS[name]) {\n                    throw new Error('cannot register existing reader', name);\n                }\n                READERS[name] = reader;\n            },\n            setReaders(readers) {\n                // eslint-disable-next-line no-param-reassign\n                config.readers = readers;\n                _barcodeReaders.length = 0;\n                initReaders();\n            },\n        };\n    },\n};\n","import BarcodeReader from './barcode_reader';\nimport TwoOfFiveReader from './2of5_reader';\nimport NewCodabarReader from './codabar_reader';\nimport Code128Reader from './code_128_reader';\nimport Code32Reader from './code_32_reader';\nimport Code39Reader from './code_39_reader';\nimport Code39VINReader from './code_39_vin_reader';\nimport Code93Reader from './code_93_reader';\nimport EAN2Reader from './ean_2_reader';\nimport EAN5Reader from './ean_5_reader';\nimport EAN8Reader from './ean_8_reader';\nimport EANReader from './ean_reader';\nimport I2of5Reader from './i2of5_reader';\nimport UPCEReader from './upc_e_reader';\nimport UPCReader from './upc_reader';\n\nexport {\n    BarcodeReader,\n    TwoOfFiveReader,\n    NewCodabarReader,\n    Code128Reader,\n    Code32Reader,\n    Code39Reader,\n    Code39VINReader,\n    Code93Reader,\n    EAN2Reader,\n    EAN5Reader,\n    EAN8Reader,\n    EANReader,\n    I2of5Reader,\n    UPCEReader,\n    UPCReader,    \n}\n","type EventName = string;\n\ninterface Subscription {\n    async?: boolean;\n    callback: Function;\n    once?: boolean;\n}\n\ninterface EventData {\n    subscribers: Array<Subscription>;\n}\n\ninterface Events {\n    [key: string]: EventData;\n}\n\ninterface EventInterface {\n    subscribe(event: EventName, callback: Function | Subscription, async?: boolean): void;\n    publish(eventName: EventName, data?: never): void;\n    once(event: EventName, callback: Function, async?: boolean): void;\n    unsubscribe(eventName?: EventName, callback?: Function | Subscription): void;\n}\n\nexport default (function EventInterface(): EventInterface {\n    let events: Events = {};\n\n    function getEvent(eventName: EventName): EventData {\n        if (!events[eventName]) {\n            events[eventName] = {\n                subscribers: [],\n            };\n        }\n        return events[eventName];\n    }\n\n    function clearEvents(): void {\n        events = {};\n    }\n\n    function publishSubscription(subscription: Subscription, data: never): void {\n        if (subscription.async) {\n            setTimeout(() => {\n                subscription.callback(data);\n            }, 4);\n        } else {\n            subscription.callback(data);\n        }\n    }\n\n    function _subscribe(event: EventName, callback: Function | Subscription, async?: boolean): void {\n        let subscription;\n\n        if (typeof callback === 'function') {\n            subscription = {\n                callback,\n                async,\n            };\n        } else {\n            subscription = callback;\n            if (!subscription.callback) {\n                throw new Error('Callback was not specified on options');\n            }\n        }\n\n        getEvent(event).subscribers.push(subscription);\n    }\n\n    return {\n        subscribe(event: EventName, callback: Function | Subscription, async?: boolean): void {\n            return _subscribe(event, callback, async);\n        },\n        publish(eventName: EventName, data?: never): void {\n            const event = getEvent(eventName);\n            const { subscribers } = event;\n\n            // Publish one-time subscriptions\n            subscribers.filter((subscriber) => !!subscriber.once).forEach((subscriber) => {\n                publishSubscription(subscriber, data as never);\n            });\n\n            // remove them from the subscriber\n            event.subscribers = subscribers.filter((subscriber) => !subscriber.once);\n\n            // publish the rest\n            event.subscribers.forEach((subscriber) => {\n                publishSubscription(subscriber, data as never);\n            });\n        },\n        once(event: EventName, callback: Function, async = false): void {\n            _subscribe(event, {\n                callback,\n                async,\n                once: true,\n            });\n        },\n        unsubscribe(eventName?: EventName, callback?: Function | Subscription): void {\n            if (eventName) {\n                const event = getEvent(eventName);\n                if (event && callback) {\n                    event.subscribers = event.subscribers.filter((subscriber) => subscriber.callback !== callback);\n                } else {\n                    event.subscribers = [];\n                }\n            } else {\n                clearEvents();\n            }\n        },\n    };\n}());\n","export default class Exception extends Error {\n    code?: number;\n\n    constructor(m: string, code?: number) {\n        super(m);\n        this.code = code;\n        Object.setPrototypeOf(this, Exception.prototype);\n    }\n}\n","import Exception from '../quagga/Exception';\n\nconst ERROR_DESC = 'This may mean that the user has declined camera access, or the browser does not support media APIs. If you are running in iOS, you must use Safari.';\n\nexport function enumerateDevices(): Promise<Array<MediaDeviceInfo>> {\n    try {\n        return navigator.mediaDevices.enumerateDevices();\n    } catch (err) {\n        const error: Error = new Exception(`enumerateDevices is not defined. ${ERROR_DESC}`, -1);\n        return Promise.reject(error);\n    }\n}\n\nexport function getUserMedia(constraints: MediaStreamConstraints): Promise<MediaStream> {\n    try {\n        return navigator.mediaDevices.getUserMedia(constraints);\n    } catch (err) {\n        const error: Error = new Exception(`getUserMedia is not defined. ${ERROR_DESC}`, -1);\n        return Promise.reject(error);\n    }\n}\n","// TODO: when this file was written years ago, HTMLMediaElement.play() did not return a useful value\n// to let us know when the video started playing.  Now, it does.  So, we shouldn't need to run this\n// odd waitForVideo() function that polls to see if the video has started.\nimport pick from 'lodash/pick';\nimport { getUserMedia, enumerateDevices } from '../common/mediaDevices';\nimport Exception from '../quagga/Exception';\nimport type {\n    MediaTrackConstraintsWithDeprecated,\n    QuaggaJSCameraAccess as CameraAccessType,\n} from '../../type-definitions/quagga.d';\n\nlet streamRef: MediaStream | null;\n\nfunction waitForVideo(video: HTMLVideoElement): Promise<void> {\n    return new Promise((resolve, reject) => {\n        let attempts = 10;\n\n        function checkVideo(): void {\n            if (attempts > 0) {\n                if (video.videoWidth > 10 && video.videoHeight > 10) {\n                    if (ENV.development) {\n                        console.log(`* dev: checkVideo found ${video.videoWidth}px x ${video.videoHeight}px`);\n                    }\n                    resolve();\n                } else {\n                    window.setTimeout(checkVideo, 500);\n                }\n            } else {\n                reject(new Exception('Unable to play video stream. Is webcam working?', -1)); // TODO: add error code\n            }\n            attempts--;\n        }\n        checkVideo();\n    });\n}\n\n/**\n * Tries to attach the camera-stream to a given video-element\n * and calls the callback function when the content is ready\n * @param {Object} constraints\n * @param {Object} video\n */\nasync function initCamera(video: HTMLVideoElement | null, constraints: MediaStreamConstraints): Promise<void> {\n    const stream = await getUserMedia(constraints);\n    streamRef = stream;\n    if (video) {\n        video.setAttribute('autoplay', 'true');\n        video.setAttribute('muted', 'true');\n        video.setAttribute('playsinline', 'true'); // not listed on MDN...\n        // eslint-disable-next-line no-param-reassign\n        video.srcObject = stream;\n        video.addEventListener('loadedmetadata', () => {\n            video.play().catch((err) => {\n                console.warn('* Error while trying to play video stream:', err);\n            });\n        });\n        return waitForVideo(video);\n    }\n    return Promise.resolve();\n}\n\nfunction deprecatedConstraints(videoConstraints: MediaTrackConstraintsWithDeprecated): MediaTrackConstraints {\n    const normalized = pick(videoConstraints, ['width', 'height', 'facingMode',\n        'aspectRatio', 'deviceId']);\n\n    if (typeof videoConstraints.minAspectRatio !== 'undefined'\n            && videoConstraints.minAspectRatio > 0) {\n        normalized.aspectRatio = videoConstraints.minAspectRatio;\n        console.log('WARNING: Constraint \\'minAspectRatio\\' is deprecated; Use \\'aspectRatio\\' instead');\n    }\n    if (typeof videoConstraints.facing !== 'undefined') {\n        normalized.facingMode = videoConstraints.facing;\n        console.log('WARNING: Constraint \\'facing\\' is deprecated. Use \\'facingMode\\' instead\\'');\n    }\n    return normalized;\n}\n\n// TODO: #192 I don't think there's any good reason pickConstraints should return a Promise,\n// I think it was just that way so it could be chained to other functions that did return a Promise.\n// That's not necessary with async functions being a thing, so that should be fixed.\nexport function pickConstraints(videoConstraints: MediaTrackConstraintsWithDeprecated = {}): Promise<MediaStreamConstraints> {\n    const video = deprecatedConstraints(videoConstraints);\n\n    if (video && video.deviceId && video.facingMode) {\n        delete video.facingMode;\n    }\n    return Promise.resolve({ audio: false, video });\n}\n\nasync function enumerateVideoDevices(): Promise<Array<MediaDeviceInfo>> {\n    const devices = await enumerateDevices();\n    return devices.filter((device: MediaDeviceInfo) => device.kind === 'videoinput');\n}\n\nfunction getActiveTrack(): MediaStreamTrack | null {\n    if (!streamRef) {\n        return null;\n    }\n    const tracks = streamRef.getVideoTracks();\n    return tracks && tracks?.length ? tracks[0] : null;\n}\n\n/**\n * Used for accessing information about the active stream track and available video devices.\n */\nconst QuaggaJSCameraAccess: CameraAccessType = {\n    requestedVideoElement: null,\n    async request(video: HTMLVideoElement | null, videoConstraints?: MediaTrackConstraintsWithDeprecated): Promise<any> {\n        QuaggaJSCameraAccess.requestedVideoElement = video;\n        const newConstraints = await pickConstraints(videoConstraints);\n        return initCamera(video, newConstraints);\n    },\n    release(): Promise<void> {\n        const tracks = streamRef && streamRef.getVideoTracks();\n        if (QuaggaJSCameraAccess.requestedVideoElement !== null) {\n            QuaggaJSCameraAccess.requestedVideoElement.pause();\n        }\n        return new Promise<void>((resolve) => {\n            setTimeout(() => {\n                if (tracks && tracks.length) {\n                    tracks.forEach((track) => track.stop());\n                }\n                streamRef = null;\n                QuaggaJSCameraAccess.requestedVideoElement = null;\n                resolve();\n            }, 0);\n        });\n    },\n    enumerateVideoDevices,\n    getActiveStreamLabel(): string {\n        const track = getActiveTrack();\n        return track ? track.label : '';\n    },\n    getActiveTrack,\n    async disableTorch() {\n        const track = getActiveTrack();\n        // TODO: should we acquire camera access even if there's no current camera open?\n        // TODO: what happens on iOS or another device where torch isn't supported at all? Should we throw an error?\n        if (track) {\n            try {\n                await track.applyConstraints({ advanced: [{ torch: false }] } as MediaTrackConstraintSet);\n            } catch (err) {\n                if (err instanceof OverconstrainedError) {\n                    console.warn('quagga2/CameraAccess: Torch not supported on this device');\n                }\n                throw err;\n            }\n        }\n    },\n    async enableTorch() {\n        const track = getActiveTrack();\n        // TODO: should we acquire camera access even if there's no current camera open?\n        // TODO: what happens on iOS or another device where torch isn't supported at all? Should we throw an error?\n        if (track) {\n            try {\n                await track.applyConstraints({ advanced: [{ torch: true }] } as MediaTrackConstraintSet);\n            } catch (err) {\n                if (err instanceof OverconstrainedError) {\n                    console.warn('quagga2/CameraAccess: Torch not supported on this device');\n                }\n                throw err;\n            }\n        }\n    },\n};\n\nexport default QuaggaJSCameraAccess;\n","import ImageDebug from '../common/image_debug';\nimport type {\n    QuaggaJSCodeResult,\n    QuaggaJSResultCollector,\n    QuaggaJSResultCollectorFilterFunction,\n    XYSize,\n    QuaggaImageData,\n} from '../../type-definitions/quagga.d';\n\nfunction contains(codeResult: QuaggaJSCodeResult, list: Array<QuaggaJSCodeResult>): boolean {\n    return list && list.some((item) => {\n        const keys = Object.keys(item) as Array<keyof QuaggaJSCodeResult>;\n        return keys.every((key) => item[key] === codeResult[key]);\n    });\n}\n\nfunction passesFilter(\n    codeResult: QuaggaJSCodeResult,\n    filter: QuaggaJSResultCollectorFilterFunction | undefined,\n): boolean {\n    return typeof filter === 'function' ? filter(codeResult) : true;\n}\n\ninterface ResultCollector {\n    addResult: (data: QuaggaImageData, imageSize: XYSize, codeResult: QuaggaJSCodeResult) => void;\n    getResults: () => Array<QuaggaJSCodeResult>;\n}\n\nexport default {\n    create(config: QuaggaJSResultCollector): ResultCollector {\n        const canvas = document.createElement('canvas');\n        const ctx = canvas.getContext('2d', { willReadFrequently: !!config.willReadFrequently }) as CanvasRenderingContext2D;\n        const results: Array<QuaggaJSCodeResult> = [];\n        let capacity = config.capacity ?? 20;\n        const capture = config.capture === true;\n\n        function matchesConstraints(codeResult: QuaggaJSCodeResult): boolean {\n            return !!capacity\n                && codeResult\n                && !contains(codeResult, config.blacklist as Array<QuaggaJSCodeResult>)\n                && passesFilter(codeResult, config.filter);\n        }\n\n        return {\n            addResult(data: QuaggaImageData, imageSize: XYSize, codeResult: QuaggaJSCodeResult): void {\n                const result: any = { }; // this is 'any' to avoid having to construct a whole QuaggaJSCodeResult :|\n                if (matchesConstraints(codeResult)) {\n                    capacity--;\n                    result.codeResult = codeResult;\n                    if (capture) {\n                        canvas.width = imageSize.x;\n                        canvas.height = imageSize.y;\n                        ImageDebug.drawImage(data, imageSize, ctx);\n                        result.frame = canvas.toDataURL();\n                    }\n                    results.push(result);\n                }\n            },\n            getResults(): Array<QuaggaJSCodeResult> {\n                return results;\n            },\n        };\n    },\n};\n","import { QuaggaJSConfigObject } from '../../type-definitions/quagga.d';\n\nconst DevConfig: QuaggaJSConfigObject = {\n    inputStream: {\n        name: 'Live',\n        type: 'LiveStream',\n        constraints: {\n            width: 640,\n            height: 480,\n            // aspectRatio: 640/480, // optional\n            facingMode: 'environment', // or user\n            // deviceId: \"38745983457387598375983759834\"\n        },\n        area: {\n            top: '0%',\n            right: '0%',\n            left: '0%',\n            bottom: '0%',\n        },\n        singleChannel: false, // true: only the red color-channel is read\n        debug: {\n            showImageDetails: false, // logs frame grabber info, canvas size adjustments\n        },\n    },\n    locate: true,\n    numOfWorkers: 0,\n    decoder: {\n        readers: [\n            'code_128_reader',\n        ],\n        debug: {\n            drawBoundingBox: false,\n            showFrequency: false,\n            drawScanline: false,\n            showPattern: false,\n            printReaderInfo: false, // logs reader registration and initialization\n        },\n    },\n    locator: {\n        halfSample: true,\n        patchSize: 'medium', // x-small, small, medium, large, x-large\n        debug: {\n            showCanvas: false,\n            showPatches: false,\n            showFoundPatches: false,\n            showSkeleton: false,\n            showLabels: false,\n            showPatchLabels: false,\n            showRemainingPatchLabels: false,\n            showPatchSize: false, // logs calculated patch size\n            showImageDetails: false, // logs image wrapper size, canvas details\n            boxFromPatches: {\n                showTransformed: false,\n                showTransformedBox: false,\n                showBB: false,\n            },\n        },\n    },\n};\n\nexport default DevConfig;\n","import { QuaggaJSConfigObject } from '../../type-definitions/quagga.d';\n\nconst NodeConfig: QuaggaJSConfigObject = {\n    inputStream: {\n        type: 'ImageStream',\n        sequence: false,\n        size: 800,\n        area: {\n            top: '0%',\n            right: '0%',\n            left: '0%',\n            bottom: '0%',\n        },\n        singleChannel: false, // true: only the red color-channel is read\n    },\n    locate: true,\n    numOfWorkers: 0,\n    decoder: {\n        readers: [\n            'code_128_reader',\n        ],\n    },\n    locator: {\n        halfSample: true,\n        patchSize: 'medium', // x-small, small, medium, large, x-large\n    },\n};\n\nexport default NodeConfig;\n","import { QuaggaJSConfigObject } from '../../type-definitions/quagga.d';\n\nconst ProdConfig: QuaggaJSConfigObject = {\n    inputStream: {\n        name: 'Live',\n        type: 'LiveStream',\n        constraints: {\n            width: 640,\n            height: 480,\n            // aspectRatio: 640/480, // optional\n            facingMode: 'environment', // or user\n            // deviceId: \"38745983457387598375983759834\"\n        },\n        area: {\n            top: '0%',\n            right: '0%',\n            left: '0%',\n            bottom: '0%',\n        },\n        singleChannel: false, // true: only the red color-channel is read\n    },\n    locate: true,\n    numOfWorkers: 4,\n    decoder: {\n        readers: [\n            'code_128_reader',\n        ],\n    },\n    locator: {\n        halfSample: true,\n        patchSize: 'medium', // x-small, small, medium, large, x-large\n    },\n};\n\nexport default ProdConfig;\n","import { QuaggaJSConfigObject } from '../../type-definitions/quagga.d';\nimport DevConfig from './config.dev';\nimport NodeConfig from './config.node';\nimport ProdConfig from './config.prod';\n\nconst ExportConfig: QuaggaJSConfigObject = (() => {\n    let QuaggaConfig: QuaggaJSConfigObject;\n    if (typeof ENV === 'undefined' || ENV.development) {\n        QuaggaConfig = DevConfig;\n    } else if (ENV.node) {\n        QuaggaConfig = NodeConfig;\n    } else {\n        QuaggaConfig = ProdConfig;\n    }\n    return QuaggaConfig;\n})();\n\nexport default ExportConfig;\n","// NOTE FOR ANYONE IN HERE IN THE FUTURE:\n// webpack.config.js replaces the frame_grabber module with THIS module when it is building for a Browser environment.\n\nimport {\n    imageRef,\n    grayAndHalfSampleFromCanvasData,\n    computeGray,\n} from '../common/cv_utils';\n\nconst TO_RADIANS = Math.PI / 180;\n\nfunction adjustCanvasSize(canvas, targetSize, debug) {\n    if (canvas.width !== targetSize.x) {\n        if (ENV.development && debug?.showImageDetails) {\n            console.log('WARNING: canvas-size needs to be adjusted');\n        }\n        canvas.width = targetSize.x;\n    }\n    if (canvas.height !== targetSize.y) {\n        if (ENV.development && debug?.showImageDetails) {\n            console.log('WARNING: canvas-size needs to be adjusted');\n        }\n        canvas.height = targetSize.y;\n    }\n}\n\nconst FrameGrabber = {};\n\nFrameGrabber.create = function (inputStream, canvas) {\n    // console.warn('*** FrameGrabberBrowser create');\n    const _that = {};\n    const _streamConfig = inputStream.getConfig();\n    const _videoSize = imageRef(inputStream.getRealWidth(), inputStream.getRealHeight());\n    const _canvasSize = inputStream.getCanvasSize();\n    const _size = imageRef(inputStream.getWidth(), inputStream.getHeight());\n    const topRight = inputStream.getTopRight();\n    const _sx = topRight.x;\n    const _sy = topRight.y;\n    let _canvas;\n    let _ctx = null;\n    let _data = null;\n    const { willReadFrequently } = _streamConfig;\n\n    _canvas = canvas || document.createElement('canvas');\n    _canvas.width = _canvasSize.x;\n    _canvas.height = _canvasSize.y;\n    if (ENV.development && _streamConfig.debug?.showImageDetails) {\n        console.warn('*** frame_grabber_browser: willReadFrequently=', willReadFrequently, 'canvas=', _canvas);\n    }\n    _ctx = _canvas.getContext('2d', { willReadFrequently: !!willReadFrequently }); // double not because we have an optional bool that needs to pass as a bool\n    _data = new Uint8Array(_size.x * _size.y);\n    if (ENV.development && _streamConfig.debug?.showImageDetails) {\n        console.log('FrameGrabber', JSON.stringify({\n            size: _size,\n            topRight,\n            videoSize: _videoSize,\n            canvasSize: _canvasSize,\n        }));\n    }\n\n    /**\n     * Uses the given array as frame-buffer\n     */\n    _that.attachData = function (data) {\n        _data = data;\n    };\n\n    /**\n     * Returns the used frame-buffer\n     */\n    _that.getData = function () {\n        return _data;\n    };\n\n    /**\n     * Fetches a frame from the input-stream and puts into the frame-buffer.\n     * The image-data is converted to gray-scale and then half-sampled if configured.\n     */\n    _that.grab = function () {\n        const doHalfSample = _streamConfig.halfSample;\n        const frame = inputStream.getFrame();\n        let drawable = frame;\n        let drawAngle = 0;\n        let ctxData;\n        if (drawable) {\n            adjustCanvasSize(_canvas, _canvasSize, _streamConfig.debug);\n            if (_streamConfig.type === 'ImageStream') {\n                drawable = frame.img;\n                if (frame.tags && frame.tags.orientation) {\n                    switch (frame.tags.orientation) {\n                        case 6:\n                            drawAngle = 90 * TO_RADIANS;\n                            break;\n                        case 8:\n                            drawAngle = -90 * TO_RADIANS;\n                            break;\n                    }\n                }\n            }\n\n            if (drawAngle !== 0) {\n                _ctx.translate(_canvasSize.x / 2, _canvasSize.y / 2);\n                _ctx.rotate(drawAngle);\n                _ctx.drawImage(drawable, -_canvasSize.y / 2, -_canvasSize.x / 2, _canvasSize.y, _canvasSize.x);\n                _ctx.rotate(-drawAngle);\n                _ctx.translate(-_canvasSize.x / 2, -_canvasSize.y / 2);\n            } else {\n                _ctx.drawImage(drawable, 0, 0, _canvasSize.x, _canvasSize.y);\n            }\n\n            ctxData = _ctx.getImageData(_sx, _sy, _size.x, _size.y).data;\n            if (doHalfSample) {\n                grayAndHalfSampleFromCanvasData(ctxData, _size, _data);\n            } else {\n                computeGray(ctxData, _data, _streamConfig);\n            }\n            return true;\n        }\n        return false;\n    };\n\n    _that.getSize = function () {\n        return _size;\n    };\n\n    return _that;\n};\n\nexport default FrameGrabber;\n","// NOTE: (SOME OF) THIS IS BROWSER ONLY CODE.  Node does not have 'atob' built in, nor XMLHttpRequest.\n// How exactly is this set of functions used in Quagga? Do we need the browser specific code? Do we\n// need to port any part of this that doesn't work in Node to node?\n\n// Tags scraped from https://github.com/exif-js/exif-js\nconst ExifTags = { 0x0112: 'orientation' };\nexport const AvailableTags = Object.keys(ExifTags).map((key) => ExifTags[key]);\n\nexport function findTagsInObjectURL(src, tags = AvailableTags) {\n    if (/^blob:/i.test(src)) {\n        return objectURLToBlob(src)\n            .then(readToBuffer)\n            .then((buffer) => findTagsInBuffer(buffer, tags));\n    }\n    return Promise.resolve(null);\n}\n\nexport function base64ToArrayBuffer(dataUrl) {\n    const base64 = dataUrl.replace(/^data:([^;]+);base64,/gmi, '');\n    const binary = atob(base64);\n    const len = binary.length;\n    const buffer = new ArrayBuffer(len);\n    const view = new Uint8Array(buffer);\n\n    for (let i = 0; i < len; i++) {\n        view[i] = binary.charCodeAt(i);\n    }\n    return buffer;\n}\n\nfunction readToBuffer(blob) {\n    return new Promise((resolve) => {\n        const fileReader = new FileReader();\n        fileReader.onload = function (e) {\n            return resolve(e.target.result);\n        };\n        fileReader.readAsArrayBuffer(blob);\n    });\n}\n\nfunction objectURLToBlob(url) {\n    return new Promise((resolve, reject) => {\n        const http = new XMLHttpRequest();\n        http.open('GET', url, true);\n        http.responseType = 'blob';\n        http.onreadystatechange = function () {\n            if (http.readyState === XMLHttpRequest.DONE && (http.status === 200 || http.status === 0)) {\n                resolve(this.response);\n            }\n        };\n        http.onerror = reject;\n        http.send();\n    });\n}\n\nexport function findTagsInBuffer(file, selectedTags = AvailableTags) {\n    const dataView = new DataView(file);\n    const length = file.byteLength;\n    const exifTags = selectedTags.reduce((result, selectedTag) => {\n        const exifTag = Object.keys(ExifTags).filter((tag) => ExifTags[tag] === selectedTag)[0];\n        if (exifTag) {\n            result[exifTag] = selectedTag;\n        }\n        return result;\n    }, {});\n    let offset = 2;\n    let marker;\n\n    if ((dataView.getUint8(0) !== 0xFF) || (dataView.getUint8(1) !== 0xD8)) {\n        return false;\n    }\n\n    while (offset < length) {\n        if (dataView.getUint8(offset) !== 0xFF) {\n            return false;\n        }\n\n        marker = dataView.getUint8(offset + 1);\n        if (marker === 0xE1) {\n            return readEXIFData(dataView, offset + 4, exifTags);\n        }\n        offset += 2 + dataView.getUint16(offset + 2);\n    }\n\n    return false;\n}\n\nfunction readEXIFData(file, start, exifTags) {\n    if (getStringFromBuffer(file, start, 4) !== 'Exif') {\n        return false;\n    }\n\n    const tiffOffset = start + 6;\n    let bigEnd;\n\n    if (file.getUint16(tiffOffset) === 0x4949) {\n        bigEnd = false;\n    } else if (file.getUint16(tiffOffset) === 0x4D4D) {\n        bigEnd = true;\n    } else {\n        return false;\n    }\n\n    if (file.getUint16(tiffOffset + 2, !bigEnd) !== 0x002A) {\n        return false;\n    }\n\n    const firstIFDOffset = file.getUint32(tiffOffset + 4, !bigEnd);\n    if (firstIFDOffset < 0x00000008) {\n        return false;\n    }\n\n    const tags = readTags(file, tiffOffset, tiffOffset + firstIFDOffset, exifTags, bigEnd);\n    return tags;\n}\n\nfunction readTags(file, tiffStart, dirStart, strings, bigEnd) {\n    const entries = file.getUint16(dirStart, !bigEnd);\n    const tags = {};\n\n    for (let i = 0; i < entries; i++) {\n        const entryOffset = dirStart + i * 12 + 2;\n        const tag = strings[file.getUint16(entryOffset, !bigEnd)];\n        if (tag) {\n            tags[tag] = readTagValue(file, entryOffset, tiffStart, dirStart, bigEnd);\n        }\n    }\n    return tags;\n}\n\nfunction readTagValue(file, entryOffset, tiffStart, dirStart, bigEnd) {\n    const type = file.getUint16(entryOffset + 2, !bigEnd);\n    const numValues = file.getUint32(entryOffset + 4, !bigEnd);\n\n    switch (type) {\n        case 3:\n            if (numValues === 1) {\n                return file.getUint16(entryOffset + 8, !bigEnd);\n            }\n    }\n\n    return null;\n}\n\nfunction getStringFromBuffer(buffer, start, length) {\n    let outstr = '';\n    for (let n = start; n < start + length; n++) {\n        outstr += String.fromCharCode(buffer.getUint8(n));\n    }\n    return outstr;\n}\n","import { findTagsInObjectURL } from './exif_helper';\n\nconst ImageLoader = {};\nImageLoader.load = function (directory, callback, offset, size, sequence, config) {\n    const htmlImagesSrcArray = new Array(size);\n    const htmlImagesArray = new Array(htmlImagesSrcArray.length);\n    let i;\n    let img;\n    let num;\n\n    if (sequence === false) {\n        htmlImagesSrcArray[0] = directory;\n    } else {\n        for (i = 0; i < htmlImagesSrcArray.length; i++) {\n            num = (offset + i);\n            htmlImagesSrcArray[i] = `${directory}image-${(`00${num}`).slice(-3)}.jpg`;\n        }\n    }\n    htmlImagesArray.notLoaded = [];\n    htmlImagesArray.addImage = function (image) {\n        htmlImagesArray.notLoaded.push(image);\n    };\n    htmlImagesArray.loaded = function (loadedImg) {\n        const notloadedImgs = htmlImagesArray.notLoaded;\n        for (let x = 0; x < notloadedImgs.length; x++) {\n            if (notloadedImgs[x] === loadedImg) {\n                notloadedImgs.splice(x, 1);\n                for (let y = 0; y < htmlImagesSrcArray.length; y++) {\n                    const imgName = htmlImagesSrcArray[y].substr(htmlImagesSrcArray[y].lastIndexOf('/'));\n                    if (loadedImg.src.lastIndexOf(imgName) !== -1) {\n                        htmlImagesArray[y] = { img: loadedImg };\n                        break;\n                    }\n                }\n                break;\n            }\n        }\n        if (notloadedImgs.length === 0) {\n            if (ENV.development && config?.debug?.showImageDetails) {\n                console.log(`Images loaded: ${htmlImagesArray.length} image${htmlImagesArray.length !== 1 ? 's' : ''} from ${sequence === false ? directory : directory + ' (sequence)'}`);\n            }\n            if (sequence === false) {\n                findTagsInObjectURL(directory, ['orientation'])\n                    .then((tags) => {\n                        htmlImagesArray[0].tags = tags;\n                        callback(htmlImagesArray);\n                    }).catch((e) => {\n                        console.log(e);\n                        callback(htmlImagesArray);\n                    });\n            } else {\n                callback(htmlImagesArray);\n            }\n        }\n    };\n\n    for (i = 0; i < htmlImagesSrcArray.length; i++) {\n        img = new Image();\n        htmlImagesArray.addImage(img);\n        addOnloadHandler(img, htmlImagesArray);\n        img.src = htmlImagesSrcArray[i];\n    }\n};\n\nfunction addOnloadHandler(img, htmlImagesArray) {\n    img.onload = function () {\n        htmlImagesArray.loaded(this);\n    };\n}\n\nexport default (ImageLoader);\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport ImageLoader from '../image_loader';\nimport { XYSize, Point } from '../../../type-definitions/quagga.d';\nimport { InputStreamFactory, InputStream, EventHandlerList } from './input_stream.d';\n\nconst inputStreamFactory: InputStreamFactory = {\n    createVideoStream(video): InputStream {\n        console.warn('**** InputStreamBrowser createVideoStream');\n        let _config: { size: number; type: string } | null = null;\n        const _eventNames = ['canrecord', 'ended'];\n        const _eventHandlers: EventHandlerList = {};\n        let _calculatedWidth: number;\n        let _calculatedHeight: number;\n        const _topRight: Point = { x: 0, y: 0, type: 'Point' };\n        const _canvasSize: XYSize = { x: 0, y: 0, type: 'XYSize' };\n\n        function initSize(): void {\n            const width = video.videoWidth;\n            const height = video.videoHeight;\n\n            // eslint-disable-next-line no-nested-ternary\n            _calculatedWidth = _config?.size ? width / height > 1 ? _config.size : Math.floor((width / height) * _config.size) : width;\n            // eslint-disable-next-line no-nested-ternary\n            _calculatedHeight = _config?.size ? width / height > 1 ? Math.floor((height / width) * _config.size) : _config.size : height;\n\n            _canvasSize.x = _calculatedWidth;\n            _canvasSize.y = _calculatedHeight;\n        }\n        const inputStream: InputStream = {\n            getRealWidth() {\n                return video.videoWidth;\n            },\n\n            getRealHeight() {\n                return video.videoHeight;\n            },\n\n            getWidth() {\n                return _calculatedWidth;\n            },\n\n            getHeight() {\n                return _calculatedHeight;\n            },\n\n            setWidth(width) {\n                _calculatedWidth = width;\n            },\n\n            setHeight(height) {\n                _calculatedHeight = height;\n            },\n\n            setInputStream(config) {\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n                _config = config;\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n                this.setAttribute('src', (typeof config.src !== 'undefined') ? config.src : '');\n            },\n\n            ended() {\n                return video.ended;\n            },\n\n            getConfig() {\n                return _config;\n            },\n\n            setAttribute(name, value) {\n                if (video) {\n                    video.setAttribute(name, value);\n                }\n            },\n\n            pause() {\n                video.pause();\n            },\n\n            play() {\n                // eslint-disable-next-line @typescript-eslint/no-floating-promises\n                video.play();\n            },\n\n            setCurrentTime(time) {\n                if (_config?.type !== 'LiveStream') {\n                    this.setAttribute('currentTime', time.toString());\n                }\n            },\n\n            addEventListener(event, f, bool) {\n                if (_eventNames.indexOf(event) !== -1) {\n                    if (!_eventHandlers[event]) {\n                        _eventHandlers[event] = [];\n                    }\n                    _eventHandlers[event].push(f);\n                } else {\n                    video.addEventListener(event, f, bool);\n                }\n            },\n\n            clearEventHandlers() {\n                _eventNames.forEach((eventName) => {\n                    const handlers = _eventHandlers[eventName];\n                    if (handlers && handlers.length > 0) {\n                        handlers.forEach((handler) => {\n                            video.removeEventListener(eventName, handler);\n                        });\n                    }\n                });\n            },\n\n            trigger(eventName, args) {\n                let j;\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n                const handlers = _eventHandlers[eventName];\n\n                if (eventName === 'canrecord') {\n                    initSize();\n                }\n                if (handlers && handlers.length > 0) {\n                    for (j = 0; j < handlers.length; j++) {\n                        handlers[j].apply(inputStream, args);\n                    }\n                }\n            },\n\n            setTopRight(topRight) {\n                _topRight.x = topRight.x;\n                _topRight.y = topRight.y;\n            },\n\n            getTopRight() {\n                return _topRight;\n            },\n\n            setCanvasSize(size) {\n                _canvasSize.x = size.x;\n                _canvasSize.y = size.y;\n            },\n\n            getCanvasSize() {\n                return _canvasSize;\n            },\n\n            getFrame() {\n                return video;\n            },\n        };\n        return inputStream;\n    },\n    createLiveStream(video): InputStream {\n        console.warn('**** InputStreamBrowser createLiveStream');\n        if (video) {\n            video.setAttribute('autoplay', 'true');\n        }\n        const that = inputStreamFactory.createVideoStream(video);\n        that.ended = function ended(): false {\n            return false;\n        };\n        return that;\n    },\n    createImageStream(): InputStream {\n        // console.warn('**** InputStreamBrowser createImageStream');\n        let _config: { size: number; sequence: any } | null = null;\n\n        let width = 0;\n        let height = 0;\n        let frameIdx = 0;\n        let paused = true;\n        let loaded = false;\n        let imgArray: any[] | null = null;\n        let size = 0;\n        const offset = 1;\n        let baseUrl: string | null = null;\n        let ended = false;\n        let calculatedWidth: number;\n        let calculatedHeight: number;\n        const _eventNames = ['canrecord', 'ended'];\n        const _eventHandlers: EventHandlerList = {};\n        const _topRight: Point = { x: 0, y: 0, type: 'Point' };\n        const _canvasSize: XYSize = { x: 0, y: 0, type: 'XYSize' };\n\n        function loadImages(): void {\n            loaded = false;\n            ImageLoader.load(baseUrl, (imgs: Array<{ tags: any; img: HTMLImageElement}>) => {\n                imgArray = imgs;\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n                if (imgs[0].tags && imgs[0].tags.orientation) {\n                    // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n                    switch (imgs[0].tags.orientation) {\n                        case 6:\n                        case 8:\n                            width = imgs[0].img.height;\n                            height = imgs[0].img.width;\n                            break;\n                        default:\n                            width = imgs[0].img.width;\n                            height = imgs[0].img.height;\n                    }\n                } else {\n                    width = imgs[0].img.width;\n                    height = imgs[0].img.height;\n                }\n                // eslint-disable-next-line no-nested-ternary\n                calculatedWidth = _config?.size ? width / height > 1 ? _config.size : Math.floor((width / height) * _config.size) : width;\n                // eslint-disable-next-line no-nested-ternary\n                calculatedHeight = _config?.size ? width / height > 1 ? Math.floor((height / width) * _config.size) : _config.size : height;\n                _canvasSize.x = calculatedWidth;\n                _canvasSize.y = calculatedHeight;\n                loaded = true;\n                frameIdx = 0;\n                setTimeout(() => {\n                    // eslint-disable-next-line @typescript-eslint/no-use-before-define\n                    publishEvent('canrecord', []);\n                }, 0);\n            }, offset, size, _config?.sequence, _config);\n        }\n\n        function publishEvent(eventName: string, args: Array<any>): void {\n            let j;\n            const handlers = _eventHandlers[eventName];\n\n            if (handlers && handlers.length > 0) {\n                for (j = 0; j < handlers.length; j++) {\n                    // eslint-disable-next-line @typescript-eslint/no-use-before-define\n                    handlers[j].apply(inputStream, args as any); // TODO: typescript complains that any[] is not valid for a second arg for apply?!\n                }\n            }\n        }\n\n        // TODO: any code shared with the first InputStream above should be shared not copied\n        // TODO: publishEvent needs access to inputStream, but inputStream needs access to publishEvent\n        // TODO: This is why it's a 'var', so it hoists back.  This is ugly, and should be changed.\n        // eslint-disable-next-line no-var,vars-on-top\n        var inputStream: InputStream = {\n\n            trigger: publishEvent,\n\n            getWidth() {\n                return calculatedWidth;\n            },\n\n            getHeight() {\n                return calculatedHeight;\n            },\n\n            setWidth(newWidth) {\n                calculatedWidth = newWidth;\n            },\n\n            setHeight(newHeight) {\n                calculatedHeight = newHeight;\n            },\n\n            getRealWidth() {\n                return width;\n            },\n\n            getRealHeight() {\n                return height;\n            },\n\n            setInputStream(stream) {\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n                _config = stream;\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n                if (stream.sequence === false) {\n                    // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access\n                    baseUrl = stream.src;\n                    size = 1;\n                } else {\n                    // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access\n                    baseUrl = stream.src;\n                    // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access\n                    size = stream.length;\n                }\n                loadImages();\n            },\n\n            ended() {\n                return ended;\n            },\n\n            setAttribute() {},\n\n            getConfig() {\n                return _config;\n            },\n\n            pause() {\n                paused = true;\n            },\n\n            play() {\n                paused = false;\n            },\n\n            setCurrentTime(time) {\n                frameIdx = time;\n            },\n\n            addEventListener(event, f) {\n                if (_eventNames.indexOf(event) !== -1) {\n                    if (!_eventHandlers[event]) {\n                        _eventHandlers[event] = [];\n                    }\n                    _eventHandlers[event].push(f);\n                }\n            },\n\n            clearEventHandlers() {\n                Object.keys(_eventHandlers).forEach((ind) => delete _eventHandlers[ind]);\n            },\n\n            setTopRight(topRight) {\n                _topRight.x = topRight.x;\n                _topRight.y = topRight.y;\n            },\n\n            getTopRight() {\n                return _topRight;\n            },\n\n            setCanvasSize(canvasSize) {\n                _canvasSize.x = canvasSize.x;\n                _canvasSize.y = canvasSize.y;\n            },\n\n            getCanvasSize() {\n                return _canvasSize;\n            },\n\n            getFrame() {\n                let frame;\n\n                if (!loaded) {\n                    return null;\n                }\n                if (!paused) {\n                    // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n                    frame = imgArray?.[frameIdx];\n                    if (frameIdx < (size - 1)) {\n                        frameIdx++;\n                    } else {\n                        setTimeout(() => {\n                            ended = true;\n                            publishEvent('ended', []);\n                        }, 0);\n                    }\n                }\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n                return frame;\n            },\n        };\n        return inputStream;\n    },\n};\n\nexport default inputStreamFactory;\n","/**\n * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\n */\nconst Tracer = {\n    searchDirections: [[0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [-1, -1], [-1, 0], [-1, 1]],\n    create(imageWrapper, labelWrapper) {\n        const imageData = imageWrapper.data;\n        const labelData = labelWrapper.data;\n        const { searchDirections } = this;\n        const width = imageWrapper.size.x;\n        let pos;\n\n        function trace(current, color, label, edgelabel) {\n            let i;\n            let y;\n            let x;\n\n            for (i = 0; i < searchDirections.length; i++) {\n                y = current.cy + searchDirections[current.dir][0];\n                x = current.cx + searchDirections[current.dir][1];\n                pos = y * width + x;\n                if ((imageData[pos] === color) && ((labelData[pos] === 0) || (labelData[pos] === label))) {\n                    labelData[pos] = label;\n                    current.cy = y;\n                    current.cx = x;\n                    return true;\n                }\n                if (labelData[pos] === 0) {\n                    labelData[pos] = edgelabel;\n                }\n                current.dir = (current.dir + 1) % 8;\n            }\n            return false;\n        }\n\n        function vertex2D(x, y, dir) {\n            return {\n                dir,\n                x,\n                y,\n                next: null,\n                prev: null,\n            };\n        }\n\n        function contourTracing(sy, sx, label, color, edgelabel) {\n            let Fv = null;\n            let Cv;\n            let P;\n            let ldir;\n            const current = {\n                cx: sx,\n                cy: sy,\n                dir: 0,\n            };\n\n            if (trace(current, color, label, edgelabel)) {\n                Fv = vertex2D(sx, sy, current.dir);\n                Cv = Fv;\n                ldir = current.dir;\n                P = vertex2D(current.cx, current.cy, 0);\n                P.prev = Cv;\n                Cv.next = P;\n                P.next = null;\n                Cv = P;\n\n                let totalPixelCount = imageWrapper.size.x * imageWrapper.size.y;\n                let pixelCounter = 0;\n                do {\n                    current.dir = (current.dir + 6) % 8;\n                    trace(current, color, label, edgelabel);\n                    if (ldir !== current.dir) {\n                        Cv.dir = current.dir;\n                        P = vertex2D(current.cx, current.cy, 0);\n                        P.prev = Cv;\n                        Cv.next = P;\n                        P.next = null;\n                        Cv = P;\n                    } else {\n                        Cv.dir = ldir;\n                        Cv.x = current.cx;\n                        Cv.y = current.cy;\n                    }\n                    ldir = current.dir;\n                } while ((current.cx !== sx || current.cy !== sy) && ++pixelCounter < totalPixelCount);\n                Fv.prev = Cv.prev;\n                Cv.prev.next = Fv;\n            }\n            return Fv;\n        }\n\n        return {\n            trace(current, color, label, edgelabel) {\n                return trace(current, color, label, edgelabel);\n            },\n            contourTracing(sy, sx, label, color, edgelabel) {\n                return contourTracing(sy, sx, label, color, edgelabel);\n            },\n        };\n    },\n};\n\nexport default (Tracer);\n","import Tracer from './tracer';\n\n/**\n * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\n */\nconst Rasterizer = {\n    createContour2D() {\n        return {\n            dir: null,\n            index: null,\n            firstVertex: null,\n            insideContours: null,\n            nextpeer: null,\n            prevpeer: null,\n        };\n    },\n    CONTOUR_DIR: {\n        CW_DIR: 0,\n        CCW_DIR: 1,\n        UNKNOWN_DIR: 2,\n    },\n    DIR: {\n        OUTSIDE_EDGE: -32767,\n        INSIDE_EDGE: -32766,\n    },\n    create(imageWrapper, labelWrapper) {\n        const imageData = imageWrapper.data;\n        const labelData = labelWrapper.data;\n        const width = imageWrapper.size.x;\n        const height = imageWrapper.size.y;\n        const tracer = Tracer.create(imageWrapper, labelWrapper);\n\n        return {\n            rasterize(depthlabel) {\n                let color;\n                let bc;\n                let lc;\n                let labelindex;\n                let cx;\n                let cy;\n                const colorMap = [];\n                let vertex;\n                let p;\n                let cc;\n                let sc;\n                let pos;\n                let connectedCount = 0;\n                let i;\n\n                for (i = 0; i < 400; i++) {\n                    colorMap[i] = 0;\n                }\n\n                colorMap[0] = imageData[0];\n                cc = null;\n                for (cy = 1; cy < height - 1; cy++) {\n                    labelindex = 0;\n                    bc = colorMap[0];\n                    for (cx = 1; cx < width - 1; cx++) {\n                        pos = cy * width + cx;\n                        if (labelData[pos] === 0) {\n                            color = imageData[pos];\n                            if (color !== bc) {\n                                if (labelindex === 0) {\n                                    lc = connectedCount + 1;\n                                    colorMap[lc] = color;\n                                    bc = color;\n                                    vertex = tracer.contourTracing(cy, cx, lc, color, Rasterizer.DIR.OUTSIDE_EDGE);\n                                    if (vertex !== null) {\n                                        connectedCount++;\n                                        labelindex = lc;\n                                        p = Rasterizer.createContour2D();\n                                        p.dir = Rasterizer.CONTOUR_DIR.CW_DIR;\n                                        p.index = labelindex;\n                                        p.firstVertex = vertex;\n                                        p.nextpeer = cc;\n                                        p.insideContours = null;\n                                        if (cc !== null) {\n                                            cc.prevpeer = p;\n                                        }\n                                        cc = p;\n                                    }\n                                } else {\n                                    vertex = tracer\n                                        .contourTracing(cy, cx, Rasterizer.DIR.INSIDE_EDGE, color, labelindex);\n                                    if (vertex !== null) {\n                                        p = Rasterizer.createContour2D();\n                                        p.firstVertex = vertex;\n                                        p.insideContours = null;\n                                        if (depthlabel === 0) {\n                                            p.dir = Rasterizer.CONTOUR_DIR.CCW_DIR;\n                                        } else {\n                                            p.dir = Rasterizer.CONTOUR_DIR.CW_DIR;\n                                        }\n                                        p.index = depthlabel;\n                                        sc = cc;\n                                        while ((sc !== null) && sc.index !== labelindex) {\n                                            sc = sc.nextpeer;\n                                        }\n                                        if (sc !== null) {\n                                            p.nextpeer = sc.insideContours;\n                                            if (sc.insideContours !== null) {\n                                                sc.insideContours.prevpeer = p;\n                                            }\n                                            sc.insideContours = p;\n                                        }\n                                    }\n                                }\n                            } else {\n                                labelData[pos] = labelindex;\n                            }\n                        } else if (labelData[pos] === Rasterizer.DIR.OUTSIDE_EDGE\n                                || labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) {\n                            labelindex = 0;\n                            if (labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) {\n                                bc = imageData[pos];\n                            } else {\n                                bc = colorMap[0];\n                            }\n                        } else {\n                            labelindex = labelData[pos];\n                            bc = colorMap[labelindex];\n                        }\n                    }\n                }\n                sc = cc;\n                while (sc !== null) {\n                    sc.index = depthlabel;\n                    sc = sc.nextpeer;\n                }\n                return {\n                    cc,\n                    count: connectedCount,\n                };\n            },\n            debug: {\n                drawContour(canvas, firstContour) {\n                    const ctx = canvas.getContext('2d');\n                    let pq = firstContour;\n                    let iq;\n                    let q;\n                    let p;\n\n                    ctx.strokeStyle = 'red';\n                    ctx.fillStyle = 'red';\n                    ctx.lineWidth = 1;\n\n                    if (pq !== null) {\n                        iq = pq.insideContours;\n                    } else {\n                        iq = null;\n                    }\n\n                    while (pq !== null) {\n                        if (iq !== null) {\n                            q = iq;\n                            iq = iq.nextpeer;\n                        } else {\n                            q = pq;\n                            pq = pq.nextpeer;\n                            if (pq !== null) {\n                                iq = pq.insideContours;\n                            } else {\n                                iq = null;\n                            }\n                        }\n\n                        switch (q.dir) {\n                            case Rasterizer.CONTOUR_DIR.CW_DIR:\n                                ctx.strokeStyle = 'red';\n                                break;\n                            case Rasterizer.CONTOUR_DIR.CCW_DIR:\n                                ctx.strokeStyle = 'blue';\n                                break;\n                            case Rasterizer.CONTOUR_DIR.UNKNOWN_DIR:\n                                ctx.strokeStyle = 'green';\n                                break;\n                        }\n\n                        p = q.firstVertex;\n                        ctx.beginPath();\n                        ctx.moveTo(p.x, p.y);\n                        do {\n                            p = p.next;\n                            ctx.lineTo(p.x, p.y);\n                        } while (p !== q.firstVertex);\n                        ctx.stroke();\n                    }\n                },\n            },\n        };\n    },\n};\n\nexport default Rasterizer;\n","/* eslint-disable no-param-reassign */\n/* eslint-disable no-bitwise */\n/* eslint-disable eqeqeq */\n/* @preserve ASM BEGIN */\n/**\n * Morphological skeletonization using iterative thinning algorithm.\n * Reduces binary images to single-pixel-wide skeletons while preserving topology.\n *\n * Memory layout in shared ArrayBuffer (4 regions of size²):\n * - Region 0: Working image (subImagePtr = 0)\n * - Region 1: Eroded result (erodedImagePtr = size²)\n * - Region 2: Temp/scratch space (tempImagePtr = 2*size²)\n * - Region 3: Final skeleton output (skelImagePtr = 3*size²)\n */\nfunction Skeletonizer(stdlib, foreign, buffer) {\n    'use asm';\n\n    var images = new stdlib.Uint8Array(buffer);\n    var size = foreign.size | 0;\n    var imul = stdlib.Math.imul;\n\n    /**\n     * Morphological erosion with 5-pixel cross structuring element.\n     * A pixel survives only if all 5 pixels in the cross pattern are set:\n     * top-left, top-right, center, bottom-left, bottom-right.\n     */\n    function erode(inImagePtr, outImagePtr) {\n        inImagePtr = inImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var v = 0;\n        var u = 0;\n        var sum = 0;\n        var yStart1 = 0;\n        var yStart2 = 0;\n        var xStart1 = 0;\n        var xStart2 = 0;\n        var offset = 0;\n\n        for (v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\n            offset = (offset + size) | 0;\n            for (u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\n                yStart1 = (offset - size) | 0;\n                yStart2 = (offset + size) | 0;\n                xStart1 = (u - 1) | 0;\n                xStart2 = (u + 1) | 0;\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\n                // Pixel survives erosion only if all 5 cross neighbors are set\n                if ((sum | 0) == (5 | 0)) {\n                    images[(outImagePtr + offset + u) | 0] = 1;\n                } else {\n                    images[(outImagePtr + offset + u) | 0] = 0;\n                }\n            }\n        }\n    }\n\n    // Pixel-wise subtraction: out = a - b (captures the \"peeled\" layer)\n    function subtract(aImagePtr, bImagePtr, outImagePtr) {\n        aImagePtr = aImagePtr | 0;\n        bImagePtr = bImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(outImagePtr + length) | 0] = ((images[(aImagePtr + length) | 0] | 0) - (images[(bImagePtr + length) | 0] | 0)) | 0;\n        }\n    }\n\n    // Pixel-wise OR: out = a | b (accumulates skeleton layers)\n    function bitwiseOr(aImagePtr, bImagePtr, outImagePtr) {\n        aImagePtr = aImagePtr | 0;\n        bImagePtr = bImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(outImagePtr + length) | 0] = ((images[(aImagePtr + length) | 0] | 0) | (images[(bImagePtr + length) | 0] | 0)) | 0;\n        }\n    }\n\n    // Counts non-zero pixels to detect when erosion is complete\n    function countNonZero(imagePtr) {\n        imagePtr = imagePtr | 0;\n\n        var sum = 0;\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            sum = ((sum | 0) + (images[(imagePtr + length) | 0] | 0)) | 0;\n        }\n\n        return (sum | 0);\n    }\n\n    // Fills image region with a constant value\n    function init(imagePtr, value) {\n        imagePtr = imagePtr | 0;\n        value = value | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(imagePtr + length) | 0] = value;\n        }\n    }\n\n    // Morphological dilation with 5-pixel cross - pixel is set if any neighbor is set\n    function dilate(inImagePtr, outImagePtr) {\n        inImagePtr = inImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var v = 0;\n        var u = 0;\n        var sum = 0;\n        var yStart1 = 0;\n        var yStart2 = 0;\n        var xStart1 = 0;\n        var xStart2 = 0;\n        var offset = 0;\n\n        for (v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\n            offset = (offset + size) | 0;\n            for (u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\n                yStart1 = (offset - size) | 0;\n                yStart2 = (offset + size) | 0;\n                xStart1 = (u - 1) | 0;\n                xStart2 = (u + 1) | 0;\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\n                if ((sum | 0) > (0 | 0)) {\n                    images[(outImagePtr + offset + u) | 0] = 1;\n                } else {\n                    images[(outImagePtr + offset + u) | 0] = 0;\n                }\n            }\n        }\n    }\n\n    // Copies image data from src to dst region\n    function memcpy(srcImagePtr, dstImagePtr) {\n        srcImagePtr = srcImagePtr | 0;\n        dstImagePtr = dstImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(dstImagePtr + length) | 0] = (images[(srcImagePtr + length) | 0] | 0);\n        }\n    }\n\n    /**\n     * Zeros out the border pixels of the image.\n     * First loop: handles top, left, and right edges simultaneously\n     * Second loop: handles bottom edge\n     */\n    function zeroBorder(imagePtr) {\n        imagePtr = imagePtr | 0;\n\n        var x = 0;\n        var y = 0;\n\n        for (x = 0; (x | 0) < ((size - 1) | 0); x = (x + 1) | 0) {\n            images[(imagePtr + x) | 0] = 0;\n            images[(imagePtr + y) | 0] = 0;\n            y = ((y + size) - 1) | 0;\n            images[(imagePtr + y) | 0] = 0;\n            y = (y + 1) | 0;\n        }\n        for (x = 0; (x | 0) < (size | 0); x = (x + 1) | 0) {\n            images[(imagePtr + y) | 0] = 0;\n            y = (y + 1) | 0;\n        }\n    }\n\n    /**\n     * Main skeletonization algorithm using iterative thinning:\n     * 1. Erode the working image\n     * 2. Dilate the eroded version\n     * 3. Subtract dilated from original (extracts \"peeled\" layer)\n     * 4. OR the peeled layer into skeleton accumulator\n     * 5. Copy eroded image back to working image\n     * 6. Repeat until working image is empty\n     *\n     * @returns {void} No return value - operates directly on shared buffer.\n     *   Input image is read from buffer offset 0 (subImagePtr).\n     *   Output skeleton is written to buffer offset 3*size² (skelImagePtr).\n     */\n    function skeletonize() {\n        var subImagePtr = 0;        // Region 0: Working image (input, offset = 0)\n        var erodedImagePtr = 0;     // Region 1: Eroded result (offset = size²)\n        var tempImagePtr = 0;       // Region 2: Scratch space (offset = 2*size²)\n        var skelImagePtr = 0;       // Region 3: Final skeleton (output, offset = 3*size²)\n        var sum = 0;\n        var done = 0;\n\n        // Calculate byte offsets for each region in the shared buffer\n        erodedImagePtr = imul(size, size) | 0;                  // Region 1: size² bytes in\n        tempImagePtr = (erodedImagePtr + erodedImagePtr) | 0;  // Region 2: 2*size² bytes in\n        skelImagePtr = (tempImagePtr + erodedImagePtr) | 0;    // Region 3: 3*size² bytes in\n\n        // Initialize skeleton accumulator to zero\n        init(skelImagePtr, 0);\n        zeroBorder(subImagePtr);\n\n        do {\n            erode(subImagePtr, erodedImagePtr);\n            dilate(erodedImagePtr, tempImagePtr);\n            subtract(subImagePtr, tempImagePtr, tempImagePtr);\n            bitwiseOr(skelImagePtr, tempImagePtr, skelImagePtr);\n            memcpy(erodedImagePtr, subImagePtr);\n            sum = countNonZero(subImagePtr) | 0;\n            done = ((sum | 0) == 0 | 0);\n        } while (!done);\n    }\n    return { skeletonize: skeletonize };\n}\n/* @preserve ASM END */\n\nexport default Skeletonizer;\n/* eslint-enable eqeqeq */\n","import { vec2, mat2 } from 'gl-matrix';\nimport ImageWrapper from '../common/image_wrapper';\nimport {\n    calculatePatchSize,\n    otsuThreshold,\n    hsv2rgb,\n    cluster,\n    topGeneric,\n    imageRef,\n    halfSample,\n    computeImageArea,\n} from '../common/cv_utils';\nimport ArrayHelper from '../common/array_helper';\nimport ImageDebug from '../common/image_debug';\nimport Rasterizer from './rasterizer';\nimport Tracer from './tracer';\nimport skeletonizer from './skeletonizer';\n\nlet _config;\nlet _currentImageWrapper;\nlet _skelImageWrapper;\nlet _subImageWrapper;\nlet _labelImageWrapper;\nlet _patchGrid;\nlet _patchLabelGrid;\nlet _imageToPatchGrid;\nlet _binaryImageWrapper;\nlet _patchSize;\nconst _canvasContainer = {\n    ctx: {\n        binary: null,\n    },\n    dom: {\n        binary: null,\n    },\n};\nconst _numPatches = { x: 0, y: 0 };\nlet _inputImageWrapper;\nlet _skeletonizer;\n\nfunction initBuffers() {\n    if (_config.halfSample) {\n        _currentImageWrapper = new ImageWrapper({\n            // eslint-disable-next-line no-bitwise\n            x: _inputImageWrapper.size.x / 2 | 0,\n            // eslint-disable-next-line no-bitwise\n            y: _inputImageWrapper.size.y / 2 | 0,\n        });\n    } else {\n        _currentImageWrapper = _inputImageWrapper;\n    }\n\n    _patchSize = calculatePatchSize(_config.patchSize, _currentImageWrapper.size);\n\n    // eslint-disable-next-line no-bitwise\n    _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0;\n    // eslint-disable-next-line no-bitwise\n    _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0;\n\n    _binaryImageWrapper = new ImageWrapper(_currentImageWrapper.size, undefined, Uint8Array, false);\n\n    _labelImageWrapper = new ImageWrapper(_patchSize, undefined, Array, true);\n\n    const skeletonImageData = new ArrayBuffer(64 * 1024);\n    _subImageWrapper = new ImageWrapper(_patchSize,\n        new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y));\n    _skelImageWrapper = new ImageWrapper(_patchSize,\n        new Uint8Array(skeletonImageData, _patchSize.x * _patchSize.y * 3, _patchSize.x * _patchSize.y),\n        undefined, true);\n    _skeletonizer = skeletonizer(\n        { Math, Uint8Array },\n        { size: _patchSize.x },\n        skeletonImageData,\n    );\n\n    _imageToPatchGrid = new ImageWrapper({\n        // eslint-disable-next-line no-bitwise\n        x: (_currentImageWrapper.size.x / _subImageWrapper.size.x) | 0,\n        // eslint-disable-next-line no-bitwise\n        y: (_currentImageWrapper.size.y / _subImageWrapper.size.y) | 0,\n    }, undefined, Array, true);\n    _patchGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, undefined, true);\n    _patchLabelGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, Int32Array, true);\n}\n\nfunction initCanvas() {\n    if (_config.useWorker || typeof document === 'undefined') {\n        return;\n    }\n    _canvasContainer.dom.binary = document.createElement('canvas');\n    _canvasContainer.dom.binary.className = 'binaryBuffer';\n    if (ENV.development && _config.debug.showCanvas === true) {\n        document.querySelector('#debug').appendChild(_canvasContainer.dom.binary);\n    }\n    const willReadFrequently = !!_config.willReadFrequently;\n    if (ENV.development && _config.debug?.showCanvas) {\n        console.warn('* initCanvas willReadFrequently', willReadFrequently, _config);\n    }\n    _canvasContainer.ctx.binary = _canvasContainer.dom.binary.getContext('2d', { willReadFrequently });\n    _canvasContainer.dom.binary.width = _binaryImageWrapper.size.x;\n    _canvasContainer.dom.binary.height = _binaryImageWrapper.size.y;\n}\n\n/**\n * Creates a bounding box which encloses all the given patches\n * @returns {Array} The minimal bounding box\n */\nfunction boxFromPatches(patches) {\n    let overAvg;\n    let i;\n    let j;\n    let patch;\n    let transMat;\n    let minx = _binaryImageWrapper.size.x;\n    let miny = _binaryImageWrapper.size.y;\n    let maxx = -_binaryImageWrapper.size.x;\n    let maxy = -_binaryImageWrapper.size.y;\n    let box;\n    let scale;\n\n    // draw all patches which are to be taken into consideration\n    overAvg = 0;\n    for (i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        overAvg += patch.rad;\n        if (ENV.development && _config.debug.showPatches) {\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: 'red' });\n        }\n    }\n\n    overAvg /= patches.length;\n    overAvg = (overAvg * 180 / Math.PI + 90) % 180 - 90;\n    if (overAvg < 0) {\n        overAvg += 180;\n    }\n\n    overAvg = (180 - overAvg) * Math.PI / 180;\n    transMat = mat2.copy(mat2.create(), [Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]);\n\n    // iterate over patches and rotate by angle\n    for (i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        for (j = 0; j < 4; j++) {\n            vec2.transformMat2(patch.box[j], patch.box[j], transMat);\n        }\n\n        if (ENV.development && _config.debug.boxFromPatches.showTransformed) {\n            ImageDebug.drawPath(patch.box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#99ff00', lineWidth: 2 });\n        }\n    }\n\n    // find bounding box\n    for (i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        for (j = 0; j < 4; j++) {\n            if (patch.box[j][0] < minx) {\n                minx = patch.box[j][0];\n            }\n            if (patch.box[j][0] > maxx) {\n                maxx = patch.box[j][0];\n            }\n            if (patch.box[j][1] < miny) {\n                miny = patch.box[j][1];\n            }\n            if (patch.box[j][1] > maxy) {\n                maxy = patch.box[j][1];\n            }\n        }\n    }\n\n    box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]];\n\n    if (ENV.development && _config.debug.boxFromPatches.showTransformedBox) {\n        ImageDebug.drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 });\n    }\n\n    scale = _config.halfSample ? 2 : 1;\n    // reverse rotation;\n    transMat = mat2.invert(transMat, transMat);\n    for (j = 0; j < 4; j++) {\n        vec2.transformMat2(box[j], box[j], transMat);\n    }\n\n    if (ENV.development && _config.debug.boxFromPatches.showBB) {\n        ImageDebug.drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 });\n    }\n\n    for (j = 0; j < 4; j++) {\n        vec2.scale(box[j], box[j], scale);\n    }\n\n    return box;\n}\n\n/**\n * Creates a binary image of the current image\n */\nfunction binarizeImage() {\n    otsuThreshold(_currentImageWrapper, _binaryImageWrapper);\n    _binaryImageWrapper.zeroBorder();\n    if (ENV.development && _config.debug.showCanvas) {\n        _binaryImageWrapper.show(_canvasContainer.dom.binary, 255);\n    }\n}\n\n/**\n * Iterate over the entire image\n * extract patches\n */\nfunction findPatches() {\n    let i;\n    let j;\n    let x;\n    let y;\n    let moments;\n    let patchesFound = [];\n    let rasterizer;\n    let rasterResult;\n    let patch;\n    for (i = 0; i < _numPatches.x; i++) {\n        for (j = 0; j < _numPatches.y; j++) {\n            x = _subImageWrapper.size.x * i;\n            y = _subImageWrapper.size.y * j;\n\n            // seperate parts\n            skeletonize(x, y);\n\n            // Rasterize, find individual bars\n            _skelImageWrapper.zeroBorder();\n            ArrayHelper.init(_labelImageWrapper.data, 0);\n            rasterizer = Rasterizer.create(_skelImageWrapper, _labelImageWrapper);\n            rasterResult = rasterizer.rasterize(0);\n\n            if (ENV.development && _config.debug.showLabels) {\n                _labelImageWrapper.overlay(_canvasContainer.dom.binary, Math.floor(360 / rasterResult.count),\n                    { x, y });\n            }\n\n            // calculate moments from the skeletonized patch\n            moments = _labelImageWrapper.moments(rasterResult.count);\n\n            // extract eligible patches\n            patchesFound = patchesFound.concat(describePatch(moments, [i, j], x, y));\n        }\n    }\n\n    if (ENV.development && _config.debug.showFoundPatches) {\n        for (i = 0; i < patchesFound.length; i++) {\n            patch = patchesFound[i];\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                { color: '#99ff00', lineWidth: 2 });\n        }\n    }\n\n    return patchesFound;\n}\n\n/**\n * Finds those connected areas which contain at least 6 patches\n * and returns them ordered DESC by the number of contained patches\n * @param {Number} maxLabel\n */\nfunction findBiggestConnectedAreas(maxLabel) {\n    let i;\n    let sum;\n    let labelHist = [];\n    let topLabels = [];\n\n    for (i = 0; i < maxLabel; i++) {\n        labelHist.push(0);\n    }\n    sum = _patchLabelGrid.data.length;\n    while (sum--) {\n        if (_patchLabelGrid.data[sum] > 0) {\n            labelHist[_patchLabelGrid.data[sum] - 1]++;\n        }\n    }\n\n    labelHist = labelHist.map((val, idx) => ({\n        val,\n        label: idx + 1,\n    }));\n\n    labelHist.sort((a, b) => b.val - a.val);\n\n    // extract top areas with at least 6 patches present\n    topLabels = labelHist.filter((el) => el.val >= 5);\n\n    return topLabels;\n}\n\n/**\n *\n */\nfunction findBoxes(topLabels, maxLabel) {\n    let i;\n    let j;\n    let sum;\n    const patches = [];\n    let patch;\n    let box;\n    const boxes = [];\n    const hsv = [0, 1, 1];\n    const rgb = [0, 0, 0];\n\n    for (i = 0; i < topLabels.length; i++) {\n        sum = _patchLabelGrid.data.length;\n        patches.length = 0;\n        while (sum--) {\n            if (_patchLabelGrid.data[sum] === topLabels[i].label) {\n                patch = _imageToPatchGrid.data[sum];\n                patches.push(patch);\n            }\n        }\n        box = boxFromPatches(patches);\n        if (box) {\n            boxes.push(box);\n\n            // draw patch-labels if requested\n            if (ENV.development && _config.debug.showRemainingPatchLabels) {\n                for (j = 0; j < patches.length; j++) {\n                    patch = patches[j];\n                    hsv[0] = (topLabels[i].label / (maxLabel + 1)) * 360;\n                    hsv2rgb(hsv, rgb);\n                    ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                        { color: `rgb(${rgb.join(',')})`, lineWidth: 2 });\n                }\n            }\n        }\n    }\n    return boxes;\n}\n\n/**\n * Find similar moments (via cluster)\n * @param {Object} moments\n */\nfunction similarMoments(moments) {\n    const clusters = cluster(moments, 0.90);\n    const topCluster = topGeneric(clusters, 1, (e) => e.getPoints().length);\n    let points = []; const\n        result = [];\n    if (topCluster.length === 1) {\n        points = topCluster[0].item.getPoints();\n        for (let i = 0; i < points.length; i++) {\n            result.push(points[i].point);\n        }\n    }\n    return result;\n}\n\nfunction skeletonize(x, y) {\n    _binaryImageWrapper.subImageAsCopy(_subImageWrapper, imageRef(x, y));\n    _skeletonizer.skeletonize();\n\n    // Show skeleton if requested\n    if (ENV.development && _config.debug.showSkeleton) {\n        _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, imageRef(x, y));\n    }\n}\n\n/**\n * Extracts and describes those patches which seem to contain a barcode pattern\n * @param {Array} moments\n * @param {Object} patchPos,\n * @param {Number} x\n * @param {Number} y\n * @returns {Array} list of patches\n */\nfunction describePatch(moments, patchPos, x, y) {\n    let k;\n    let avg;\n    const eligibleMoments = [];\n    let matchingMoments;\n    let patch;\n    const patchesFound = [];\n    const minComponentWeight = Math.ceil(_patchSize.x / 3);\n\n    if (moments.length >= 2) {\n        // only collect moments which's area covers at least minComponentWeight pixels.\n        for (k = 0; k < moments.length; k++) {\n            if (moments[k].m00 > minComponentWeight) {\n                eligibleMoments.push(moments[k]);\n            }\n        }\n\n        // if at least 2 moments are found which have at least minComponentWeights covered\n        if (eligibleMoments.length >= 2) {\n            matchingMoments = similarMoments(eligibleMoments);\n            avg = 0;\n            // determine the similarity of the moments\n            for (k = 0; k < matchingMoments.length; k++) {\n                avg += matchingMoments[k]?.rad ?? 0;\n            }\n\n            // Only two of the moments are allowed not to fit into the equation\n            // add the patch to the set\n            if (matchingMoments.length > 1\n                    && matchingMoments.length >= (eligibleMoments.length / 4) * 3\n                    && matchingMoments.length > moments.length / 4) {\n                avg /= matchingMoments.length;\n                patch = {\n                    index: patchPos[1] * _numPatches.x + patchPos[0],\n                    pos: {\n                        x,\n                        y,\n                    },\n                    box: [\n                        vec2.clone([x, y]),\n                        vec2.clone([x + _subImageWrapper.size.x, y]),\n                        vec2.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]),\n                        vec2.clone([x, y + _subImageWrapper.size.y]),\n                    ],\n                    moments: matchingMoments,\n                    rad: avg,\n                    vec: vec2.clone([Math.cos(avg), Math.sin(avg)]),\n                };\n                patchesFound.push(patch);\n            }\n        }\n    }\n    return patchesFound;\n}\n\n/**\n * finds patches which are connected and share the same orientation\n * @param {Object} patchesFound\n */\nfunction rasterizeAngularSimilarity(patchesFound) {\n    let label = 0;\n    const threshold = 0.95;\n    let currIdx = 0;\n    let j;\n    let patch;\n    const hsv = [0, 1, 1];\n    const rgb = [0, 0, 0];\n\n    function notYetProcessed() {\n        let i;\n        for (i = 0; i < _patchLabelGrid.data.length; i++) {\n            if (_patchLabelGrid.data[i] === 0 && _patchGrid.data[i] === 1) {\n                return i;\n            }\n        }\n        return _patchLabelGrid.data.length;\n    }\n\n    function trace(currentIdx) {\n        let x;\n        let y;\n        let currentPatch;\n        let idx;\n        let dir;\n        const current = {\n            x: currentIdx % _patchLabelGrid.size.x,\n            y: (currentIdx / _patchLabelGrid.size.x) | 0,\n        };\n        let similarity;\n\n        if (currentIdx < _patchLabelGrid.data.length) {\n            currentPatch = _imageToPatchGrid.data[currentIdx];\n            // assign label\n            _patchLabelGrid.data[currentIdx] = label;\n            for (dir = 0; dir < Tracer.searchDirections.length; dir++) {\n                y = current.y + Tracer.searchDirections[dir][0];\n                x = current.x + Tracer.searchDirections[dir][1];\n                idx = y * _patchLabelGrid.size.x + x;\n\n                // continue if patch empty\n                if (_patchGrid.data[idx] === 0) {\n                    _patchLabelGrid.data[idx] = Number.MAX_VALUE;\n                    // eslint-disable-next-line no-continue\n                    continue;\n                }\n\n                if (_patchLabelGrid.data[idx] === 0) {\n                    similarity = Math.abs(vec2.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec));\n                    if (similarity > threshold) {\n                        trace(idx);\n                    }\n                }\n            }\n        }\n    }\n\n    // prepare for finding the right patches\n    ArrayHelper.init(_patchGrid.data, 0);\n    ArrayHelper.init(_patchLabelGrid.data, 0);\n    ArrayHelper.init(_imageToPatchGrid.data, null);\n\n    for (j = 0; j < patchesFound.length; j++) {\n        patch = patchesFound[j];\n        _imageToPatchGrid.data[patch.index] = patch;\n        _patchGrid.data[patch.index] = 1;\n    }\n\n    // rasterize the patches found to determine area\n    _patchGrid.zeroBorder();\n\n    // eslint-disable-next-line no-cond-assign\n    while ((currIdx = notYetProcessed()) < _patchLabelGrid.data.length) {\n        label++;\n        trace(currIdx);\n    }\n\n    // draw patch-labels if requested\n    if (ENV.development && _config.debug.showPatchLabels) {\n        for (j = 0; j < _patchLabelGrid.data.length; j++) {\n            if (_patchLabelGrid.data[j] > 0 && _patchLabelGrid.data[j] <= label) {\n                patch = _imageToPatchGrid.data[j];\n                hsv[0] = (_patchLabelGrid.data[j] / (label + 1)) * 360;\n                hsv2rgb(hsv, rgb);\n                ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                    { color: `rgb(${rgb.join(',')})`, lineWidth: 2 });\n            }\n        }\n    }\n\n    return label;\n}\n\nexport default {\n    init(inputImageWrapper, config) {\n        _config = config;\n        _inputImageWrapper = inputImageWrapper;\n\n        initBuffers();\n        initCanvas();\n    },\n\n    locate() {\n        if (_config.halfSample) {\n            halfSample(_inputImageWrapper, _currentImageWrapper);\n        }\n\n        binarizeImage();\n        const patchesFound = findPatches();\n        // return unless 5% or more patches are found\n        if (patchesFound.length < _numPatches.x * _numPatches.y * 0.05) {\n            return null;\n        }\n\n        // rasterrize area by comparing angular similarity;\n        const maxLabel = rasterizeAngularSimilarity(patchesFound);\n        if (maxLabel < 1) {\n            return null;\n        }\n\n        // search for area with the most patches (biggest connected area)\n        const topLabels = findBiggestConnectedAreas(maxLabel);\n        if (topLabels.length === 0) {\n            return null;\n        }\n\n        const boxes = findBoxes(topLabels, maxLabel);\n        return boxes;\n    },\n\n    checkImageConstraints(inputStream, config) {\n        let patchSize;\n        let width = inputStream.getWidth();\n        let height = inputStream.getHeight();\n        const thisHalfSample = config.halfSample ? 0.5 : 1;\n        let area;\n\n        // calculate width and height based on area\n        if (inputStream.getConfig().area) {\n            area = computeImageArea(width, height, inputStream.getConfig().area);\n            inputStream.setTopRight({ x: area.sx, y: area.sy });\n            inputStream.setCanvasSize({ x: width, y: height });\n            width = area.sw;\n            height = area.sh;\n        }\n\n        const size = {\n            x: Math.floor(width * thisHalfSample),\n            y: Math.floor(height * thisHalfSample),\n        };\n\n        patchSize = calculatePatchSize(config.patchSize, size);\n        if (ENV.development && config.debug?.showPatchSize) {\n            console.log(`Patch-Size: ${JSON.stringify(patchSize)}`);\n        }\n\n        inputStream.setWidth(Math.max(Math.floor(Math.floor(size.x / patchSize.x) * (1 / thisHalfSample) * patchSize.x), patchSize.x));\n        inputStream.setHeight(Math.max(Math.floor(Math.floor(size.y / patchSize.y) * (1 / thisHalfSample) * patchSize.y), patchSize.y));\n\n        if ((inputStream.getWidth() % patchSize.x) === 0 && (inputStream.getHeight() % patchSize.y) === 0) {\n            return true;\n        }\n\n        throw new Error(`Image dimensions do not comply with the current settings: Width (${\n            width} )and height (${height\n        }) must a multiple of ${patchSize.x}`);\n    },\n};\n","import { QuaggaJSConfigObject } from \"../type-definitions/quagga\";\nimport ImageWrapper from \"common/image_wrapper\";\n\nexport class QuaggaContext {\n    public config?: QuaggaJSConfigObject;\n\n    public inputStream: any;\n\n    public framegrabber: any;\n\n    public inputImageWrapper?: ImageWrapper;\n\n    public stopped: boolean = false;\n\n    public boxSize: any;\n\n    public resultCollector: any;\n\n    public decoder: any;\n\n    public workerPool: any[] = [];\n\n    public onUIThread = true;\n\n    public readonly canvasContainer = new CanvasContainer();\n}\n\nexport class CanvasInfo {\n    image: any;\n    overlay: any;\n}\n\nexport class CanvasContainer {\n    public readonly ctx: CanvasInfo;\n    public readonly dom: CanvasInfo;\n\n    constructor() {\n        this.ctx = new CanvasInfo();\n        this.dom = new CanvasInfo();\n    }\n}\n","export default function getViewPort(target?: Element | string): Element | null {\n    if (typeof document === 'undefined') {\n        return null;\n    }\n\n    // Check if target is already a DOM element\n    if (target instanceof HTMLElement && target.nodeName && target.nodeType === 1) {\n        return target;\n    }\n    // Use '#interactive.viewport' as a fallback selector (backwards compatibility)\n    const selector = typeof target === 'string' ? target : '#interactive.viewport';\n    return document.querySelector(selector);\n}\n","import { vec2 } from 'gl-matrix';\nimport ImageWrapper from '../common/image_wrapper';\nimport type { InputStream } from '../input/input_stream/input_stream.d';\nimport BarcodeLocator from '../locator/barcode_locator';\n\n// TODO: need typescript def for BarcodeLocator\nexport default function initBuffers(\n    inputStream: InputStream,\n    imageWrapper: ImageWrapper | undefined,\n    locator: any,\n) {\n    const inputImageWrapper = imageWrapper || new ImageWrapper({\n        x: inputStream.getWidth(),\n        y: inputStream.getHeight(),\n        type: 'XYSize',\n    });\n\n    if (ENV.development && (locator as any).config?.debug?.showImageDetails) {\n        console.log(`image wrapper size ${inputImageWrapper.size}`);\n    }\n    const boxSize = [\n        vec2.clone([0, 0]),\n        vec2.clone([0, inputImageWrapper.size.y]),\n        vec2.clone([inputImageWrapper.size.x, inputImageWrapper.size.y]),\n        vec2.clone([inputImageWrapper.size.x, 0]),\n    ];\n    BarcodeLocator.init(inputImageWrapper, locator);\n    return { inputImageWrapper, boxSize };\n}\n","import { QuaggaContext, CanvasContainer } from 'QuaggaContext';\nimport getViewPort from './getViewPort';\nimport type { XYSize } from '../../type-definitions/quagga.d';\n\nfunction findOrCreateCanvas(selector: string, className: string) {\n    let canvas: HTMLCanvasElement | null = document.querySelector(selector);\n    if (!canvas) {\n        canvas = document.createElement('canvas');\n        canvas.className = className;\n    }\n    return canvas;\n}\n\nfunction getCanvasAndContext(selector: string, className: string, options: { willReadFrequently: boolean; debug?: any }) {\n    const canvas = findOrCreateCanvas(selector, className);\n    if (ENV.development && options.debug?.showImageDetails) {\n        console.warn('* initCanvas getCanvasAndContext');\n    }\n    const context = canvas.getContext('2d', { willReadFrequently: options.willReadFrequently });\n    return { canvas, context };\n}\n\nfunction initCanvases(canvasSize: XYSize, { willReadFrequently, debug }: { willReadFrequently: boolean; debug?: any }): CanvasContainer | null {\n    if (typeof document !== 'undefined') {\n        const image = getCanvasAndContext('canvas.imgBuffer', 'imgBuffer', { willReadFrequently, debug });\n        const overlay = getCanvasAndContext('canvas.drawingBuffer', 'drawingBuffer', { willReadFrequently, debug });\n\n        // eslint-disable-next-line no-multi-assign\n        image.canvas.width = overlay.canvas.width = canvasSize.x;\n        // eslint-disable-next-line no-multi-assign\n        image.canvas.height = overlay.canvas.height = canvasSize.y;\n\n        return {\n            dom: {\n                image: image.canvas,\n                overlay: overlay.canvas,\n            },\n            ctx: {\n                image: image.context,\n                overlay: overlay.context,\n            },\n        };\n    }\n    return null;\n}\n\nexport default function initCanvas(context: QuaggaContext): CanvasContainer | null {\n    const viewport = getViewPort(context?.config?.inputStream?.target);\n    const type = context?.config?.inputStream?.type;\n    if (!type) return null;\n    const container = initCanvases(\n        context.inputStream.getCanvasSize(),\n        {\n            willReadFrequently: !!context?.config?.inputStream?.willReadFrequently,\n            debug: context?.config?.locator?.debug\n        }\n    );\n    if (!container) return { dom: { image: null, overlay: null }, ctx: { image: null, overlay: null } };\n\n    const { dom } = container;\n    if (typeof document !== 'undefined') {\n        if (viewport) {\n            if (type === 'ImageStream' && !viewport.contains(dom.image)) {\n                viewport.appendChild(dom.image);\n            }\n            if (!viewport.contains(dom.overlay)) {\n                viewport.appendChild(dom.overlay);\n            }\n        }\n    }\n    return container;\n}\n","/* Worker functions. These are straight from the original quagga.js file.\n * Not presently used, as worker support is non-functional.  Keeping them around temporarily\n * to refer to until it is re-implemented. We may be able to fix/use some of this.\n */\n\nimport { QuaggaJSConfigObject, QuaggaJSReaderConfig } from \"../../type-definitions/quagga\";\n\n// TODO: need a typescript interface for FrameGrabber\n\ninterface QWorkerThread {\n    imageData: Uint8Array;\n    busy: boolean;\n    worker: Worker;\n}\n\nlet workerPool: Array<QWorkerThread> = [];\n\nexport function updateWorkers(frameGrabber: any) {\n    let availableWorker: QWorkerThread;\n    if (workerPool.length) {\n        availableWorker = workerPool.filter((workerThread) => !workerThread.busy)[0];\n        if (availableWorker) {\n            frameGrabber.attachData(availableWorker.imageData);\n            if (frameGrabber.grab()) {\n                availableWorker.busy = true;\n                availableWorker.worker.postMessage({\n                    cmd: 'process',\n                    imageData: availableWorker.imageData,\n                }, [availableWorker.imageData.buffer]);\n            }\n            return true;\n        } else {\n            return false;\n        }\n    }\n    return null;\n}\n\nfunction configForWorker(config: QuaggaJSConfigObject) {\n    return {\n        ...config,\n        inputStream: {\n            ...config.inputStream,\n            target: null,\n        },\n    };\n}\n\n// @ts-ignore\nfunction workerInterface(factory) {\n    if (factory) {\n        var Quagga = factory().default;\n        if (!Quagga) {\n// @ts-ignore\n            self.postMessage({ 'event': 'error', message: 'Quagga could not be created' });\n            return;\n        }\n    }\n// @ts-ignore\n    var imageWrapper;\n\n// @ts-ignore\n    function onProcessed(result) {\n        self.postMessage({\n            'event': 'processed',\n// @ts-ignore\n            imageData: imageWrapper.data,\n            result: result,\n// @ts-ignore\n        }, [imageWrapper.data.buffer]);\n    }\n\n    function workerInterfaceReady() {\n        self.postMessage({\n            'event': 'initialized',\n// @ts-ignore\n            imageData: imageWrapper.data,\n// @ts-ignore\n        }, [imageWrapper.data.buffer]);\n    }\n\n// @ts-ignore\n    self.onmessage = function (e) {\n        if (e.data.cmd === 'init') {\n            var config = e.data.config;\n            config.numOfWorkers = 0;\n            imageWrapper = new Quagga.ImageWrapper({\n                x: e.data.size.x,\n                y: e.data.size.y,\n            }, new Uint8Array(e.data.imageData));\n            Quagga.init(config, workerInterfaceReady, imageWrapper);\n            Quagga.onProcessed(onProcessed);\n        } else if (e.data.cmd === 'process') {\n// @ts-ignore\n            imageWrapper.data = new Uint8Array(e.data.imageData);\n            Quagga.start();\n        } else if (e.data.cmd === 'setReaders') {\n            Quagga.setReaders(e.data.readers);\n        } else if (e.data.cmd === 'registerReader') {\n            Quagga.registerReader(e.data.name, e.data.reader);\n        }\n    };\n}\n\nfunction generateWorkerBlob() {\n    var blob,\n        factorySource;\n\n    /* jshint ignore:start */\n    // @ts-ignore\n    if (typeof __factorySource__ !== 'undefined') {\n        // @ts-ignore\n        factorySource = __factorySource__; // eslint-disable-line no-undef\n    }\n    /* jshint ignore:end */\n\n    blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'],\n        { type: 'text/javascript' });\n\n    return window.URL.createObjectURL(blob);\n}\n\nexport function initWorker(config: QuaggaJSConfigObject, inputStream: any, cb: Function) {\n    const blobURL = generateWorkerBlob();\n    const worker = new Worker(blobURL);\n\n    const workerThread: QWorkerThread = {\n        worker,\n        imageData: new Uint8Array(inputStream.getWidth() * inputStream.getHeight()),\n        busy: true,\n    };\n\n    workerThread.worker.onmessage = function (e) {\n        if (e.data.event === 'initialized') {\n            URL.revokeObjectURL(blobURL);\n            workerThread.busy = false;\n            workerThread.imageData = new Uint8Array(e.data.imageData);\n            if (ENV.development) {\n                console.log('Worker initialized');\n            }\n            cb(workerThread);\n        } else if (e.data.event === 'processed') {\n            workerThread.imageData = new Uint8Array(e.data.imageData);\n            workerThread.busy = false;\n            // TODO: how to thread publishResult into here? TypeScript says it's not here. https://github.com/ericblade/quagga2/issues/466#issuecomment-1724248080 says it's necessary?\n            // @ts-ignore\n            if (typeof publishResult !== 'undefined') {\n                // @ts-ignore\n                publishResult(e.data.result, workerThread.imageData);\n            }\n        } else if (e.data.event === 'error') {\n            if (ENV.development) {\n                console.log('Worker error: ' + e.data.message);\n            }\n        }\n    };\n\n    workerThread.worker.postMessage({\n        cmd: 'init',\n        size: { x: inputStream.getWidth(), y: inputStream.getHeight() },\n        imageData: workerThread.imageData,\n        config: configForWorker(config),\n    }, [workerThread.imageData.buffer]);\n}\n\nexport function adjustWorkerPool(capacity: number, config?: QuaggaJSConfigObject, inputStream?: any, cb?: Function) {\n    const increaseBy = capacity - workerPool.length;\n    if (increaseBy === 0 && cb) {\n        cb();\n    } else if (increaseBy < 0) {\n        const workersToTerminate = workerPool.slice(increaseBy);\n        workersToTerminate.forEach(function (workerThread) {\n            workerThread.worker.terminate();\n            if (ENV.development) {\n                console.log('Worker terminated!');\n            }\n        });\n        workerPool = workerPool.slice(0, increaseBy);\n        if (cb) {\n            cb();\n        }\n    } else {\n        const workerInitialized = (workerThread: QWorkerThread) => {\n            workerPool.push(workerThread);\n            if (workerPool.length >= capacity && cb) {\n                cb();\n            }\n        };\n\n        if (config) {\n            for (let i = 0; i < increaseBy; i++) {\n                initWorker(config, inputStream, workerInitialized);\n            }\n        }\n    }\n}\n\nexport function setReaders(readers: Array<QuaggaJSReaderConfig>) {\n    workerPool.forEach((workerThread) => workerThread.worker.postMessage({ cmd: 'setReaders', readers }));\n}\n\nexport function registerReader(name: string, reader: any) {\n    workerPool.forEach((workerThread) => workerThread.worker.postMessage({ cmd: 'registerReader', name, reader }));\n}\n","import { InputStreamFactory } from 'input/input_stream/input_stream.d';\nimport type { InputStreamType } from '../../type-definitions/quagga.d';\n\n// TODO: need to create an InputStream typescript interface, so we don't have an \"any\" in the next line\nexport default function setupInputStream(type: InputStreamType = 'LiveStream', viewport: Element | null, inputStreamFactory: InputStreamFactory) {\n    switch (type) {\n        case 'VideoStream': {\n            const video = document.createElement('video');\n            return {\n                video,\n                inputStream: inputStreamFactory.createVideoStream(video),\n            };\n        }\n        case 'ImageStream':\n            return { inputStream: inputStreamFactory.createImageStream() };\n        case 'LiveStream': {\n            let video: HTMLVideoElement | null = null;\n            if (viewport) {\n                video = viewport.querySelector('video');\n                if (!video) {\n                    video = document.createElement('video');\n                    viewport.appendChild(video);\n                }\n            }\n            return {\n                video,\n                inputStream: inputStreamFactory.createLiveStream(video as HTMLVideoElement),\n            };\n        }\n        default:\n            console.error(`* setupInputStream invalid type ${type}`);\n            return { video: null, inputStream: null };\n    }\n}\n","/* eslint-disable no-param-reassign */\nimport type { Point } from '../../type-definitions/quagga.d';\n\nexport type Box = Array<[ number, number ]>;\n\nexport type Line = [ Point, Point ];\n\nexport function moveBox(box: Box, xOffset: number, yOffset: number): void {\n    let corner = box.length;\n    while (corner--) {\n        box[corner][0] += xOffset;\n        box[corner][1] += yOffset;\n    }\n}\n\nexport function moveLine(line: Line, xOffset: number, yOffset: number): void {\n    line[0].x += xOffset;\n    line[0].y += yOffset;\n    line[1].x += xOffset;\n    line[1].y += yOffset;\n}\n","import { vec2 } from 'gl-matrix';\nimport { QuaggaJSResultObject, QuaggaJSReaderConfig } from '../../type-definitions/quagga.d';\nimport Events from '../common/events';\nimport ImageWrapper from '../common/image_wrapper';\nimport BarcodeDecoder from '../decoder/barcode_decoder';\nimport CameraAccess from '../input/camera_access';\nimport FrameGrabber from '../input/frame_grabber.js';\nimport InputStream from '../input/input_stream/input_stream';\nimport BarcodeLocator from '../locator/barcode_locator';\nimport { QuaggaContext } from '../QuaggaContext';\nimport { BarcodeInfo } from '../reader/barcode_reader';\nimport _getViewPort from './getViewPort';\nimport _initBuffers from './initBuffers';\nimport _initCanvas from './initCanvas';\nimport * as QWorkers from './qworker';\nimport setupInputStream from './setupInputStream';\nimport { moveLine, moveBox } from './transform';\n\nexport default class Quagga {\n    context: QuaggaContext = new QuaggaContext();\n\n    initBuffers(imageWrapper?: ImageWrapper): void {\n        if (!this.context.config) {\n            return;\n        }\n        const { inputImageWrapper, boxSize } = _initBuffers(\n            this.context.inputStream,\n            imageWrapper,\n            this.context.config.locator,\n        );\n        this.context.inputImageWrapper = inputImageWrapper;\n        this.context.boxSize = boxSize;\n    }\n\n    initializeData(imageWrapper?: ImageWrapper): void {\n        if (!this.context.config) {\n            return;\n        }\n        this.initBuffers(imageWrapper);\n        this.context.decoder = BarcodeDecoder.create(this.context.config.decoder, this.context.inputImageWrapper);\n    }\n\n    getViewPort(): Element | null {\n        if (!this.context.config || !this.context.config.inputStream) {\n            return null;\n        }\n        const { target } = this.context.config.inputStream;\n        return _getViewPort(target);\n    }\n\n    ready(callback: () => void): void {\n        this.context.inputStream.play();\n        callback();\n    }\n\n    initCanvas(): void {\n        const container = _initCanvas(this.context);\n        if (!container) {\n            return;\n        }\n        const { ctx, dom } = container;\n        this.context.canvasContainer.dom.image = dom.image;\n        this.context.canvasContainer.dom.overlay = dom.overlay;\n        this.context.canvasContainer.ctx.image = ctx.image;\n        this.context.canvasContainer.ctx.overlay = ctx.overlay;\n    }\n\n    canRecord = (callback: () => void): void => {\n        if (!this.context.config) {\n            return;\n        }\n        BarcodeLocator.checkImageConstraints(this.context.inputStream, this.context.config?.locator);\n        this.initCanvas();\n        this.context.framegrabber = FrameGrabber.create(\n            this.context.inputStream,\n            this.context.canvasContainer.dom.image,\n        );\n\n        if (this.context.config.numOfWorkers === undefined) {\n            this.context.config.numOfWorkers = 0;\n        }\n\n        QWorkers.adjustWorkerPool(\n            this.context.config.numOfWorkers,\n            this.context.config,\n            this.context.inputStream,\n            () => {\n                if (this.context.config?.numOfWorkers === 0) {\n                    this.initializeData();\n                }\n                this.ready(callback);\n            },\n        );\n    };\n\n    initInputStream(callback: (err?: Error) => void): void {\n        if (!this.context.config || !this.context.config.inputStream) {\n            return;\n        }\n        const { type: inputType, constraints } = this.context.config.inputStream;\n        const { video, inputStream } = setupInputStream(inputType, this.getViewPort(), InputStream);\n\n        if (inputType === 'LiveStream' && video) {\n            CameraAccess.request(video, constraints)\n                .then(() => inputStream.trigger('canrecord'))\n                .catch((err) => callback(err));\n        }\n\n        if (inputStream) {\n            inputStream.setAttribute('preload', 'auto');\n            inputStream.setInputStream(this.context.config.inputStream);\n            inputStream.addEventListener('canrecord', this.canRecord.bind(undefined, callback));\n        }\n\n        this.context.inputStream = inputStream;\n    }\n\n    getBoundingBoxes(): Array<Array<Array<number>>> | null {\n        return this.context.config?.locate ? BarcodeLocator.locate()\n            : [[\n                vec2.clone(this.context.boxSize[0]),\n                vec2.clone(this.context.boxSize[1]),\n                vec2.clone(this.context.boxSize[2]),\n                vec2.clone(this.context.boxSize[3]),\n            ]] as unknown as Array<Array<Array<number>>>;\n    }\n\n    // TODO: need a typescript type for result here.\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    transformResult(result: any): void {\n        const topRight = this.context.inputStream.getTopRight();\n        const xOffset = topRight.x;\n        const yOffset = topRight.y;\n\n        if (xOffset === 0 && yOffset === 0) {\n            return;\n        }\n\n        if (result.barcodes) {\n            // TODO: BarcodeInfo may not be the right type here.\n            result.barcodes.forEach((barcode: BarcodeInfo) => this.transformResult(barcode));\n        }\n\n        if (result.line && result.line.length === 2) {\n            moveLine(result.line, xOffset, yOffset);\n        }\n\n        if (result.box) {\n            moveBox(result.box, xOffset, yOffset);\n        }\n\n        if (result.boxes && result.boxes.length > 0) {\n            for (let i = 0; i < result.boxes.length; i++) {\n                moveBox(result.boxes[i], xOffset, yOffset);\n            }\n        }\n    }\n\n    addResult(result: QuaggaJSResultObject, imageData: Array<number>): void {\n        if (!imageData || !this.context.resultCollector) {\n            return;\n        }\n\n        // TODO: Figure out what data structure holds a \"barcodes\" result, if any...\n        if (result.barcodes) {\n            result.barcodes.filter((barcode: QuaggaJSResultObject) => barcode.codeResult)\n                .forEach((barcode: QuaggaJSResultObject) => this.addResult(barcode, imageData));\n        } else if (result.codeResult) {\n            this.context.resultCollector.addResult(\n                imageData,\n                this.context.inputStream.getCanvasSize(),\n                result.codeResult,\n            );\n        }\n    }\n\n    // eslint-disable-next-line class-methods-use-this\n    hasCodeResult(result: QuaggaJSResultObject): boolean {\n        return !!(result && (result.barcodes\n            ? result.barcodes.some((barcode) => barcode.codeResult)\n            : result.codeResult));\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    publishResult(result: QuaggaJSResultObject | null = null, imageData?: any): void {\n        let resultToPublish: Array<QuaggaJSResultObject> | QuaggaJSResultObject | null = result;\n\n        if (result && this.context.onUIThread) {\n            this.transformResult(result);\n            this.addResult(result, imageData);\n            // @ts-ignore\n            resultToPublish = result?.barcodes?.length > 0 ? result.barcodes : result;\n        }\n\n        Events.publish('processed', resultToPublish as never);\n        if (this.hasCodeResult(result as QuaggaJSResultObject)) {\n            Events.publish('detected', resultToPublish as never);\n        }\n    }\n\n    async locateAndDecode(): Promise<void> {\n        const boxes = this.getBoundingBoxes();\n        if (boxes) {\n            const decodeResult = (await this.context.decoder.decodeFromBoundingBoxes(boxes)) || {};\n            decodeResult.boxes = boxes;\n            this.publishResult(decodeResult, this.context.inputImageWrapper?.data);\n        } else {\n            const imageResult = await this.context.decoder.decodeFromImage(this.context.inputImageWrapper);\n            if (imageResult) {\n                this.publishResult(imageResult, this.context.inputImageWrapper?.data);\n            } else {\n                this.publishResult();\n            }\n        }\n    }\n\n    update = (): void => {\n        if (this.context.onUIThread) {\n            const workersUpdated = QWorkers.updateWorkers(this.context.framegrabber);\n            if (!workersUpdated) {\n                this.context.framegrabber.attachData(this.context.inputImageWrapper?.data);\n                if (this.context.framegrabber.grab()) {\n                    if (!workersUpdated) {\n                        this.locateAndDecode();\n                    }\n                }\n            }\n        } else {\n            this.context.framegrabber.attachData(this.context.inputImageWrapper?.data);\n            this.context.framegrabber.grab();\n            this.locateAndDecode();\n        }\n    };\n\n    startContinuousUpdate(): void {\n        let next: number | null = null;\n        const delay = 1000 / (this.context.config?.frequency || 60);\n\n        this.context.stopped = false;\n        const { context } = this;\n\n        const newFrame = (timestamp: number) => {\n            next = next || timestamp;\n            if (!context.stopped) {\n                if (timestamp >= next) {\n                    next += delay;\n                    this.update();\n                }\n                window.requestAnimationFrame(newFrame);\n            }\n        };\n\n        newFrame(performance.now());\n    }\n\n    start(): void {\n        if (this.context.onUIThread && this.context.config?.inputStream?.type === 'LiveStream') {\n            this.startContinuousUpdate();\n        } else {\n            this.update();\n        }\n    }\n\n    async stop(): Promise<void> {\n        this.context.stopped = true;\n        QWorkers.adjustWorkerPool(0);\n        if (this.context.config?.inputStream && this.context.config.inputStream.type === 'LiveStream') {\n            await CameraAccess.release();\n            this.context.inputStream.clearEventHandlers();\n        }\n    }\n\n    setReaders(readers: Array<QuaggaJSReaderConfig>): void {\n        if (this.context.decoder) {\n            this.context.decoder.setReaders(readers);\n        }\n        QWorkers.setReaders(readers);\n    }\n\n    registerReader(name: string, reader: QuaggaJSReaderConfig): void {\n        BarcodeDecoder.registerReader(name, reader);\n        if (this.context.decoder) {\n            this.context.decoder.registerReader(name, reader);\n        }\n        QWorkers.registerReader(name, reader);\n    }\n}\n","import merge from 'lodash/merge';\nimport TypeDefs from './common/typedefs'; // eslint-disable-line no-unused-vars\nimport ImageWrapper from './common/image_wrapper';\nimport BarcodeDecoder from './decoder/barcode_decoder';\nimport * as Readers from './reader/index';\nimport Events from './common/events';\nimport CameraAccess from './input/camera_access';\nimport ImageDebug from './common/image_debug';\nimport ResultCollector from './analytics/result_collector';\nimport Config from './config/config';\n\nimport Quagga from './quagga/quagga';\n\nconst instance = new Quagga();\nconst _context = instance.context;\n\nconst QuaggaJSStaticInterface = {\n    init: function (config, cb, imageWrapper, quaggaInstance = instance) {\n        let promise;\n        if (!cb) {\n            promise = new Promise((resolve, reject) => {\n                cb = (err) => { err ? reject(err) : resolve(); };\n            });\n        }\n        quaggaInstance.context.config = merge({}, Config, config);\n        // TODO #179: pending restructure in Issue #179, we are temp disabling workers\n        if (quaggaInstance.context.config.numOfWorkers > 0) {\n            quaggaInstance.context.config.numOfWorkers = 0;\n        }\n        if (imageWrapper) {\n            quaggaInstance.context.onUIThread = false;\n            quaggaInstance.initializeData(imageWrapper);\n            if (cb) {\n                cb();\n            }\n        } else {\n            quaggaInstance.initInputStream(cb);\n        }\n        return promise;\n    },\n    start: function () {\n        return instance.start();\n    },\n    stop: function () {\n        return instance.stop();\n    },\n    pause: function () {\n        _context.stopped = true;\n    },\n    onDetected: function (callback) {\n        if (!callback || (typeof callback !== 'function' && (typeof callback !== 'object' || !callback.callback))) {\n            console.trace('* warning: Quagga.onDetected called with invalid callback, ignoring');\n            return;\n        }\n        Events.subscribe('detected', callback);\n    },\n    offDetected: function (callback) {\n        Events.unsubscribe('detected', callback);\n    },\n    onProcessed: function (callback) {\n        if (!callback || (typeof callback !== 'function' && (typeof callback !== 'object' || !callback.callback))) {\n            console.trace('* warning: Quagga.onProcessed called with invalid callback, ignoring');\n            return;\n        }\n        Events.subscribe('processed', callback);\n    },\n    offProcessed: function (callback) {\n        Events.unsubscribe('processed', callback);\n    },\n    setReaders: function (readers) {\n        if (!readers) {\n            console.trace('* warning: Quagga.setReaders called with no readers, ignoring');\n            return;\n        }\n        instance.setReaders(readers);\n    },\n    registerReader: function (name, reader) {\n        if (!name) {\n            console.trace('* warning: Quagga.registerReader called with no name, ignoring');\n            return;\n        }\n        if (!reader) {\n            console.trace('* warning: Quagga.registerReader called with no reader, ignoring');\n            return;\n        }\n        instance.registerReader(name, reader);\n    },\n    registerResultCollector: function (resultCollector) {\n        if (resultCollector && typeof resultCollector.addResult === 'function') {\n            _context.resultCollector = resultCollector;\n        }\n    },\n    get canvas() {\n        return _context.canvasContainer;\n    },\n    decodeSingle: function (config, resultCallback) {\n        const quaggaInstance = new Quagga();\n        config = merge({\n            inputStream: {\n                type: 'ImageStream',\n                sequence: false,\n                size: 800,\n                src: config.src,\n            },\n            numOfWorkers: (ENV.development && config.debug) ? 0 : 1,\n            locator: {\n                halfSample: false,\n            },\n        }, config);\n        // TODO #175: restructure worker support so that it will work with typescript using worker-loader\n        // https://webpack.js.org/loaders/worker-loader/\n        if (config.numOfWorkers > 0) {\n            config.numOfWorkers = 0;\n        }\n        // workers require Worker and Blob support presently, so if no Blob or Worker then set\n        // workers to 0.\n        if (config.numOfWorkers > 0 && (typeof Blob === 'undefined' || typeof Worker === 'undefined')) {\n            console.warn('* no Worker and/or Blob support - forcing numOfWorkers to 0');\n            config.numOfWorkers = 0;\n        }\n        return new Promise((resolve, reject) => {\n            try {\n                this.init(config, () => {\n                    Events.once('processed', (result) => {\n                        quaggaInstance.stop();\n                        if (resultCallback) {\n                            resultCallback.call(null, result);\n                        }\n                        resolve(result);\n                    }, true);\n                    quaggaInstance.start();\n                }, null, quaggaInstance);\n            } catch (err) {\n                reject(err);\n            }\n        });\n    },\n    // add the usually expected \"default\" for use with require, build step won't allow us to\n    // write to module.exports so do it here.\n    get default() {\n        return QuaggaJSStaticInterface;\n    },\n    Readers,\n    CameraAccess,\n    ImageDebug,\n    ImageWrapper,\n    ResultCollector,\n};\n\nexport default QuaggaJSStaticInterface;\n// export BarcodeReader and other utilities for external plugins\nexport {\n    BarcodeDecoder,\n    Readers,\n    CameraAccess,\n    ImageDebug,\n    ImageWrapper,\n    ResultCollector,\n};\n"],"sourceRoot":""}