(function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(require("get-pixels"), require("ndarray"), require("ndarray-linear-interpolate")); else if(typeof define === 'function' && define.amd) define(["get-pixels", "ndarray", "ndarray-linear-interpolate"], factory); else if(typeof exports === 'object') exports["Quagga"] = factory(require("get-pixels"), require("ndarray"), require("ndarray-linear-interpolate")); else root["Quagga"] = factory(root["get-pixels"], root["ndarray"], root["ndarray-linear-interpolate"]); })(this, function(__WEBPACK_EXTERNAL_MODULE_165__, __WEBPACK_EXTERNAL_MODULE_166__, __WEBPACK_EXTERNAL_MODULE_167__) { 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; /******/ /******/ // identity function for calling harmony imports with the correct context /******/ __webpack_require__.i = function(value) { return value; }; /******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { /******/ Object.defineProperty(exports, name, { /******/ configurable: false, /******/ enumerable: true, /******/ get: getter /******/ }); /******/ } /******/ }; /******/ /******/ // 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 = 168); /******/ }) /************************************************************************/ /******/ ([ /* 0 */ /***/ (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; /***/ }), /* 1 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _array_helper = __webpack_require__(3); var _array_helper2 = _interopRequireDefault(_array_helper); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function BarcodeReader(config, supplements) { this._row = []; this.config = config || {}; this.supplements = supplements; return this; } BarcodeReader.prototype._nextUnset = function (line, start) { var i; if (start === undefined) { start = 0; } for (i = start; i < line.length; i++) { if (!line[i]) { return i; } } return line.length; }; BarcodeReader.prototype._matchPattern = function (counter, code, maxSingleError) { var i, error = 0, singleError = 0, sum = 0, modulo = 0, barWidth, count, scaled; maxSingleError = maxSingleError || this.SINGLE_CODE_ERROR || 1; for (i = 0; i < counter.length; i++) { sum += counter[i]; modulo += code[i]; } if (sum < modulo) { return Number.MAX_VALUE; } barWidth = sum / modulo; maxSingleError *= barWidth; for (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; }; BarcodeReader.prototype._nextSet = function (line, offset) { var i; offset = offset || 0; for (i = offset; i < line.length; i++) { if (line[i]) { return i; } } return line.length; }; BarcodeReader.prototype._correctBars = function (counter, correction, indices) { var length = indices.length, tmp = 0; while (length--) { tmp = counter[indices[length]] * (1 - (1 - correction) / 2); if (tmp > 1) { counter[indices[length]] = tmp; } } }; BarcodeReader.prototype._matchTrace = function (cmpCounter, epsilon) { var counter = [], i, self = this, offset = self._nextSet(self._row), isWhite = !self._row[offset], counterPos = 0, bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0 }, error; if (cmpCounter) { for (i = 0; i < cmpCounter.length; i++) { counter.push(0); } for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { error = self._matchPattern(counter, cmpCounter); if (error < epsilon) { bestMatch.start = i - offset; bestMatch.end = i; bestMatch.counter = counter; return bestMatch; } else { return null; } } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } } else { counter.push(0); for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { counterPos++; counter.push(0); counter[counterPos] = 1; isWhite = !isWhite; } } } // if cmpCounter was not given bestMatch.start = offset; bestMatch.end = self._row.length - 1; bestMatch.counter = counter; return bestMatch; }; BarcodeReader.prototype.decodePattern = function (pattern) { var self = this, result; self._row = pattern; result = self._decode(); if (result === null) { self._row.reverse(); result = self._decode(); if (result) { result.direction = BarcodeReader.DIRECTION.REVERSE; result.start = self._row.length - result.start; result.end = self._row.length - result.end; } } else { result.direction = BarcodeReader.DIRECTION.FORWARD; } if (result) { result.format = self.FORMAT; } return result; }; BarcodeReader.prototype._matchRange = function (start, end, value) { var i; start = start < 0 ? 0 : start; for (i = start; i < end; i++) { if (this._row[i] !== value) { return false; } } return true; }; BarcodeReader.prototype._fillCounters = function (offset, end, isWhite) { var self = this, counterPos = 0, i, counters = []; isWhite = typeof isWhite !== 'undefined' ? isWhite : true; offset = typeof offset !== 'undefined' ? offset : self._nextUnset(self._row); end = end || self._row.length; counters[counterPos] = 0; for (i = offset; i < end; i++) { if (self._row[i] ^ isWhite) { counters[counterPos]++; } else { counterPos++; counters[counterPos] = 1; isWhite = !isWhite; } } return counters; }; BarcodeReader.prototype._toCounters = function (start, counter) { var self = this, numCounters = counter.length, end = self._row.length, isWhite = !self._row[start], i, counterPos = 0; _array_helper2.default.init(counter, 0); for (i = start; i < end; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { counterPos++; if (counterPos === numCounters) { break; } else { counter[counterPos] = 1; isWhite = !isWhite; } } } return counter; }; Object.defineProperty(BarcodeReader.prototype, "FORMAT", { value: 'unknown', writeable: false }); BarcodeReader.DIRECTION = { FORWARD: 1, REVERSE: -1 }; BarcodeReader.Exception = { StartNotFoundException: "Start-Info was not found!", CodeNotFoundException: "Code could not be found!", PatternNotFoundException: "Pattern could not be found!" }; BarcodeReader.CONFIG_KEYS = {}; exports.default = BarcodeReader; /***/ }), /* 2 */ /***/ (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; /***/ }), /* 3 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; exports.default = { init: function init(arr, val) { var l = arr.length; while (l--) { arr[l] = val; } }, /** * Shuffles the content of an array * @return {Array} the array itself shuffled */ shuffle: function shuffle(arr) { var i = arr.length - 1, j, x; for (i; i >= 0; i--) { j = Math.floor(Math.random() * i); x = arr[i]; arr[i] = arr[j]; arr[j] = x; } return arr; }, toPointList: function toPointList(arr) { var i, j, row = [], rows = []; for (i = 0; i < arr.length; i++) { row = []; for (j = 0; j < arr[i].length; j++) { row[j] = arr[i][j]; } rows[i] = "[" + row.join(",") + "]"; } return "[" + rows.join(",\r\n") + "]"; }, /** * returns the elements which's score is bigger than the threshold * @return {Array} the reduced array */ threshold: function threshold(arr, _threshold, scoreFunc) { var i, queue = []; for (i = 0; i < arr.length; i++) { if (scoreFunc.apply(arr, [arr[i]]) >= _threshold) { queue.push(arr[i]); } } return queue; }, maxIndex: function maxIndex(arr) { var i, max = 0; for (i = 0; i < arr.length; i++) { if (arr[i] > arr[max]) { max = i; } } return max; }, max: function max(arr) { var i, max = 0; for (i = 0; i < arr.length; i++) { if (arr[i] > max) { max = arr[i]; } } return max; }, sum: function sum(arr) { var length = arr.length, sum = 0; while (length--) { sum += arr[length]; } return sum; } }; /***/ }), /* 4 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _merge2 = __webpack_require__(28); var _merge3 = _interopRequireDefault(_merge2); var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _barcode_reader = __webpack_require__(1); var _barcode_reader2 = _interopRequireDefault(_barcode_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function EANReader(opts, supplements) { opts = (0, _merge3.default)(getDefaulConfig(), opts); _barcode_reader2.default.call(this, opts, supplements); } function getDefaulConfig() { var config = {}; Object.keys(EANReader.CONFIG_KEYS).forEach(function (key) { config[key] = EANReader.CONFIG_KEYS[key].default; }); return config; } var properties = { CODE_L_START: { value: 0 }, CODE_G_START: { value: 10 }, START_PATTERN: { value: [1, 1, 1] }, STOP_PATTERN: { value: [1, 1, 1] }, MIDDLE_PATTERN: { value: [1, 1, 1, 1, 1] }, EXTENSION_START_PATTERN: { value: [1, 1, 2] }, CODE_PATTERN: { value: [[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]] }, CODE_FREQUENCY: { value: [0, 11, 13, 14, 19, 25, 28, 21, 22, 26] }, SINGLE_CODE_ERROR: { value: 0.70 }, AVG_CODE_ERROR: { value: 0.48 }, FORMAT: { value: "ean_13", writeable: false } }; EANReader.prototype = Object.create(_barcode_reader2.default.prototype, properties); EANReader.prototype.constructor = EANReader; EANReader.prototype._decodeCode = function (start, coderange) { var counter = [0, 0, 0, 0], i, self = this, offset = start, isWhite = !self._row[offset], counterPos = 0, bestMatch = { error: Number.MAX_VALUE, code: -1, start: start, end: start }, code, error; if (!coderange) { coderange = self.CODE_PATTERN.length; } for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { for (code = 0; code < coderange; code++) { error = self._matchPattern(counter, self.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } bestMatch.end = i; if (bestMatch.error > self.AVG_CODE_ERROR) { return null; } return bestMatch; } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return null; }; EANReader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder, epsilon) { var counter = [], self = this, i, counterPos = 0, bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0 }, error, j, sum; if (!offset) { offset = self._nextSet(self._row); } if (isWhite === undefined) { isWhite = false; } if (tryHarder === undefined) { tryHarder = true; } if (epsilon === undefined) { epsilon = self.AVG_CODE_ERROR; } for (i = 0; i < pattern.length; i++) { counter[i] = 0; } for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { sum = 0; for (j = 0; j < counter.length; j++) { sum += counter[j]; } error = self._matchPattern(counter, pattern); if (error < epsilon) { bestMatch.error = error; bestMatch.start = i - sum; bestMatch.end = i; return bestMatch; } if (tryHarder) { for (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; }; EANReader.prototype._findStart = function () { var self = this, leadingWhitespaceStart, offset = self._nextSet(self._row), startInfo; while (!startInfo) { startInfo = self._findPattern(self.START_PATTERN, offset); if (!startInfo) { return null; } leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start); if (leadingWhitespaceStart >= 0) { if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) { return startInfo; } } offset = startInfo.end; startInfo = null; } }; EANReader.prototype._verifyTrailingWhitespace = function (endInfo) { var self = this, trailingWhitespaceEnd; trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start); if (trailingWhitespaceEnd < self._row.length) { if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { return endInfo; } } return null; }; EANReader.prototype._findEnd = function (offset, isWhite) { var self = this, endInfo = self._findPattern(self.STOP_PATTERN, offset, isWhite, false); return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null; }; EANReader.prototype._calculateFirstDigit = function (codeFrequency) { var i, self = this; for (i = 0; i < self.CODE_FREQUENCY.length; i++) { if (codeFrequency === self.CODE_FREQUENCY[i]) { return i; } } return null; }; EANReader.prototype._decodePayload = function (code, result, decodedCodes) { var i, self = this, codeFrequency = 0x0, firstDigit; for (i = 0; i < 6; i++) { code = self._decodeCode(code.end); if (!code) { return null; } if (code.code >= self.CODE_G_START) { code.code = code.code - self.CODE_G_START; codeFrequency |= 1 << 5 - i; } else { codeFrequency |= 0 << 5 - i; } result.push(code.code); decodedCodes.push(code); } firstDigit = self._calculateFirstDigit(codeFrequency); if (firstDigit === null) { return null; } result.unshift(firstDigit); code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); if (code === null) { return null; } decodedCodes.push(code); for (i = 0; i < 6; i++) { code = self._decodeCode(code.end, self.CODE_G_START); if (!code) { return null; } decodedCodes.push(code); result.push(code.code); } return code; }; EANReader.prototype._decode = function () { var startInfo, self = this, code, result = [], decodedCodes = [], resultInfo = {}; startInfo = self._findStart(); if (!startInfo) { return null; } code = { code: startInfo.code, start: startInfo.start, end: startInfo.end }; decodedCodes.push(code); code = self._decodePayload(code, result, decodedCodes); if (!code) { return null; } code = self._findEnd(code.end, false); if (!code) { return null; } decodedCodes.push(code); // Checksum if (!self._checksum(result)) { return null; } if (this.supplements.length > 0) { var ext = this._decodeExtensions(code.end); if (!ext) { return null; } var lastCode = ext.decodedCodes[ext.decodedCodes.length - 1], endInfo = { start: lastCode.start + ((lastCode.end - lastCode.start) / 2 | 0), end: lastCode.end }; if (!self._verifyTrailingWhitespace(endInfo)) { return null; } resultInfo = { supplement: ext, code: result.join("") + ext.code }; } return _extends({ code: result.join(""), start: startInfo.start, end: code.end, codeset: "", startInfo: startInfo, decodedCodes: decodedCodes }, resultInfo); }; EANReader.prototype._decodeExtensions = function (offset) { var i, start = this._nextSet(this._row, offset), startInfo = this._findPattern(this.EXTENSION_START_PATTERN, start, false, false), result; if (startInfo === null) { return null; } for (i = 0; i < this.supplements.length; i++) { result = this.supplements[i].decode(this._row, startInfo.end); if (result !== null) { return { code: result.code, start: start, startInfo: startInfo, end: result.end, codeset: "", decodedCodes: result.decodedCodes }; } } return null; }; EANReader.prototype._checksum = function (result) { var sum = 0, i; for (i = result.length - 2; i >= 0; i -= 2) { sum += result[i]; } sum *= 3; for (i = result.length - 1; i >= 0; i -= 2) { sum += result[i]; } return sum % 10 === 0; }; EANReader.CONFIG_KEYS = { supplements: { 'type': 'arrayOf(string)', 'default': [], 'description': 'Allowed extensions to be decoded (2 and/or 5)' } }; exports.default = EANReader; /***/ }), /* 5 */ /***/ (function(module, exports, __webpack_require__) { var freeGlobal = __webpack_require__(38); /** 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; /***/ }), /* 6 */ /***/ (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; /***/ }), /* 7 */ /***/ (function(module, exports) { module.exports = clone /** * Creates a new vec2 initialized with values from an existing vector * * @param {vec2} a vector to clone * @returns {vec2} a new 2D vector */ function clone(a) { var out = new Float32Array(2) out[0] = a[0] out[1] = a[1] return out } /***/ }), /* 8 */ /***/ (function(module, exports, __webpack_require__) { var Symbol = __webpack_require__(11), getRawTag = __webpack_require__(118), objectToString = __webpack_require__(145); /** `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; /***/ }), /* 9 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; exports.default = { drawRect: function drawRect(pos, size, ctx, style) { ctx.strokeStyle = style.color; ctx.fillStyle = style.color; ctx.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), data = canvasData.data, imageDataPos = imageData.length, canvasDataPos = data.length, value; if (canvasDataPos / imageDataPos !== 4) { return false; } while (imageDataPos--) { value = imageData[imageDataPos]; data[--canvasDataPos] = 255; data[--canvasDataPos] = value; data[--canvasDataPos] = value; data[--canvasDataPos] = value; } ctx.putImageData(canvasData, 0, 0); return true; } }; /***/ }), /* 10 */ /***/ (function(module, exports, __webpack_require__) { var listCacheClear = __webpack_require__(132), listCacheDelete = __webpack_require__(133), listCacheGet = __webpack_require__(134), listCacheHas = __webpack_require__(135), listCacheSet = __webpack_require__(136); /** * 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; /***/ }), /* 11 */ /***/ (function(module, exports, __webpack_require__) { var root = __webpack_require__(5); /** Built-in value references. */ var Symbol = root.Symbol; module.exports = Symbol; /***/ }), /* 12 */ /***/ (function(module, exports, __webpack_require__) { var eq = __webpack_require__(17); /** * 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; /***/ }), /* 13 */ /***/ (function(module, exports, __webpack_require__) { var isArray = __webpack_require__(2), isKey = __webpack_require__(129), stringToPath = __webpack_require__(153), toString = __webpack_require__(164); /** * 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; /***/ }), /* 14 */ /***/ (function(module, exports, __webpack_require__) { var isKeyable = __webpack_require__(130); /** * 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; /***/ }), /* 15 */ /***/ (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; /***/ }), /* 16 */ /***/ (function(module, exports, __webpack_require__) { var getNative = __webpack_require__(22); /* Built-in method references that are verified to be native. */ var nativeCreate = getNative(Object, 'create'); module.exports = nativeCreate; /***/ }), /* 17 */ /***/ (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; /***/ }), /* 18 */ /***/ (function(module, exports, __webpack_require__) { var baseIsArguments = __webpack_require__(95), isObjectLike = __webpack_require__(6); /** 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; /***/ }), /* 19 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; exports._dimensionsConverters = exports.ERODE = exports.DILATE = exports.Tracer = undefined; exports.imageRef = imageRef; exports.computeIntegralImage2 = computeIntegralImage2; exports.computeIntegralImage = computeIntegralImage; exports.thresholdImage = thresholdImage; exports.computeHistogram = computeHistogram; exports.sharpenLine = sharpenLine; exports.determineOtsuThreshold = determineOtsuThreshold; exports.otsuThreshold = otsuThreshold; exports.computeBinaryImage = computeBinaryImage; exports.cluster = cluster; exports.dilate = dilate; exports.erode = erode; exports.subtract = subtract; exports.bitwiseOr = bitwiseOr; exports.countNonZero = countNonZero; exports.topGeneric = topGeneric; exports.grayArrayFromImage = grayArrayFromImage; exports.grayArrayFromContext = grayArrayFromContext; exports.grayAndHalfSampleFromCanvasData = grayAndHalfSampleFromCanvasData; exports.computeGray = computeGray; exports.loadImageArray = loadImageArray; exports.halfSample = halfSample; exports.hsv2rgb = hsv2rgb; exports._computeDivisors = _computeDivisors; exports.calculatePatchSize = calculatePatchSize; exports._parseCSSDimensionValues = _parseCSSDimensionValues; exports.computeImageArea = computeImageArea; var _cluster = __webpack_require__(53); var _cluster2 = _interopRequireDefault(_cluster); var _array_helper = __webpack_require__(3); var _array_helper2 = _interopRequireDefault(_array_helper); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var vec2 = { clone: __webpack_require__(7) }; var vec3 = { clone: __webpack_require__(82) }; /** * @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.clone([this.x, this.y]); }, toVec3: function toVec3() { return vec3.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, posA = 0, posB = 0, posC = 0, posD = 0, x, 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) { targetWrapper = imageWrapper; } var imageData = imageWrapper.data, length = imageData.length, targetData = targetWrapper.data; while (length--) { targetData[length] = imageData[length] < threshold ? 1 : 0; } }; function computeHistogram(imageWrapper, bitsPerPixel) { if (!bitsPerPixel) { bitsPerPixel = 8; } var imageData = imageWrapper.data, length = imageData.length, bitShift = 8 - bitsPerPixel, bucketCnt = 1 << bitsPerPixel, hist = new Int32Array(bucketCnt); while (length--) { hist[imageData[length] >> bitShift]++; } return hist; }; function sharpenLine(line) { var i, length = line.length, left = line[0], center = line[1], right; for (i = 1; i < length - 1; i++) { right = line[i + 1]; // -1 4 -1 kernel line[i - 1] = center * 2 - left - right & 255; left = center; center = right; } return line; }; function determineOtsuThreshold(imageWrapper, bitsPerPixel) { if (!bitsPerPixel) { bitsPerPixel = 8; } var hist, threshold, bitShift = 8 - bitsPerPixel; function px(init, end) { var sum = 0, i; for (i = init; i <= end; i++) { sum += hist[i]; } return sum; } function mx(init, end) { var i, sum = 0; for (i = init; i <= end; i++) { sum += i * hist[i]; } return sum; } function determineThreshold() { var vet = [0], p1, p2, p12, k, m1, m2, m12, max = (1 << bitsPerPixel) - 1; hist = computeHistogram(imageWrapper, bitsPerPixel); for (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_helper2.default.maxIndex(vet); } 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) { 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, v, u, kernel = 3, A, B, C, D, avg, 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 cluster(points, threshold, property) { var i, k, cluster, point, clusters = []; if (!property) { property = "rad"; } function addToCluster(newPoint) { var found = false; for (k = 0; k < clusters.length; k++) { cluster = clusters[k]; if (cluster.fits(newPoint)) { cluster.add(newPoint); found = true; } } return found; } // iterate over each cloud for (i = 0; i < points.length; i++) { point = _cluster2.default.createPoint(points[i], i, property); if (!addToCluster(point)) { clusters.push(_cluster2.default.create(point, threshold)); } } return clusters; }; var Tracer = exports.Tracer = { trace: function trace(points, vec) { var iteration, maxIterations = 10, top = [], result = [], centerPos = 0, currentPos = 0; function trace(idx, forward) { var from, to, toIdx, predictedPos, thresholdX = 1, thresholdY = Math.abs(vec[1] / 10), 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; } else { return false; } } // check if the next index is within the vec specifications // if not, check as long as the threshold is met 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]; 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]); while ((currentPos = trace(currentPos, true)) !== null) { top.push(points[currentPos]); } if (centerPos > 0) { currentPos = centerPos; while ((currentPos = trace(currentPos, false)) !== null) { top.push(points[currentPos]); } } if (top.length > result.length) { result = top; } } return result; } }; var DILATE = exports.DILATE = 1; var ERODE = exports.ERODE = 2; function dilate(inImageWrapper, outImageWrapper) { var v, u, inImageData = inImageWrapper.data, outImageData = outImageWrapper.data, height = inImageWrapper.size.y, width = inImageWrapper.size.x, sum, yStart1, yStart2, xStart1, 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, u, inImageData = inImageWrapper.data, outImageData = outImageWrapper.data, height = inImageWrapper.size.y, width = inImageWrapper.size.x, sum, yStart1, yStart2, xStart1, 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 subtract(aImageWrapper, bImageWrapper, resultImageWrapper) { if (!resultImageWrapper) { resultImageWrapper = aImageWrapper; } var length = aImageWrapper.data.length, aImageData = aImageWrapper.data, bImageData = bImageWrapper.data, cImageData = resultImageWrapper.data; while (length--) { cImageData[length] = aImageData[length] - bImageData[length]; } }; function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) { if (!resultImageWrapper) { resultImageWrapper = aImageWrapper; } var length = aImageWrapper.data.length, aImageData = aImageWrapper.data, bImageData = bImageWrapper.data, cImageData = resultImageWrapper.data; while (length--) { cImageData[length] = aImageData[length] || bImageData[length]; } }; function countNonZero(imageWrapper) { var length = imageWrapper.data.length, data = imageWrapper.data, sum = 0; while (length--) { sum += data[length]; } return sum; }; function topGeneric(list, top, scoreFunc) { var i, minIdx = 0, min = 0, queue = [], score, hit, 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++) { 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 = topRowIdx + 2; bottomRowIdx = bottomRowIdx + 2; } topRowIdx = topRowIdx + inWidth; bottomRowIdx = bottomRowIdx + inWidth; } }; function computeGray(imageData, outArray, config) { var l = imageData.length / 4 | 0, i, singleChannel = config && config.singleChannel === true; if (singleChannel) { for (i = 0; i < l; i++) { outArray[i] = imageData[i * 4 + 0]; } } else { for (i = 0; i < l; i++) { outArray[i] = 0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2]; } } }; function loadImageArray(src, callback, canvas) { if (!canvas) { canvas = document.createElement('canvas'); } var img = new Image(); img.callback = callback; img.onload = function () { canvas.width = this.width; canvas.height = this.height; var ctx = canvas.getContext('2d'); ctx.drawImage(this, 0, 0); var array = new Uint8Array(this.width * this.height); ctx.drawImage(this, 0, 0); var data = ctx.getImageData(0, 0, this.width, this.height).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 = topRowIdx + 2; bottomRowIdx = bottomRowIdx + 2; } topRowIdx = topRowIdx + inWidth; bottomRowIdx = bottomRowIdx + inWidth; } }; function hsv2rgb(hsv, rgb) { var h = hsv[0], s = hsv[1], v = hsv[2], c = v * s, x = c * (1 - Math.abs(h / 60 % 2 - 1)), m = v - c, r = 0, g = 0, b = 0; rgb = rgb || [0, 0, 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; } rgb[0] = (r + m) * 255 | 0; rgb[1] = (g + m) * 255 | 0; rgb[2] = (b + m) * 255 | 0; return rgb; }; function _computeDivisors(n) { var largeDivisors = [], divisors = [], i; for (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, j = 0, 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), divisorsY = _computeDivisors(imgSize.y), wideSide = Math.max(imgSize.x, imgSize.y), common = _computeIntersection(divisorsX, divisorsY), nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80], nrOfPatchesMap = { "x-small": 5, "small": 4, "medium": 3, "large": 2, "x-large": 1 }, nrOfPatchesIdx = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium, nrOfPatches = nrOfPatchesList[nrOfPatchesIdx], desiredPatchSize = Math.floor(wideSide / nrOfPatches), optimalPatchSize; function findPatchSizeForDivisors(divisors) { var i = 0, 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 = exports._dimensionsConverters = { top: function top(dimension, context) { if (dimension.unit === "%") { return Math.floor(context.height * (dimension.value / 100)); } }, right: function right(dimension, context) { if (dimension.unit === "%") { return Math.floor(context.width - context.width * (dimension.value / 100)); } }, bottom: function bottom(dimension, context) { if (dimension.unit === "%") { return Math.floor(context.height - context.height * (dimension.value / 100)); } }, left: function left(dimension, context) { if (dimension.unit === "%") { return Math.floor(context.width * (dimension.value / 100)); } } }; function computeImageArea(inputWidth, inputHeight, area) { var context = { width: inputWidth, height: inputHeight }; var parsedArea = Object.keys(area).reduce(function (result, key) { var value = area[key], parsed = _parseCSSDimensionValues(value), calculated = _dimensionsConverters[key](parsed, context); result[key] = calculated; return result; }, {}); return { sx: parsedArea.left, sy: parsedArea.top, sw: parsedArea.right - parsedArea.left, sh: parsedArea.bottom - parsedArea.top }; }; /***/ }), /* 20 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _subImage = __webpack_require__(56); var _subImage2 = _interopRequireDefault(_subImage); var _cv_utils = __webpack_require__(19); var _array_helper = __webpack_require__(3); var _array_helper2 = _interopRequireDefault(_array_helper); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var vec2 = { clone: __webpack_require__(7) }; /** * Represents a basic image combining the data and size. * In addition, some methods for manipulation are contained. * @param size {x,y} The size of the image in pixel * @param data {Array} If given, a flat array containing the pixel data * @param ArrayType {Type} If given, the desired DataType of the Array (may be typed/non-typed) * @param initialize {Boolean} Indicating if the array should be initialized on creation. * @returns {ImageWrapper} */ function ImageWrapper(size, data, ArrayType, initialize) { if (!data) { if (ArrayType) { this.data = new ArrayType(size.x * size.y); if (ArrayType === Array && initialize) { _array_helper2.default.init(this.data, 0); } } else { this.data = new Uint8Array(size.x * size.y); if (Uint8Array === Array && initialize) { _array_helper2.default.init(this.data, 0); } } } else { this.data = data; } this.size = size; } /** * tests if a position is within the image with a given offset * @param imgRef {x, y} The location to test * @param border Number the padding value in pixel * @returns {Boolean} true if location inside the image's border, false otherwise * @see cvd/image.h */ ImageWrapper.prototype.inImageWithBorder = function (imgRef, border) { return imgRef.x >= border && imgRef.y >= border && imgRef.x < this.size.x - border && imgRef.y < this.size.y - border; }; /** * Performs bilinear sampling * @param inImg Image to extract sample from * @param x the x-coordinate * @param y the y-coordinate * @returns the sampled value * @see cvd/vision.h */ ImageWrapper.sample = function (inImg, x, y) { var lx = Math.floor(x); var ly = Math.floor(y); var w = inImg.size.x; var base = ly * inImg.size.x + lx; var a = inImg.data[base + 0]; var b = inImg.data[base + 1]; var c = inImg.data[base + w]; var d = inImg.data[base + w + 1]; var e = a - b; x -= lx; y -= ly; var result = Math.floor(x * (y * (e - c + d) - e) + y * (c - a) + a); return result; }; /** * Initializes a given array. Sets each element to zero. * @param array {Array} The array to initialize */ ImageWrapper.clearArray = function (array) { var l = array.length; while (l--) { array[l] = 0; } }; /** * Creates a {SubImage} from the current image ({this}). * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner) * @param size {ImageRef} The size of the resulting image * @returns {SubImage} A shared part of the original image */ ImageWrapper.prototype.subImage = function (from, size) { return new _subImage2.default(from, size, this); }; /** * Creates an {ImageWrapper) and copies the needed underlying image-data area * @param imageWrapper {ImageWrapper} The target {ImageWrapper} where the data should be copied * @param from {ImageRef} The location where to copy from (top-left location) */ ImageWrapper.prototype.subImageAsCopy = function (imageWrapper, from) { var sizeY = imageWrapper.size.y, sizeX = imageWrapper.size.x; var x, y; for (x = 0; x < sizeX; x++) { for (y = 0; y < sizeY; y++) { imageWrapper.data[y * sizeX + x] = this.data[(from.y + y) * this.size.x + from.x + x]; } } }; ImageWrapper.prototype.copyTo = function (imageWrapper) { var length = this.data.length, srcData = this.data, dstData = imageWrapper.data; while (length--) { dstData[length] = srcData[length]; } }; /** * Retrieves a given pixel position from the image * @param x {Number} The x-position * @param y {Number} The y-position * @returns {Number} The grayscale value at the pixel-position */ ImageWrapper.prototype.get = function (x, y) { return this.data[y * this.size.x + x]; }; /** * Retrieves a given pixel position from the image * @param x {Number} The x-position * @param y {Number} The y-position * @returns {Number} The grayscale value at the pixel-position */ ImageWrapper.prototype.getSafe = function (x, y) { var i; if (!this.indexMapping) { this.indexMapping = { x: [], y: [] }; for (i = 0; i < this.size.x; i++) { this.indexMapping.x[i] = i; this.indexMapping.x[i + this.size.x] = i; } for (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 * @param x {Number} The x-position * @param y {Number} The y-position * @param value {Number} The grayscale value to set * @returns {ImageWrapper} The Image itself (for possible chaining) */ ImageWrapper.prototype.set = function (x, y, value) { this.data[y * this.size.x + x] = value; return this; }; /** * Sets the border of the image (1 pixel) to zero */ ImageWrapper.prototype.zeroBorder = function () { var i, width = this.size.x, height = this.size.y, data = this.data; for (i = 0; i < width; i++) { data[i] = data[(height - 1) * width + i] = 0; } for (i = 1; i < height - 1; i++) { data[i * width] = data[i * width + (width - 1)] = 0; } }; /** * Inverts a binary image in place */ ImageWrapper.prototype.invert = function () { var data = this.data, length = data.length; while (length--) { data[length] = data[length] ? 0 : 1; } }; ImageWrapper.prototype.convolve = function (kernel) { var x, y, kx, ky, kSize = kernel.length / 2 | 0, accu = 0; for (y = 0; y < this.size.y; y++) { for (x = 0; x < this.size.x; x++) { accu = 0; for (ky = -kSize; ky <= kSize; ky++) { for (kx = -kSize; kx <= kSize; kx++) { accu += kernel[ky + kSize][kx + kSize] * this.getSafe(x + kx, y + ky); } } this.data[y * this.size.x + x] = accu; } } }; ImageWrapper.prototype.moments = function (labelcount) { var data = this.data, x, y, height = this.size.y, width = this.size.x, val, ysq, labelsum = [], i, label, mu11, mu02, mu20, x_, y_, tmp, result = [], PI = Math.PI, 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]; 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; 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.clone([Math.cos(tmp), Math.sin(tmp)]); result.push(label); } } return result; }; /** * Displays the {ImageWrapper} in a given canvas * @param canvas {Canvas} The canvas element to write to * @param scale {Number} Scale which is applied to each pixel-value */ ImageWrapper.prototype.show = function (canvas, scale) { var ctx, frame, data, current, pixel, x, y; if (!scale) { scale = 1.0; } ctx = canvas.getContext('2d'); canvas.width = this.size.x; canvas.height = this.size.y; frame = ctx.getImageData(0, 0, canvas.width, canvas.height); data = frame.data; current = 0; for (y = 0; y < this.size.y; y++) { for (x = 0; x < this.size.x; x++) { pixel = y * this.size.x + x; current = this.get(x, y) * scale; data[pixel * 4 + 0] = current; data[pixel * 4 + 1] = current; data[pixel * 4 + 2] = current; data[pixel * 4 + 3] = 255; } } //frame.data = data; ctx.putImageData(frame, 0, 0); }; /** * Displays the {SubImage} in a given canvas * @param canvas {Canvas} The canvas element to write to * @param scale {Number} Scale which is applied to each pixel-value */ ImageWrapper.prototype.overlay = function (canvas, scale, from) { if (!scale || scale < 0 || scale > 360) { scale = 360; } var hsv = [0, 1, 1]; var rgb = [0, 0, 0]; var whiteRgb = [255, 255, 255]; var blackRgb = [0, 0, 0]; var result = []; var ctx = canvas.getContext('2d'); 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] * scale; result = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : (0, _cv_utils.hsv2rgb)(hsv, rgb); data[length * 4 + 0] = result[0]; data[length * 4 + 1] = result[1]; data[length * 4 + 2] = result[2]; data[length * 4 + 3] = 255; } ctx.putImageData(frame, from.x, from.y); }; exports.default = ImageWrapper; /***/ }), /* 21 */ /***/ (function(module, exports, __webpack_require__) { var defineProperty = __webpack_require__(37); /** * 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; /***/ }), /* 22 */ /***/ (function(module, exports, __webpack_require__) { var baseIsNative = __webpack_require__(96), getValue = __webpack_require__(119); /** * 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; /***/ }), /* 23 */ /***/ (function(module, exports, __webpack_require__) { var isSymbol = __webpack_require__(27); /** 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; /***/ }), /* 24 */ /***/ (function(module, exports, __webpack_require__) { var isFunction = __webpack_require__(25), isLength = __webpack_require__(26); /** * 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; /***/ }), /* 25 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(8), isObject = __webpack_require__(0); /** `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; /***/ }), /* 26 */ /***/ (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; /***/ }), /* 27 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(8), isObjectLike = __webpack_require__(6); /** `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; /***/ }), /* 28 */ /***/ (function(module, exports, __webpack_require__) { var baseMerge = __webpack_require__(99), createAssigner = __webpack_require__(115); /** * 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; /***/ }), /* 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__) { "use strict"; exports.__esModule = true; /** * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization */ var 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, labelData = labelWrapper.data, searchDirections = this.searchDirections, width = imageWrapper.size.x, pos; function _trace(current, color, label, edgelabel) { var i, y, x; for (i = 0; i < 7; 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; } else { 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, Cv, P, ldir, 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; 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); 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); } }; } }; exports.default = Tracer; /***/ }), /* 31 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _barcode_reader = __webpack_require__(1); var _barcode_reader2 = _interopRequireDefault(_barcode_reader); var _array_helper = __webpack_require__(3); var _array_helper2 = _interopRequireDefault(_array_helper); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function Code39Reader() { _barcode_reader2.default.call(this); } var properties = { ALPHABETH_STRING: { value: "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%" }, ALPHABET: { value: [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 45, 46, 32, 42, 36, 47, 43, 37] }, CHARACTER_ENCODINGS: { value: [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] }, ASTERISK: { value: 0x094 }, FORMAT: { value: "code_39", writeable: false } }; Code39Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties); Code39Reader.prototype.constructor = Code39Reader; Code39Reader.prototype._decode = function () { var self = this, counters = [0, 0, 0, 0, 0, 0, 0, 0, 0], result = [], start = self._findStart(), decodedChar, lastStart, pattern, nextStart; if (!start) { return null; } nextStart = self._nextSet(self._row, start.end); do { counters = self._toCounters(nextStart, counters); pattern = self._toPattern(counters); if (pattern < 0) { return null; } decodedChar = self._patternToChar(pattern); if (decodedChar < 0) { return null; } result.push(decodedChar); lastStart = nextStart; nextStart += _array_helper2.default.sum(counters); nextStart = self._nextSet(self._row, nextStart); } while (decodedChar !== '*'); result.pop(); if (!result.length) { return null; } if (!self._verifyTrailingWhitespace(lastStart, nextStart, counters)) { return null; } return { code: result.join(""), start: start.start, end: nextStart, startInfo: start, decodedCodes: result }; }; Code39Reader.prototype._verifyTrailingWhitespace = function (lastStart, nextStart, counters) { var trailingWhitespaceEnd, patternSize = _array_helper2.default.sum(counters); trailingWhitespaceEnd = nextStart - lastStart - patternSize; if (trailingWhitespaceEnd * 3 >= patternSize) { return true; } return false; }; Code39Reader.prototype._patternToChar = function (pattern) { var i, self = this; for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) { if (self.CHARACTER_ENCODINGS[i] === pattern) { return String.fromCharCode(self.ALPHABET[i]); } } return -1; }; Code39Reader.prototype._findNextWidth = function (counters, current) { var i, minWidth = Number.MAX_VALUE; for (i = 0; i < counters.length; i++) { if (counters[i] < minWidth && counters[i] > current) { minWidth = counters[i]; } } return minWidth; }; Code39Reader.prototype._toPattern = function (counters) { var numCounters = counters.length, maxNarrowWidth = 0, numWideBars = numCounters, wideBarWidth = 0, self = this, pattern, i; while (numWideBars > 3) { maxNarrowWidth = self._findNextWidth(counters, maxNarrowWidth); numWideBars = 0; pattern = 0; for (i = 0; i < numCounters; i++) { if (counters[i] > maxNarrowWidth) { pattern |= 1 << numCounters - 1 - i; numWideBars++; wideBarWidth += counters[i]; } } if (numWideBars === 3) { for (i = 0; i < numCounters && numWideBars > 0; i++) { if (counters[i] > maxNarrowWidth) { numWideBars--; if (counters[i] * 2 >= wideBarWidth) { return -1; } } } return pattern; } } return -1; }; Code39Reader.prototype._findStart = function () { var self = this, offset = self._nextSet(self._row), patternStart = offset, counter = [0, 0, 0, 0, 0, 0, 0, 0, 0], counterPos = 0, isWhite = false, i, j, whiteSpaceMustStart; for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { // find start pattern if (self._toPattern(counter) === self.ASTERISK) { whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - (i - patternStart) / 4)); if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) { return { start: patternStart, end: i }; } } patternStart += counter[0] + counter[1]; for (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; }; exports.default = Code39Reader; /***/ }), /* 32 */ /***/ (function(module, exports) { module.exports = dot /** * Calculates the dot product of two vec2's * * @param {vec2} a the first operand * @param {vec2} 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] } /***/ }), /* 33 */ /***/ (function(module, exports, __webpack_require__) { var getNative = __webpack_require__(22), root = __webpack_require__(5); /* Built-in method references that are verified to be native. */ var Map = getNative(root, 'Map'); module.exports = Map; /***/ }), /* 34 */ /***/ (function(module, exports, __webpack_require__) { var mapCacheClear = __webpack_require__(137), mapCacheDelete = __webpack_require__(138), mapCacheGet = __webpack_require__(139), mapCacheHas = __webpack_require__(140), mapCacheSet = __webpack_require__(141); /** * 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; /***/ }), /* 35 */ /***/ (function(module, exports, __webpack_require__) { var baseAssignValue = __webpack_require__(21), eq = __webpack_require__(17); /** * 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; /***/ }), /* 36 */ /***/ (function(module, exports, __webpack_require__) { var baseAssignValue = __webpack_require__(21), eq = __webpack_require__(17); /** 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; /***/ }), /* 37 */ /***/ (function(module, exports, __webpack_require__) { var getNative = __webpack_require__(22); var defineProperty = (function() { try { var func = getNative(Object, 'defineProperty'); func({}, '', {}); return func; } catch (e) {} }()); module.exports = defineProperty; /***/ }), /* 38 */ /***/ (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(exports, __webpack_require__(48))) /***/ }), /* 39 */ /***/ (function(module, exports, __webpack_require__) { var overArg = __webpack_require__(146); /** Built-in value references. */ var getPrototype = overArg(Object.getPrototypeOf, Object); module.exports = getPrototype; /***/ }), /* 40 */ /***/ (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; /***/ }), /* 41 */ /***/ (function(module, exports, __webpack_require__) { var apply = __webpack_require__(86); /* 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; /***/ }), /* 42 */ /***/ (function(module, exports) { /** * Gets the value at `key`, unless `key` is "__proto__". * * @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) { return key == '__proto__' ? undefined : object[key]; } module.exports = safeGet; /***/ }), /* 43 */ /***/ (function(module, exports, __webpack_require__) { var baseSetToString = __webpack_require__(105), shortOut = __webpack_require__(147); /** * 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; /***/ }), /* 44 */ /***/ (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; /***/ }), /* 45 */ /***/ (function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(5), stubFalse = __webpack_require__(162); /** Detect free variable `exports`. */ var freeExports = typeof exports == 'object' && 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(exports, __webpack_require__(29)(module))) /***/ }), /* 46 */ /***/ (function(module, exports, __webpack_require__) { var baseIsTypedArray = __webpack_require__(97), baseUnary = __webpack_require__(108), nodeUtil = __webpack_require__(144); /* 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; /***/ }), /* 47 */ /***/ (function(module, exports, __webpack_require__) { var arrayLikeKeys = __webpack_require__(87), baseKeysIn = __webpack_require__(98), isArrayLike = __webpack_require__(24); /** * 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; /***/ }), /* 48 */ /***/ (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 || Function("return this")() || (1,eval)("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; /***/ }), /* 49 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _merge2 = __webpack_require__(28); var _merge3 = _interopRequireDefault(_merge2); var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; // eslint-disable-line no-unused-vars var _typedefs = __webpack_require__(57); var _typedefs2 = _interopRequireDefault(_typedefs); var _image_wrapper = __webpack_require__(20); var _image_wrapper2 = _interopRequireDefault(_image_wrapper); var _barcode_locator = __webpack_require__(63); var _barcode_locator2 = _interopRequireDefault(_barcode_locator); var _barcode_decoder = __webpack_require__(60); var _barcode_decoder2 = _interopRequireDefault(_barcode_decoder); var _events = __webpack_require__(54); var _events2 = _interopRequireDefault(_events); var _camera_access = __webpack_require__(62); var _camera_access2 = _interopRequireDefault(_camera_access); var _image_debug = __webpack_require__(9); var _image_debug2 = _interopRequireDefault(_image_debug); var _result_collector = __webpack_require__(52); var _result_collector2 = _interopRequireDefault(_result_collector); var _config2 = __webpack_require__(58); var _config3 = _interopRequireDefault(_config2); var _input_stream = __webpack_require__(51); var _input_stream2 = _interopRequireDefault(_input_stream); var _frame_grabber = __webpack_require__(50); var _frame_grabber2 = _interopRequireDefault(_frame_grabber); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var vec2 = { clone: __webpack_require__(7) }; var _inputStream, _framegrabber, _stopped, _canvasContainer = { ctx: { image: null, overlay: null }, dom: { image: null, overlay: null } }, _inputImageWrapper, _boxSize, _decoder, _workerPool = [], _onUIThread = true, _resultCollector, _config = {}; function initializeData(imageWrapper) { initBuffers(imageWrapper); _decoder = _barcode_decoder2.default.create(_config.decoder, _inputImageWrapper); } function initInputStream(cb) { var video; if (_config.inputStream.type === "VideoStream") { video = document.createElement("video"); _inputStream = _input_stream2.default.createVideoStream(video); } else if (_config.inputStream.type === "ImageStream") { _inputStream = _input_stream2.default.createImageStream(); } else if (_config.inputStream.type === "LiveStream") { var $viewport = getViewPort(); if ($viewport) { video = $viewport.querySelector("video"); if (!video) { video = document.createElement("video"); $viewport.appendChild(video); } } _inputStream = _input_stream2.default.createLiveStream(video); _camera_access2.default.request(video, _config.inputStream.constraints).then(function () { _inputStream.trigger("canrecord"); }).catch(function (err) { return cb(err); }); } _inputStream.setAttribute("preload", "auto"); _inputStream.setInputStream(_config.inputStream); _inputStream.addEventListener("canrecord", canRecord.bind(undefined, cb)); } function getViewPort() { var target = _config.inputStream.target; // Check if target is already a DOM element if (target && target.nodeName && target.nodeType === 1) { return target; } else { // Use '#interactive.viewport' as a fallback selector (backwards compatibility) var selector = typeof target === 'string' ? target : '#interactive.viewport'; return document.querySelector(selector); } } function canRecord(cb) { _barcode_locator2.default.checkImageConstraints(_inputStream, _config.locator); initCanvas(_config); _framegrabber = _frame_grabber2.default.create(_inputStream, _canvasContainer.dom.image); adjustWorkerPool(_config.numOfWorkers, function () { if (_config.numOfWorkers === 0) { initializeData(); } ready(cb); }); } function ready(cb) { _inputStream.play(); cb(); } function initCanvas() { if (typeof document !== "undefined") { var $viewport = getViewPort(); _canvasContainer.dom.image = document.querySelector("canvas.imgBuffer"); if (!_canvasContainer.dom.image) { _canvasContainer.dom.image = document.createElement("canvas"); _canvasContainer.dom.image.className = "imgBuffer"; if ($viewport && _config.inputStream.type === "ImageStream") { $viewport.appendChild(_canvasContainer.dom.image); } } _canvasContainer.ctx.image = _canvasContainer.dom.image.getContext("2d"); _canvasContainer.dom.image.width = _inputStream.getCanvasSize().x; _canvasContainer.dom.image.height = _inputStream.getCanvasSize().y; _canvasContainer.dom.overlay = document.querySelector("canvas.drawingBuffer"); if (!_canvasContainer.dom.overlay) { _canvasContainer.dom.overlay = document.createElement("canvas"); _canvasContainer.dom.overlay.className = "drawingBuffer"; if ($viewport) { $viewport.appendChild(_canvasContainer.dom.overlay); } var clearFix = document.createElement("br"); clearFix.setAttribute("clear", "all"); if ($viewport) { $viewport.appendChild(clearFix); } } _canvasContainer.ctx.overlay = _canvasContainer.dom.overlay.getContext("2d"); _canvasContainer.dom.overlay.width = _inputStream.getCanvasSize().x; _canvasContainer.dom.overlay.height = _inputStream.getCanvasSize().y; } } function initBuffers(imageWrapper) { if (imageWrapper) { _inputImageWrapper = imageWrapper; } else { _inputImageWrapper = new _image_wrapper2.default({ x: _inputStream.getWidth(), y: _inputStream.getHeight() }); } if (false) { console.log(_inputImageWrapper.size); } _boxSize = [vec2.clone([0, 0]), vec2.clone([0, _inputImageWrapper.size.y]), vec2.clone([_inputImageWrapper.size.x, _inputImageWrapper.size.y]), vec2.clone([_inputImageWrapper.size.x, 0])]; _barcode_locator2.default.init(_inputImageWrapper, _config.locator); } function getBoundingBoxes() { if (_config.locate) { return _barcode_locator2.default.locate(); } else { return [[vec2.clone(_boxSize[0]), vec2.clone(_boxSize[1]), vec2.clone(_boxSize[2]), vec2.clone(_boxSize[3])]]; } } function transformResult(result) { var topRight = _inputStream.getTopRight(), xOffset = topRight.x, yOffset = topRight.y, i; if (xOffset === 0 && yOffset === 0) { return; } if (result.barcodes) { for (i = 0; i < result.barcodes.length; i++) { transformResult(result.barcodes[i]); } } if (result.line && result.line.length === 2) { moveLine(result.line); } if (result.box) { moveBox(result.box); } if (result.boxes && result.boxes.length > 0) { for (i = 0; i < result.boxes.length; i++) { moveBox(result.boxes[i]); } } function moveBox(box) { var corner = box.length; while (corner--) { box[corner][0] += xOffset; box[corner][1] += yOffset; } } function moveLine(line) { line[0].x += xOffset; line[0].y += yOffset; line[1].x += xOffset; line[1].y += yOffset; } } function addResult(result, imageData) { if (!imageData || !_resultCollector) { return; } if (result.barcodes) { result.barcodes.filter(function (barcode) { return barcode.codeResult; }).forEach(function (barcode) { return addResult(barcode, imageData); }); } else if (result.codeResult) { _resultCollector.addResult(imageData, _inputStream.getCanvasSize(), result.codeResult); } } function hasCodeResult(result) { return result && (result.barcodes ? result.barcodes.some(function (barcode) { return barcode.codeResult; }) : result.codeResult); } function publishResult(result, imageData) { var resultToPublish = result; if (result && _onUIThread) { transformResult(result); addResult(result, imageData); resultToPublish = result.barcodes || result; } _events2.default.publish("processed", resultToPublish); if (hasCodeResult(result)) { _events2.default.publish("detected", resultToPublish); } } function locateAndDecode() { var result, boxes; boxes = getBoundingBoxes(); if (boxes) { result = _decoder.decodeFromBoundingBoxes(boxes); result = result || {}; result.boxes = boxes; publishResult(result, _inputImageWrapper.data); } else { publishResult(); } } function update() { var availableWorker; if (_onUIThread) { if (_workerPool.length > 0) { availableWorker = _workerPool.filter(function (workerThread) { return !workerThread.busy; })[0]; if (availableWorker) { _framegrabber.attachData(availableWorker.imageData); } else { return; // all workers are busy } } else { _framegrabber.attachData(_inputImageWrapper.data); } if (_framegrabber.grab()) { if (availableWorker) { availableWorker.busy = true; availableWorker.worker.postMessage({ cmd: 'process', imageData: availableWorker.imageData }, [availableWorker.imageData.buffer]); } else { locateAndDecode(); } } } else { locateAndDecode(); } } function startContinuousUpdate() { var next = null, delay = 1000 / (_config.frequency || 60); _stopped = false; (function frame(timestamp) { next = next || timestamp; if (!_stopped) { if (timestamp >= next) { next += delay; update(); } window.requestAnimFrame(frame); } })(performance.now()); } function _start() { if (_onUIThread && _config.inputStream.type === "LiveStream") { startContinuousUpdate(); } else { update(); } } function initWorker(cb) { var blobURL, workerThread = { worker: undefined, imageData: new Uint8Array(_inputStream.getWidth() * _inputStream.getHeight()), busy: true }; blobURL = generateWorkerBlob(); workerThread.worker = new Worker(blobURL); workerThread.worker.onmessage = function (e) { if (e.data.event === 'initialized') { URL.revokeObjectURL(blobURL); workerThread.busy = false; workerThread.imageData = new Uint8Array(e.data.imageData); if (false) { console.log("Worker initialized"); } return cb(workerThread); } else if (e.data.event === 'processed') { workerThread.imageData = new Uint8Array(e.data.imageData); workerThread.busy = false; publishResult(e.data.result, workerThread.imageData); } else if (e.data.event === 'error') { if (false) { 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 configForWorker(config) { return _extends({}, config, { inputStream: _extends({}, config.inputStream, { target: null }) }); } function workerInterface(factory) { /* eslint-disable no-undef*/ if (factory) { var Quagga = factory().default; if (!Quagga) { self.postMessage({ 'event': 'error', message: 'Quagga could not be created' }); return; } } var imageWrapper; 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, ready, imageWrapper); Quagga.onProcessed(onProcessed); } else if (e.data.cmd === 'process') { imageWrapper.data = new Uint8Array(e.data.imageData); Quagga.start(); } else if (e.data.cmd === 'setReaders') { Quagga.setReaders(e.data.readers); } }; function onProcessed(result) { self.postMessage({ 'event': 'processed', imageData: imageWrapper.data, result: result }, [imageWrapper.data.buffer]); } function ready() { // eslint-disable-line self.postMessage({ 'event': 'initialized', imageData: imageWrapper.data }, [imageWrapper.data.buffer]); } /* eslint-enable */ } function generateWorkerBlob() { var blob, factorySource; /* jshint ignore:start */ if (typeof __factorySource__ !== 'undefined') { 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 _setReaders(readers) { if (_decoder) { _decoder.setReaders(readers); } else if (_onUIThread && _workerPool.length > 0) { _workerPool.forEach(function (workerThread) { workerThread.worker.postMessage({ cmd: 'setReaders', readers: readers }); }); } } function adjustWorkerPool(capacity, cb) { var increaseBy = capacity - _workerPool.length; if (increaseBy === 0) { return cb && cb(); } if (increaseBy < 0) { var workersToTerminate = _workerPool.slice(increaseBy); workersToTerminate.forEach(function (workerThread) { workerThread.worker.terminate(); if (false) { console.log("Worker terminated!"); } }); _workerPool = _workerPool.slice(0, increaseBy); return cb && cb(); } else { var workerInitialized = function workerInitialized(workerThread) { _workerPool.push(workerThread); if (_workerPool.length >= capacity) { cb && cb(); } }; for (var i = 0; i < increaseBy; i++) { initWorker(workerInitialized); } } } exports.default = { init: function init(config, cb, imageWrapper) { _config = (0, _merge3.default)({}, _config3.default, config); if (imageWrapper) { _onUIThread = false; initializeData(imageWrapper); return cb(); } else { initInputStream(cb); } }, start: function start() { _start(); }, stop: function stop() { _stopped = true; adjustWorkerPool(0); if (_config.inputStream.type === "LiveStream") { _camera_access2.default.release(); _inputStream.clearEventHandlers(); } }, pause: function pause() { _stopped = true; }, onDetected: function onDetected(callback) { _events2.default.subscribe("detected", callback); }, offDetected: function offDetected(callback) { _events2.default.unsubscribe("detected", callback); }, onProcessed: function onProcessed(callback) { _events2.default.subscribe("processed", callback); }, offProcessed: function offProcessed(callback) { _events2.default.unsubscribe("processed", callback); }, setReaders: function setReaders(readers) { _setReaders(readers); }, registerResultCollector: function registerResultCollector(resultCollector) { if (resultCollector && typeof resultCollector.addResult === 'function') { _resultCollector = resultCollector; } }, canvas: _canvasContainer, decodeSingle: function decodeSingle(config, resultCallback) { var _this = this; config = (0, _merge3.default)({ inputStream: { type: "ImageStream", sequence: false, size: 800, src: config.src }, numOfWorkers: false ? 0 : 1, locator: { halfSample: false } }, config); this.init(config, function () { _events2.default.once("processed", function (result) { _this.stop(); resultCallback.call(null, result); }, true); _start(); }); }, ImageWrapper: _image_wrapper2.default, ImageDebug: _image_debug2.default, ResultCollector: _result_collector2.default, CameraAccess: _camera_access2.default }; /***/ }), /* 50 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; var CVUtils = __webpack_require__(19), Ndarray = __webpack_require__(166), Interp2D = __webpack_require__(167).d2; var FrameGrabber = {}; FrameGrabber.create = function (inputStream) { var _that = {}, _streamConfig = inputStream.getConfig(), _video_size = CVUtils.imageRef(inputStream.getRealWidth(), inputStream.getRealHeight()), _canvasSize = inputStream.getCanvasSize(), _size = CVUtils.imageRef(inputStream.getWidth(), inputStream.getHeight()), _topRight = inputStream.getTopRight(), _data = new Uint8Array(_size.x * _size.y), _grayData = new Uint8Array(_video_size.x * _video_size.y), _canvasData = new Uint8Array(_canvasSize.x * _canvasSize.y), _grayImageArray = Ndarray(_grayData, [_video_size.y, _video_size.x]).transpose(1, 0), _canvasImageArray = Ndarray(_canvasData, [_canvasSize.y, _canvasSize.x]).transpose(1, 0), _targetImageArray = _canvasImageArray.hi(_topRight.x + _size.x, _topRight.y + _size.y).lo(_topRight.x, _topRight.y), _stepSizeX = _video_size.x / _canvasSize.x, _stepSizeY = _video_size.y / _canvasSize.y; console.log("FrameGrabber", JSON.stringify({ videoSize: _grayImageArray.shape, canvasSize: _canvasImageArray.shape, stepSize: [_stepSizeX, _stepSizeY], size: _targetImageArray.shape, topRight: _topRight })); /** * 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 frame = inputStream.getFrame(); if (frame) { this.scaleAndCrop(frame); return true; } else { return false; } }; _that.scaleAndCrop = function (frame) { var x, y; // 1. compute full-sized gray image CVUtils.computeGray(frame.data, _grayData); // 2. interpolate for (y = 0; y < _canvasSize.y; y++) { for (x = 0; x < _canvasSize.x; x++) { _canvasImageArray.set(x, y, Interp2D(_grayImageArray, x * _stepSizeX, y * _stepSizeY) | 0); } } // targetImageArray must be equal to targetSize if (_targetImageArray.shape[0] !== _size.x || _targetImageArray.shape[1] !== _size.y) { throw new Error("Shapes do not match!"); } // 3. crop for (y = 0; y < _size.y; y++) { for (x = 0; x < _size.x; x++) { _data[y * _size.x + x] = _targetImageArray.get(x, y); } } }, _that.getSize = function () { return _size; }; return _that; }; module.exports = FrameGrabber; /***/ }), /* 51 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; var GetPixels = __webpack_require__(165); var InputStream = {}; InputStream.createImageStream = function () { var that = {}; var _config = null; var width = 0, height = 0, frameIdx = 0, paused = true, loaded = false, frame = null, baseUrl, ended = false, size, calculatedWidth, calculatedHeight, _eventNames = ['canrecord', 'ended'], _eventHandlers = {}, _topRight = { x: 0, y: 0 }, _canvasSize = { x: 0, y: 0 }; function loadImages() { loaded = false; GetPixels(baseUrl, _config.mime, function (err, pixels) { if (err) { console.log(err); exit(1); } loaded = true; console.log(pixels.shape); frame = pixels; width = pixels.shape[0]; height = pixels.shape[1]; calculatedWidth = _config.size ? width / height > 1 ? _config.size : Math.floor(width / height * _config.size) : width; calculatedHeight = _config.size ? width / height > 1 ? Math.floor(height / width * _config.size) : _config.size : height; _canvasSize.x = calculatedWidth; _canvasSize.y = calculatedHeight; setTimeout(function () { publishEvent("canrecord", []); }, 0); }); } function publishEvent(eventName, args) { var j, handlers = _eventHandlers[eventName]; if (handlers && handlers.length > 0) { for (j = 0; j < handlers.length; j++) { handlers[j].apply(that, args); } } } that.trigger = publishEvent; that.getWidth = function () { return calculatedWidth; }; that.getHeight = function () { return calculatedHeight; }; that.setWidth = function (width) { calculatedWidth = width; }; that.setHeight = function (height) { calculatedHeight = height; }; that.getRealWidth = function () { return width; }; that.getRealHeight = function () { return height; }; that.setInputStream = function (stream) { _config = stream; baseUrl = _config.src; size = 1; loadImages(); }; that.ended = function () { return ended; }; that.setAttribute = function () {}; that.getConfig = function () { return _config; }; that.pause = function () { paused = true; }; that.play = function () { paused = false; }; that.setCurrentTime = function (time) { frameIdx = time; }; that.addEventListener = function (event, f) { if (_eventNames.indexOf(event) !== -1) { if (!_eventHandlers[event]) { _eventHandlers[event] = []; } _eventHandlers[event].push(f); } }; that.setTopRight = function (topRight) { _topRight.x = topRight.x; _topRight.y = topRight.y; }; that.getTopRight = function () { return _topRight; }; that.setCanvasSize = function (size) { _canvasSize.x = size.x; _canvasSize.y = size.y; }; that.getCanvasSize = function () { return _canvasSize; }; that.getFrame = function () { if (!loaded) { return null; } return frame; }; return that; }; module.exports = InputStream; /***/ }), /* 52 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _image_debug = __webpack_require__(9); var _image_debug2 = _interopRequireDefault(_image_debug); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function contains(codeResult, list) { if (list) { return list.some(function (item) { return Object.keys(item).every(function (key) { return item[key] === codeResult[key]; }); }); } return false; } function passesFilter(codeResult, filter) { if (typeof filter === 'function') { return filter(codeResult); } return true; } exports.default = { create: function create(config) { var canvas = document.createElement("canvas"), ctx = canvas.getContext("2d"), results = [], capacity = config.capacity || 20, 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 = {}; if (matchesConstraints(codeResult)) { capacity--; result.codeResult = codeResult; if (capture) { canvas.width = imageSize.x; canvas.height = imageSize.y; _image_debug2.default.drawImage(data, imageSize, ctx); result.frame = canvas.toDataURL(); } results.push(result); } }, getResults: function getResults() { return results; } }; } }; /***/ }), /* 53 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var vec2 = { clone: __webpack_require__(7), dot: __webpack_require__(32) /** * Creates a cluster for grouping similar orientations of datapoints */ };exports.default = { create: function create(point, threshold) { var points = [], center = { rad: 0, vec: vec2.clone([0, 0]) }, pointMap = {}; function init() { _add(point); updateCenter(); } function _add(pointToAdd) { pointMap[pointToAdd.id] = pointToAdd; points.push(pointToAdd); } function updateCenter() { var i, sum = 0; for (i = 0; i < points.length; i++) { sum += points[i].rad; } center.rad = sum / points.length; center.vec = vec2.clone([Math.cos(center.rad), Math.sin(center.rad)]); } 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.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 }; } }; /***/ }), /* 54 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; exports.default = function () { 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 "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), 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, async) { _subscribe(event, { callback: callback, async: async, once: true }); }, unsubscribe: function unsubscribe(eventName, callback) { var event; if (eventName) { event = getEvent(eventName); if (event && callback) { event.subscribers = event.subscribers.filter(function (subscriber) { return subscriber.callback !== callback; }); } else { event.subscribers = []; } } else { clearEvents(); } } }; }(); /***/ }), /* 55 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; exports.enumerateDevices = enumerateDevices; exports.getUserMedia = getUserMedia; function enumerateDevices() { if (navigator.mediaDevices && typeof navigator.mediaDevices.enumerateDevices === 'function') { return navigator.mediaDevices.enumerateDevices(); } return Promise.reject(new Error('enumerateDevices is not defined')); }; function getUserMedia(constraints) { if (navigator.mediaDevices && typeof navigator.mediaDevices.getUserMedia === 'function') { return navigator.mediaDevices.getUserMedia(constraints); } return Promise.reject(new Error('getUserMedia is not defined')); } /***/ }), /* 56 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; /** * Construct representing a part of another {ImageWrapper}. Shares data * between the parent and the child. * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner) * @param size {ImageRef} The size of the resulting image * @param I {ImageWrapper} The {ImageWrapper} to share from * @returns {SubImage} A shared part of the original image */ function SubImage(from, size, I) { if (!I) { I = { data: null, size: size }; } this.data = I.data; this.originalSize = I.size; this.I = I; this.from = from; this.size = size; } /** * Displays the {SubImage} in a given canvas * @param canvas {Canvas} The canvas element to write to * @param scale {Number} Scale which is applied to each pixel-value */ SubImage.prototype.show = function (canvas, scale) { var ctx, frame, data, current, y, x, pixel; if (!scale) { scale = 1.0; } ctx = canvas.getContext('2d'); canvas.width = this.size.x; canvas.height = this.size.y; frame = ctx.getImageData(0, 0, canvas.width, canvas.height); data = frame.data; current = 0; for (y = 0; y < this.size.y; y++) { for (x = 0; x < this.size.x; x++) { pixel = y * this.size.x + x; current = this.get(x, y) * scale; data[pixel * 4 + 0] = current; data[pixel * 4 + 1] = current; data[pixel * 4 + 2] = current; data[pixel * 4 + 3] = 255; } } frame.data = data; ctx.putImageData(frame, 0, 0); }; /** * Retrieves a given pixel position from the {SubImage} * @param x {Number} The x-position * @param y {Number} The y-position * @returns {Number} The grayscale value at the pixel-position */ SubImage.prototype.get = function (x, y) { return this.data[(this.from.y + y) * this.originalSize.x + this.from.x + x]; }; /** * Updates the underlying data from a given {ImageWrapper} * @param image {ImageWrapper} The updated image */ SubImage.prototype.updateData = function (image) { this.originalSize = image.size; this.data = image.data; }; /** * Updates the position of the shared area * @param from {x,y} The new location * @returns {SubImage} returns {this} for possible chaining */ SubImage.prototype.updateFrom = function (from) { this.from = from; return this; }; exports.default = SubImage; /***/ }), /* 57 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; /* * typedefs.js * Normalizes browser-specific prefixes */ if (typeof window !== 'undefined') { window.requestAnimFrame = function () { return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function ( /* function FrameRequestCallback */callback) { window.setTimeout(callback, 1000 / 60); }; }(); } Math.imul = Math.imul || function (a, b) { var ah = a >>> 16 & 0xffff, al = a & 0xffff, bh = b >>> 16 & 0xffff, 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; }; 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++) { var nextSource = arguments[index]; if (nextSource !== null) { // Skip over if undefined or null for (var nextKey in nextSource) { // Avoid bugs when hasOwnProperty is shadowed if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) { to[nextKey] = nextSource[nextKey]; } } } } return to; }; } /***/ }), /* 58 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var config = void 0; if (false) { config = require('./config.dev.js'); } else if (true) { config = __webpack_require__(59); } else { config = require('./config.prod.js'); } exports.default = config; /***/ }), /* 59 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; module.exports = { 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 } }; /***/ }), /* 60 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; var _bresenham = __webpack_require__(61); var _bresenham2 = _interopRequireDefault(_bresenham); var _image_debug = __webpack_require__(9); var _image_debug2 = _interopRequireDefault(_image_debug); var _code_128_reader = __webpack_require__(68); var _code_128_reader2 = _interopRequireDefault(_code_128_reader); var _ean_reader = __webpack_require__(4); var _ean_reader2 = _interopRequireDefault(_ean_reader); var _code_39_reader = __webpack_require__(31); var _code_39_reader2 = _interopRequireDefault(_code_39_reader); var _code_39_vin_reader = __webpack_require__(69); var _code_39_vin_reader2 = _interopRequireDefault(_code_39_vin_reader); var _codabar_reader = __webpack_require__(67); var _codabar_reader2 = _interopRequireDefault(_codabar_reader); var _upc_reader = __webpack_require__(76); var _upc_reader2 = _interopRequireDefault(_upc_reader); var _ean_8_reader = __webpack_require__(73); var _ean_8_reader2 = _interopRequireDefault(_ean_8_reader); var _ean_2_reader = __webpack_require__(71); var _ean_2_reader2 = _interopRequireDefault(_ean_2_reader); var _ean_5_reader = __webpack_require__(72); var _ean_5_reader2 = _interopRequireDefault(_ean_5_reader); var _upc_e_reader = __webpack_require__(75); var _upc_e_reader2 = _interopRequireDefault(_upc_e_reader); var _i2of5_reader = __webpack_require__(74); var _i2of5_reader2 = _interopRequireDefault(_i2of5_reader); var _of5_reader = __webpack_require__(66); var _of5_reader2 = _interopRequireDefault(_of5_reader); var _code_93_reader = __webpack_require__(70); var _code_93_reader2 = _interopRequireDefault(_code_93_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var READERS = { code_128_reader: _code_128_reader2.default, ean_reader: _ean_reader2.default, ean_5_reader: _ean_5_reader2.default, ean_2_reader: _ean_2_reader2.default, ean_8_reader: _ean_8_reader2.default, code_39_reader: _code_39_reader2.default, code_39_vin_reader: _code_39_vin_reader2.default, codabar_reader: _codabar_reader2.default, upc_reader: _upc_reader2.default, upc_e_reader: _upc_e_reader2.default, i2of5_reader: _i2of5_reader2.default, '2of5_reader': _of5_reader2.default, code_93_reader: _code_93_reader2.default }; exports.default = { create: function create(config, inputImageWrapper) { var _canvas = { ctx: { frequency: null, pattern: null, overlay: null }, dom: { frequency: null, pattern: null, overlay: null } }, _barcodeReaders = []; initCanvas(); initReaders(); initConfig(); function initCanvas() { if (false) { 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); } } _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() { config.readers.forEach(function (readerConfig) { var reader, configuration = {}, supplements = []; if ((typeof readerConfig === 'undefined' ? 'undefined' : _typeof(readerConfig)) === 'object') { reader = readerConfig.format; configuration = readerConfig.config; } else if (typeof readerConfig === 'string') { reader = readerConfig; } if (false) { console.log("Before registering reader: ", reader); } if (configuration.supplements) { supplements = configuration.supplements.map(function (supplement) { return new READERS[supplement](); }); } _barcodeReaders.push(new READERS[reader](configuration, supplements)); }); if (false) { console.log("Registered Readers: " + _barcodeReaders.map(function (reader) { return JSON.stringify({ format: reader.FORMAT, config: reader.config }); }).join(', ')); } } function initConfig() { if (false) { var i, 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) }; line[0].y -= extension.y; line[0].x -= extension.x; line[1].y += extension.y; line[1].x += extension.x; } // check if inside image extendLine(ext); while (ext > 1 && (!inputImageWrapper.inImageWithBorder(line[0], 0) || !inputImageWrapper.inImageWithBorder(line[1], 0))) { 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, i, barcodeLine = _bresenham2.default.getBarcodeLine(inputImageWrapper, line[0], line[1]); if (false) { _image_debug2.default.drawPath(line, { x: 'x', y: 'y' }, _canvas.ctx.overlay, { color: 'red', lineWidth: 3 }); _bresenham2.default.debug.printFrequency(barcodeLine.line, _canvas.dom.frequency); } _bresenham2.default.toBinaryLine(barcodeLine); if (false) { _bresenham2.default.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)), i, slices = 16, result = null, dir, extension, xdir = Math.sin(lineAngle), ydir = Math.cos(lineAngle); for (i = 1; i < slices && result === null; i++) { // move line perpendicular to angle dir = sideLength / slices * i * (i % 2 === 0 ? -1 : 1); extension = { y: dir * xdir, x: dir * ydir }; line[0].y += extension.x; line[0].x -= extension.y; line[1].y += extension.x; line[1].x -= extension.y; 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)); } /** * 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 _decodeFromBoundingBox(box) { var line, lineAngle, ctx = _canvas.ctx.overlay, result, lineLength; if (false) { if (config.debug.drawBoundingBox && ctx) { _image_debug2.default.drawPath(box, { x: 0, y: 1 }, ctx, { color: "blue", lineWidth: 2 }); } } line = getLine(box); lineLength = getLineLength(line); 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 (false) { _image_debug2.default.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, result, barcodes = [], 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; } } if (multiple) { return { barcodes: barcodes }; } }, setReaders: function setReaders(readers) { config.readers = readers; _barcodeReaders.length = 0; initReaders(); } }; } }; /***/ }), /* 61 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _image_wrapper = __webpack_require__(20); var _image_wrapper2 = _interopRequireDefault(_image_wrapper); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 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) { var x0 = p1.x | 0, y0 = p1.y | 0, x1 = p2.x | 0, y1 = p2.y | 0, steep = Math.abs(y1 - y0) > Math.abs(x1 - x0), deltax, deltay, error, ystep, y, tmp, x, line = [], imageData = imageWrapper.data, width = imageWrapper.size.x, sum = 0, val, min = 255, max = 0; function read(a, b) { val = imageData[b * width + a]; sum += val; 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; } deltax = x1 - x0; deltay = Math.abs(y1 - y0); error = deltax / 2 | 0; y = y0; ystep = y0 < y1 ? 1 : -1; for (x = x0; x < x1; x++) { if (steep) { read(y, x); } else { read(x, y); } error = error - deltay; if (error < 0) { y = y + ystep; error = 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, max = result.max, line = result.line, slope, slope2, center = min + (max - min) / 2, extrema = [], currentDir, dir, threshold = (max - min) / 12, rThreshold = -threshold, i, 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, ctx = canvas.getContext("2d"); canvas.width = line.length; 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"), i; canvas.width = line.length; ctx.fillColor = "black"; for (i = 0; i < line.length; i++) { if (line[i] === 1) { ctx.fillRect(i, 0, 1, 100); } } } }; exports.default = Bresenham; /***/ }), /* 62 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _pick2 = __webpack_require__(161); var _pick3 = _interopRequireDefault(_pick2); exports.pickConstraints = pickConstraints; var _mediaDevices = __webpack_require__(55); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var facingMatching = { "user": /front/i, "environment": /back/i }; 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 (false) { console.log(video.videoWidth + "px x " + video.videoHeight + "px"); } resolve(); } else { window.setTimeout(checkVideo, 500); } } else { reject('Unable to play video stream. Is webcam working?'); } 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(video, constraints) { return (0, _mediaDevices.getUserMedia)(constraints).then(function (stream) { return new Promise(function (resolve) { streamRef = stream; video.setAttribute("autoplay", true); video.setAttribute('muted', true); video.setAttribute('playsinline', true); video.srcObject = stream; video.addEventListener('loadedmetadata', function () { video.play(); resolve(); }); }); }).then(waitForVideo.bind(null, video)); } function deprecatedConstraints(videoConstraints) { var normalized = (0, _pick3.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; } function pickConstraints(videoConstraints) { var normalizedConstraints = { audio: false, video: deprecatedConstraints(videoConstraints) }; if (normalizedConstraints.video.deviceId && normalizedConstraints.video.facingMode) { delete normalizedConstraints.video.facingMode; } return Promise.resolve(normalizedConstraints); } function enumerateVideoDevices() { return (0, _mediaDevices.enumerateDevices)().then(function (devices) { return devices.filter(function (device) { return device.kind === 'videoinput'; }); }); } function getActiveTrack() { if (streamRef) { var tracks = streamRef.getVideoTracks(); if (tracks && tracks.length) { return tracks[0]; } } } exports.default = { request: function request(video, videoConstraints) { return pickConstraints(videoConstraints).then(initCamera.bind(null, video)); }, release: function release() { var tracks = streamRef && streamRef.getVideoTracks(); if (tracks && tracks.length) { tracks[0].stop(); } streamRef = null; }, enumerateVideoDevices: enumerateVideoDevices, getActiveStreamLabel: function getActiveStreamLabel() { var track = getActiveTrack(); return track ? track.label : ''; }, getActiveTrack: getActiveTrack }; /***/ }), /* 63 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; /* WEBPACK VAR INJECTION */(function(global) { exports.__esModule = true; var _image_wrapper = __webpack_require__(20); var _image_wrapper2 = _interopRequireDefault(_image_wrapper); var _cv_utils = __webpack_require__(19); var _array_helper = __webpack_require__(3); var _array_helper2 = _interopRequireDefault(_array_helper); var _image_debug = __webpack_require__(9); var _image_debug2 = _interopRequireDefault(_image_debug); var _rasterizer = __webpack_require__(64); var _rasterizer2 = _interopRequireDefault(_rasterizer); var _tracer = __webpack_require__(30); var _tracer2 = _interopRequireDefault(_tracer); var _skeletonizer2 = __webpack_require__(65); var _skeletonizer3 = _interopRequireDefault(_skeletonizer2); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var vec2 = { clone: __webpack_require__(7), dot: __webpack_require__(32), scale: __webpack_require__(80), transformMat2: __webpack_require__(81) }; var mat2 = { copy: __webpack_require__(77), create: __webpack_require__(78), invert: __webpack_require__(79) }; var _config, _currentImageWrapper, _skelImageWrapper, _subImageWrapper, _labelImageWrapper, _patchGrid, _patchLabelGrid, _imageToPatchGrid, _binaryImageWrapper, _patchSize, _canvasContainer = { ctx: { binary: null }, dom: { binary: null } }, _numPatches = { x: 0, y: 0 }, _inputImageWrapper, _skeletonizer; function initBuffers() { var skeletonImageData; if (_config.halfSample) { _currentImageWrapper = new _image_wrapper2.default({ x: _inputImageWrapper.size.x / 2 | 0, y: _inputImageWrapper.size.y / 2 | 0 }); } else { _currentImageWrapper = _inputImageWrapper; } _patchSize = (0, _cv_utils.calculatePatchSize)(_config.patchSize, _currentImageWrapper.size); _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0; _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0; _binaryImageWrapper = new _image_wrapper2.default(_currentImageWrapper.size, undefined, Uint8Array, false); _labelImageWrapper = new _image_wrapper2.default(_patchSize, undefined, Array, true); skeletonImageData = new ArrayBuffer(64 * 1024); _subImageWrapper = new _image_wrapper2.default(_patchSize, new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y)); _skelImageWrapper = new _image_wrapper2.default(_patchSize, new Uint8Array(skeletonImageData, _patchSize.x * _patchSize.y * 3, _patchSize.x * _patchSize.y), undefined, true); _skeletonizer = (0, _skeletonizer3.default)(typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : global, { size: _patchSize.x }, skeletonImageData); _imageToPatchGrid = new _image_wrapper2.default({ x: _currentImageWrapper.size.x / _subImageWrapper.size.x | 0, y: _currentImageWrapper.size.y / _subImageWrapper.size.y | 0 }, undefined, Array, true); _patchGrid = new _image_wrapper2.default(_imageToPatchGrid.size, undefined, undefined, true); _patchLabelGrid = new _image_wrapper2.default(_imageToPatchGrid.size, undefined, Int32Array, true); } function initCanvas() { if (_config.useWorker || typeof document === 'undefined') { return; } _canvasContainer.dom.binary = document.createElement("canvas"); _canvasContainer.dom.binary.className = "binaryBuffer"; if (false) { document.querySelector("#debug").appendChild(_canvasContainer.dom.binary); } _canvasContainer.ctx.binary = _canvasContainer.dom.binary.getContext("2d"); _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, i, j, patch, transMat, minx = _binaryImageWrapper.size.x, miny = _binaryImageWrapper.size.y, maxx = -_binaryImageWrapper.size.x, maxy = -_binaryImageWrapper.size.y, box, 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 (false) { _image_debug2.default.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.copy(mat2.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.transformMat2(patch.box[j], patch.box[j], transMat); } if (false) { _image_debug2.default.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 (false) { _image_debug2.default.drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); } scale = _config.halfSample ? 2 : 1; // reverse rotation; transMat = mat2.invert(transMat, transMat); for (j = 0; j < 4; j++) { vec2.transformMat2(box[j], box[j], transMat); } if (false) { _image_debug2.default.drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); } for (j = 0; j < 4; j++) { vec2.scale(box[j], box[j], scale); } return box; } /** * Creates a binary image of the current image */ function binarizeImage() { (0, _cv_utils.otsuThreshold)(_currentImageWrapper, _binaryImageWrapper); _binaryImageWrapper.zeroBorder(); if (false) { _binaryImageWrapper.show(_canvasContainer.dom.binary, 255); } } /** * Iterate over the entire image * extract patches */ function findPatches() { var i, j, x, y, moments, patchesFound = [], rasterizer, rasterResult, 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_helper2.default.init(_labelImageWrapper.data, 0); rasterizer = _rasterizer2.default.create(_skelImageWrapper, _labelImageWrapper); rasterResult = rasterizer.rasterize(0); if (false) { _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 (false) { for (i = 0; i < patchesFound.length; i++) { patch = patchesFound[i]; _image_debug2.default.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, sum, labelHist = [], 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, j, sum, patches = [], patch, box, boxes = [], hsv = [0, 1, 1], 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 (false) { for (j = 0; j < patches.length; j++) { patch = patches[j]; hsv[0] = topLabels[i].label / (maxLabel + 1) * 360; (0, _cv_utils.hsv2rgb)(hsv, rgb); _image_debug2.default.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "rgb(" + rgb.join(",") + ")", lineWidth: 2 }); } } } } return boxes; } /** * Find similar moments (via cluster) * @param {Object} moments */ function similarMoments(moments) { var clusters = (0, _cv_utils.cluster)(moments, 0.90); var topCluster = (0, _cv_utils.topGeneric)(clusters, 1, function (e) { return e.getPoints().length; }); var points = [], 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, (0, _cv_utils.imageRef)(x, y)); _skeletonizer.skeletonize(); // Show skeleton if requested if (false) { _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, (0, _cv_utils.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, avg, eligibleMoments = [], matchingMoments, patch, patchesFound = [], 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++) { avg += matchingMoments[k].rad; } // 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.clone([x, y]), vec2.clone([x + _subImageWrapper.size.x, y]), vec2.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]), vec2.clone([x, y + _subImageWrapper.size.y])], moments: matchingMoments, rad: avg, vec: vec2.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, threshold = 0.95, currIdx = 0, j, patch, hsv = [0, 1, 1], 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.length; } function trace(currentIdx) { var x, y, currentPatch, idx, dir, current = { x: currentIdx % _patchLabelGrid.size.x, y: currentIdx / _patchLabelGrid.size.x | 0 }, similarity; if (currentIdx < _patchLabelGrid.data.length) { currentPatch = _imageToPatchGrid.data[currentIdx]; // assign label _patchLabelGrid.data[currentIdx] = label; for (dir = 0; dir < _tracer2.default.searchDirections.length; dir++) { y = current.y + _tracer2.default.searchDirections[dir][0]; x = current.x + _tracer2.default.searchDirections[dir][1]; idx = y * _patchLabelGrid.size.x + x; // continue if patch empty if (_patchGrid.data[idx] === 0) { _patchLabelGrid.data[idx] = Number.MAX_VALUE; continue; } if (_patchLabelGrid.data[idx] === 0) { similarity = Math.abs(vec2.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec)); if (similarity > threshold) { trace(idx); } } } } } // prepare for finding the right patches _array_helper2.default.init(_patchGrid.data, 0); _array_helper2.default.init(_patchLabelGrid.data, 0); _array_helper2.default.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(); while ((currIdx = notYetProcessed()) < _patchLabelGrid.data.length) { label++; trace(currIdx); } // draw patch-labels if requested if (false) { 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; (0, _cv_utils.hsv2rgb)(hsv, rgb); _image_debug2.default.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "rgb(" + rgb.join(",") + ")", lineWidth: 2 }); } } } return label; } exports.default = { init: function init(inputImageWrapper, config) { _config = config; _inputImageWrapper = inputImageWrapper; initBuffers(); initCanvas(); }, locate: function locate() { var patchesFound, topLabels, boxes; if (_config.halfSample) { (0, _cv_utils.halfSample)(_inputImageWrapper, _currentImageWrapper); } binarizeImage(); 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) topLabels = findBiggestConnectedAreas(maxLabel); if (topLabels.length === 0) { return null; } boxes = findBoxes(topLabels, maxLabel); return boxes; }, checkImageConstraints: function checkImageConstraints(inputStream, config) { var patchSize, width = inputStream.getWidth(), height = inputStream.getHeight(), halfSample = config.halfSample ? 0.5 : 1, size, area; // calculate width and height based on area if (inputStream.getConfig().area) { area = (0, _cv_utils.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; } size = { x: Math.floor(width * halfSample), y: Math.floor(height * halfSample) }; patchSize = (0, _cv_utils.calculatePatchSize)(config.patchSize, size); if (false) { console.log("Patch-Size: " + JSON.stringify(patchSize)); } inputStream.setWidth(Math.floor(Math.floor(size.x / patchSize.x) * (1 / halfSample) * patchSize.x)); inputStream.setHeight(Math.floor(Math.floor(size.y / patchSize.y) * (1 / halfSample) * 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 (" + width + " )and height (" + height + ") must a multiple of " + patchSize.x); } }; /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(48))) /***/ }), /* 64 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _tracer = __webpack_require__(30); var _tracer2 = _interopRequireDefault(_tracer); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** * 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, labelData = labelWrapper.data, width = imageWrapper.size.x, height = imageWrapper.size.y, tracer = _tracer2.default.create(imageWrapper, labelWrapper); return { rasterize: function rasterize(depthlabel) { var color, bc, lc, labelindex, cx, cy, colorMap = [], vertex, p, cc, sc, pos, connectedCount = 0, 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"), pq = firstContour, iq, q, 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(); } } } }; } }; exports.default = Rasterizer; /***/ }), /* 65 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; /* @preserve ASM BEGIN */ /* eslint-disable eqeqeq*/ function Skeletonizer(stdlib, foreign, buffer) { "use asm"; var images = new stdlib.Uint8Array(buffer), size = foreign.size | 0, imul = stdlib.Math.imul; function erode(inImagePtr, outImagePtr) { inImagePtr = inImagePtr | 0; outImagePtr = outImagePtr | 0; var v = 0, u = 0, sum = 0, yStart1 = 0, yStart2 = 0, xStart1 = 0, xStart2 = 0, 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) == (5 | 0)) { images[outImagePtr + offset + u | 0] = 1; } else { images[outImagePtr + offset + u | 0] = 0; } } } return; } 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; } } 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; } } function countNonZero(imagePtr) { imagePtr = imagePtr | 0; var sum = 0, 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; } 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; } } function dilate(inImagePtr, outImagePtr) { inImagePtr = inImagePtr | 0; outImagePtr = outImagePtr | 0; var v = 0, u = 0, sum = 0, yStart1 = 0, yStart2 = 0, xStart1 = 0, xStart2 = 0, 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; } } } return; } 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; } } function zeroBorder(imagePtr) { imagePtr = imagePtr | 0; var x = 0, 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; } } function skeletonize() { var subImagePtr = 0, erodedImagePtr = 0, tempImagePtr = 0, skelImagePtr = 0, sum = 0, done = 0; erodedImagePtr = imul(size, size) | 0; tempImagePtr = erodedImagePtr + erodedImagePtr | 0; skelImagePtr = tempImagePtr + erodedImagePtr | 0; // init skel-image 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 */ exports.default = Skeletonizer; /* eslint-enable eqeqeq*/ /***/ }), /* 66 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _barcode_reader = __webpack_require__(1); var _barcode_reader2 = _interopRequireDefault(_barcode_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function TwoOfFiveReader(opts) { _barcode_reader2.default.call(this, opts); this.barSpaceRatio = [1, 1]; } var N = 1, W = 3, properties = { START_PATTERN: { value: [W, N, W, N, N, N] }, STOP_PATTERN: { value: [W, N, N, N, W] }, CODE_PATTERN: { value: [[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]] }, SINGLE_CODE_ERROR: { value: 0.78, writable: true }, AVG_CODE_ERROR: { value: 0.30, writable: true }, FORMAT: { value: "2of5" } }; var startPatternLength = properties.START_PATTERN.value.reduce(function (sum, val) { return sum + val; }, 0); TwoOfFiveReader.prototype = Object.create(_barcode_reader2.default.prototype, properties); TwoOfFiveReader.prototype.constructor = TwoOfFiveReader; TwoOfFiveReader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder) { var counter = [], self = this, i, counterPos = 0, bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0 }, error, j, sum, epsilon = self.AVG_CODE_ERROR; isWhite = isWhite || false; tryHarder = tryHarder || false; if (!offset) { offset = self._nextSet(self._row); } for (i = 0; i < pattern.length; i++) { counter[i] = 0; } for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { sum = 0; for (j = 0; j < counter.length; j++) { sum += counter[j]; } error = self._matchPattern(counter, pattern); if (error < epsilon) { bestMatch.error = error; bestMatch.start = i - sum; bestMatch.end = i; return bestMatch; } if (tryHarder) { for (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; }; TwoOfFiveReader.prototype._findStart = function () { var self = this, leadingWhitespaceStart, offset = self._nextSet(self._row), startInfo, narrowBarWidth = 1; while (!startInfo) { startInfo = self._findPattern(self.START_PATTERN, offset, false, true); if (!startInfo) { return null; } narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / startPatternLength); leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5; if (leadingWhitespaceStart >= 0) { if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) { return startInfo; } } offset = startInfo.end; startInfo = null; } }; TwoOfFiveReader.prototype._verifyTrailingWhitespace = function (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; }; TwoOfFiveReader.prototype._findEnd = function () { var self = this, endInfo, tmp, offset; self._row.reverse(); offset = self._nextSet(self._row); endInfo = self._findPattern(self.STOP_PATTERN, offset, false, true); self._row.reverse(); if (endInfo === null) { return null; } // reverse numbers tmp = endInfo.start; endInfo.start = self._row.length - endInfo.end; endInfo.end = self._row.length - tmp; return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null; }; TwoOfFiveReader.prototype._decodeCode = function (counter) { var j, self = this, sum = 0, normalized, error, epsilon = self.AVG_CODE_ERROR, code, bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0 }; for (j = 0; j < counter.length; j++) { sum += counter[j]; } for (code = 0; code < self.CODE_PATTERN.length; code++) { error = self._matchPattern(counter, self.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } if (bestMatch.error < epsilon) { return bestMatch; } }; TwoOfFiveReader.prototype._decodePayload = function (counters, result, decodedCodes) { var i, self = this, pos = 0, counterLength = counters.length, counter = [0, 0, 0, 0, 0], code; while (pos < counterLength) { for (i = 0; i < 5; i++) { counter[i] = counters[pos] * this.barSpaceRatio[0]; pos += 2; } code = self._decodeCode(counter); if (!code) { return null; } result.push(code.code + ""); decodedCodes.push(code); } return code; }; TwoOfFiveReader.prototype._verifyCounterLength = function (counters) { return counters.length % 10 === 0; }; TwoOfFiveReader.prototype._decode = function () { var startInfo, endInfo, self = this, code, result = [], decodedCodes = [], counters; startInfo = self._findStart(); if (!startInfo) { return null; } decodedCodes.push(startInfo); endInfo = self._findEnd(); if (!endInfo) { return null; } counters = self._fillCounters(startInfo.end, endInfo.start, false); if (!self._verifyCounterLength(counters)) { return null; } code = self._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 }; }; exports.default = TwoOfFiveReader; /***/ }), /* 67 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _barcode_reader = __webpack_require__(1); var _barcode_reader2 = _interopRequireDefault(_barcode_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function CodabarReader() { _barcode_reader2.default.call(this); this._counters = []; } var properties = { ALPHABETH_STRING: { value: "0123456789-$:/.+ABCD" }, ALPHABET: { value: [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 45, 36, 58, 47, 46, 43, 65, 66, 67, 68] }, CHARACTER_ENCODINGS: { value: [0x003, 0x006, 0x009, 0x060, 0x012, 0x042, 0x021, 0x024, 0x030, 0x048, 0x00c, 0x018, 0x045, 0x051, 0x054, 0x015, 0x01A, 0x029, 0x00B, 0x00E] }, START_END: { value: [0x01A, 0x029, 0x00B, 0x00E] }, MIN_ENCODED_CHARS: { value: 4 }, MAX_ACCEPTABLE: { value: 2.0 }, PADDING: { value: 1.5 }, FORMAT: { value: "codabar", writeable: false } }; CodabarReader.prototype = Object.create(_barcode_reader2.default.prototype, properties); CodabarReader.prototype.constructor = CodabarReader; CodabarReader.prototype._decode = function () { var self = this, result = [], start, decodedChar, pattern, nextStart, end; this._counters = self._fillCounters(); start = self._findStart(); if (!start) { return null; } nextStart = start.startCounter; do { pattern = self._toPattern(nextStart); if (pattern < 0) { return null; } decodedChar = self._patternToChar(pattern); if (decodedChar < 0) { return null; } result.push(decodedChar); nextStart += 8; if (result.length > 1 && self._isStartEnd(pattern)) { break; } } while (nextStart < self._counters.length); // verify end if (result.length - 2 < self.MIN_ENCODED_CHARS || !self._isStartEnd(pattern)) { return null; } // verify end white space if (!self._verifyWhitespace(start.startCounter, nextStart - 8)) { return null; } if (!self._validateResult(result, start.startCounter)) { return null; } nextStart = nextStart > self._counters.length ? self._counters.length : nextStart; end = start.start + self._sumCounters(start.startCounter, nextStart - 8); return { code: result.join(""), start: start.start, end: end, startInfo: start, decodedCodes: result }; }; CodabarReader.prototype._verifyWhitespace = function (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; }; CodabarReader.prototype._calculatePatternLength = function (offset) { var i, sum = 0; for (i = offset; i < offset + 7; i++) { sum += this._counters[i]; } return sum; }; CodabarReader.prototype._thresholdResultPattern = function (result, startCounter) { var self = this, 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 } } }, kind, cat, i, j, pos = startCounter, pattern; for (i = 0; i < result.length; i++) { pattern = self._charToPattern(result[i]); for (j = 6; j >= 0; j--) { kind = (j & 1) === 2 ? categorization.bar : categorization.space; cat = (pattern & 1) === 1 ? kind.wide : kind.narrow; cat.size += self._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 * self.MAX_ACCEPTABLE + self.PADDING) / newkind.wide.counts); }); return categorization; }; CodabarReader.prototype._charToPattern = function (char) { var self = this, charCode = char.charCodeAt(0), i; for (i = 0; i < self.ALPHABET.length; i++) { if (self.ALPHABET[i] === charCode) { return self.CHARACTER_ENCODINGS[i]; } } return 0x0; }; CodabarReader.prototype._validateResult = function (result, startCounter) { var self = this, thresholds = self._thresholdResultPattern(result, startCounter), i, j, kind, cat, size, pos = startCounter, pattern; for (i = 0; i < result.length; i++) { pattern = self._charToPattern(result[i]); for (j = 6; j >= 0; j--) { kind = (j & 1) === 0 ? thresholds.bar : thresholds.space; cat = (pattern & 1) === 1 ? kind.wide : kind.narrow; size = self._counters[pos + j]; if (size < cat.min || size > cat.max) { return false; } pattern >>= 1; } pos += 8; } return true; }; CodabarReader.prototype._patternToChar = function (pattern) { var i, self = this; for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) { if (self.CHARACTER_ENCODINGS[i] === pattern) { return String.fromCharCode(self.ALPHABET[i]); } } return -1; }; CodabarReader.prototype._computeAlternatingThreshold = function (offset, end) { var i, min = Number.MAX_VALUE, max = 0, counter; for (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; }; CodabarReader.prototype._toPattern = function (offset) { var numCounters = 7, end = offset + numCounters, barThreshold, spaceThreshold, bitmask = 1 << numCounters - 1, pattern = 0, i, threshold; if (end > this._counters.length) { return -1; } barThreshold = this._computeAlternatingThreshold(offset, end); spaceThreshold = this._computeAlternatingThreshold(offset + 1, end); for (i = 0; i < numCounters; i++) { threshold = (i & 1) === 0 ? barThreshold : spaceThreshold; if (this._counters[offset + i] > threshold) { pattern |= bitmask; } bitmask >>= 1; } return pattern; }; CodabarReader.prototype._isStartEnd = function (pattern) { var i; for (i = 0; i < this.START_END.length; i++) { if (this.START_END[i] === pattern) { return true; } } return false; }; CodabarReader.prototype._sumCounters = function (start, end) { var i, sum = 0; for (i = start; i < end; i++) { sum += this._counters[i]; } return sum; }; CodabarReader.prototype._findStart = function () { var self = this, i, pattern, start = self._nextUnset(self._row), end; for (i = 1; i < this._counters.length; i++) { pattern = self._toPattern(i); if (pattern !== -1 && self._isStartEnd(pattern)) { // TODO: Look for whitespace ahead start += self._sumCounters(0, i); end = start + self._sumCounters(i, i + 8); return { start: start, end: end, startCounter: i, endCounter: i + 8 }; } } }; exports.default = CodabarReader; /***/ }), /* 68 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _barcode_reader = __webpack_require__(1); var _barcode_reader2 = _interopRequireDefault(_barcode_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function Code128Reader() { _barcode_reader2.default.call(this); } var properties = { CODE_SHIFT: { value: 98 }, CODE_C: { value: 99 }, CODE_B: { value: 100 }, CODE_A: { value: 101 }, START_CODE_A: { value: 103 }, START_CODE_B: { value: 104 }, START_CODE_C: { value: 105 }, STOP_CODE: { value: 106 }, CODE_PATTERN: { value: [[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]] }, SINGLE_CODE_ERROR: { value: 0.64 }, AVG_CODE_ERROR: { value: 0.30 }, FORMAT: { value: "code_128", writeable: false }, MODULE_INDICES: { value: { bar: [0, 2, 4], space: [1, 3, 5] } } }; Code128Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties); Code128Reader.prototype.constructor = Code128Reader; Code128Reader.prototype._decodeCode = function (start, correction) { var counter = [0, 0, 0, 0, 0, 0], i, self = this, offset = start, isWhite = !self._row[offset], counterPos = 0, bestMatch = { error: Number.MAX_VALUE, code: -1, start: start, end: start, correction: { bar: 1, space: 1 } }, code, error; for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { if (correction) { self._correct(counter, correction); } for (code = 0; code < self.CODE_PATTERN.length; code++) { error = self._matchPattern(counter, self.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } bestMatch.end = i; if (bestMatch.code === -1 || bestMatch.error > self.AVG_CODE_ERROR) { return null; } if (self.CODE_PATTERN[bestMatch.code]) { bestMatch.correction.bar = calculateCorrection(self.CODE_PATTERN[bestMatch.code], counter, this.MODULE_INDICES.bar); bestMatch.correction.space = calculateCorrection(self.CODE_PATTERN[bestMatch.code], counter, this.MODULE_INDICES.space); } return bestMatch; } else { counterPos++; } counter[counterPos] = 1; isWhite = !isWhite; } } return null; }; Code128Reader.prototype._correct = function (counter, correction) { this._correctBars(counter, correction.bar, this.MODULE_INDICES.bar); this._correctBars(counter, correction.space, this.MODULE_INDICES.space); }; Code128Reader.prototype._findStart = function () { var counter = [0, 0, 0, 0, 0, 0], i, self = this, offset = self._nextSet(self._row), isWhite = false, counterPos = 0, bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0, correction: { bar: 1, space: 1 } }, code, error, j, sum; for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { sum = 0; for (j = 0; j < counter.length; j++) { sum += counter[j]; } for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) { error = self._matchPattern(counter, self.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } if (bestMatch.error < self.AVG_CODE_ERROR) { bestMatch.start = i - sum; bestMatch.end = i; bestMatch.correction.bar = calculateCorrection(self.CODE_PATTERN[bestMatch.code], counter, this.MODULE_INDICES.bar); bestMatch.correction.space = calculateCorrection(self.CODE_PATTERN[bestMatch.code], counter, this.MODULE_INDICES.space); return bestMatch; } for (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; }; Code128Reader.prototype._decode = function () { var self = this, startInfo = self._findStart(), code = null, done = false, result = [], multiplier = 0, checksum = 0, codeset, rawResult = [], decodedCodes = [], shiftNext = false, unshift, removeLastCharacter = true; if (startInfo === null) { return null; } code = { code: startInfo.code, start: startInfo.start, end: startInfo.end, correction: { bar: startInfo.correction.bar, space: startInfo.correction.space } }; decodedCodes.push(code); checksum = code.code; switch (code.code) { case self.START_CODE_A: codeset = self.CODE_A; break; case self.START_CODE_B: codeset = self.CODE_B; break; case self.START_CODE_C: codeset = self.CODE_C; break; default: return null; } while (!done) { unshift = shiftNext; shiftNext = false; code = self._decodeCode(code.end, code.correction); if (code !== null) { if (code.code !== self.STOP_CODE) { removeLastCharacter = true; } if (code.code !== self.STOP_CODE) { rawResult.push(code.code); multiplier++; checksum += multiplier * code.code; } decodedCodes.push(code); switch (codeset) { case self.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 !== self.STOP_CODE) { removeLastCharacter = false; } switch (code.code) { case self.CODE_SHIFT: shiftNext = true; codeset = self.CODE_B; break; case self.CODE_B: codeset = self.CODE_B; break; case self.CODE_C: codeset = self.CODE_C; break; case self.STOP_CODE: done = true; break; } } break; case self.CODE_B: if (code.code < 96) { result.push(String.fromCharCode(32 + code.code)); } else { if (code.code !== self.STOP_CODE) { removeLastCharacter = false; } switch (code.code) { case self.CODE_SHIFT: shiftNext = true; codeset = self.CODE_A; break; case self.CODE_A: codeset = self.CODE_A; break; case self.CODE_C: codeset = self.CODE_C; break; case self.STOP_CODE: done = true; break; } } break; case self.CODE_C: if (code.code < 100) { result.push(code.code < 10 ? "0" + code.code : code.code); } else { if (code.code !== self.STOP_CODE) { removeLastCharacter = false; } switch (code.code) { case self.CODE_A: codeset = self.CODE_A; break; case self.CODE_B: codeset = self.CODE_B; break; case self.STOP_CODE: done = true; break; } } break; } } else { done = true; } if (unshift) { codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A; } } if (code === null) { return null; } code.end = self._nextUnset(self._row, code.end); if (!self._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 }; }; _barcode_reader2.default.prototype._verifyTrailingWhitespace = function (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; }; 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; } exports.default = Code128Reader; /***/ }), /* 69 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _code_39_reader = __webpack_require__(31); var _code_39_reader2 = _interopRequireDefault(_code_39_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function Code39VINReader() { _code_39_reader2.default.call(this); } var patterns = { IOQ: /[IOQ]/g, AZ09: /[A-Z0-9]{17}/ }; Code39VINReader.prototype = Object.create(_code_39_reader2.default.prototype); Code39VINReader.prototype.constructor = Code39VINReader; // Cribbed from: // https://github.com/zxing/zxing/blob/master/core/src/main/java/com/google/zxing/client/result/VINResultParser.java Code39VINReader.prototype._decode = function () { var result = _code_39_reader2.default.prototype._decode.apply(this); if (!result) { return null; } var code = result.code; if (!code) { return null; } code = code.replace(patterns.IOQ, ''); if (!code.match(patterns.AZ09)) { if (false) { console.log('Failed AZ09 pattern code:', code); } return null; } if (!this._checkChecksum(code)) { return null; } result.code = code; return result; }; Code39VINReader.prototype._checkChecksum = function (code) { // TODO return !!code; }; exports.default = Code39VINReader; /***/ }), /* 70 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _barcode_reader = __webpack_require__(1); var _barcode_reader2 = _interopRequireDefault(_barcode_reader); var _array_helper = __webpack_require__(3); var _array_helper2 = _interopRequireDefault(_array_helper); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function Code93Reader() { _barcode_reader2.default.call(this); } var ALPHABETH_STRING = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*"; var properties = { ALPHABETH_STRING: { value: ALPHABETH_STRING }, ALPHABET: { value: ALPHABETH_STRING.split('').map(function (char) { return char.charCodeAt(0); }) }, CHARACTER_ENCODINGS: { value: [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] }, ASTERISK: { value: 0x15E }, FORMAT: { value: "code_93", writeable: false } }; Code93Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties); Code93Reader.prototype.constructor = Code93Reader; Code93Reader.prototype._decode = function () { var self = this, counters = [0, 0, 0, 0, 0, 0], result = [], start = self._findStart(), decodedChar, lastStart, pattern, nextStart; if (!start) { return null; } nextStart = self._nextSet(self._row, start.end); do { counters = self._toCounters(nextStart, counters); pattern = self._toPattern(counters); if (pattern < 0) { return null; } decodedChar = self._patternToChar(pattern); if (decodedChar < 0) { return null; } result.push(decodedChar); lastStart = nextStart; nextStart += _array_helper2.default.sum(counters); nextStart = self._nextSet(self._row, nextStart); } while (decodedChar !== '*'); result.pop(); if (!result.length) { return null; } if (!self._verifyEnd(lastStart, nextStart, counters)) { return null; } if (!self._verifyChecksums(result)) { return null; } result = result.slice(0, result.length - 2); if ((result = self._decodeExtended(result)) === null) { return null; }; return { code: result.join(""), start: start.start, end: nextStart, startInfo: start, decodedCodes: result }; }; Code93Reader.prototype._verifyEnd = function (lastStart, nextStart) { if (lastStart === nextStart || !this._row[nextStart]) { return false; } return true; }; Code93Reader.prototype._patternToChar = function (pattern) { var i, self = this; for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) { if (self.CHARACTER_ENCODINGS[i] === pattern) { return String.fromCharCode(self.ALPHABET[i]); } } return -1; }; Code93Reader.prototype._toPattern = function (counters) { var numCounters = counters.length; var pattern = 0; var sum = 0; for (var i = 0; i < numCounters; i++) { sum += counters[i]; } 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; }; Code93Reader.prototype._findStart = function () { var self = this, offset = self._nextSet(self._row), patternStart = offset, counter = [0, 0, 0, 0, 0, 0], counterPos = 0, isWhite = false, i, j, whiteSpaceMustStart; for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { // find start pattern if (self._toPattern(counter) === self.ASTERISK) { whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - (i - patternStart) / 4)); if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) { return { start: patternStart, end: i }; } } patternStart += counter[0] + counter[1]; for (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; }; Code93Reader.prototype._decodeExtended = function (charArray) { var length = charArray.length; var result = []; for (var i = 0; i < length; i++) { var char = charArray[i]; if (char >= 'a' && char <= 'd') { if (i > length - 2) { return null; } var nextChar = charArray[++i]; var nextCharCode = nextChar.charCodeAt(0); var decodedChar = void 0; switch (char) { 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; } result.push(decodedChar); } else { result.push(char); } } return result; }; Code93Reader.prototype._verifyChecksums = function (charArray) { return this._matchCheckChar(charArray, charArray.length - 2, 20) && this._matchCheckChar(charArray, charArray.length - 1, 15); }; Code93Reader.prototype._matchCheckChar = function (charArray, index, maxWeight) { var _this = this; var arrayToCheck = charArray.slice(0, index); var length = arrayToCheck.length; var weightedSums = arrayToCheck.reduce(function (sum, char, i) { var weight = (i * -1 + (length - 1)) % maxWeight + 1; var value = _this.ALPHABET.indexOf(char.charCodeAt(0)); return sum + weight * value; }, 0); var checkChar = this.ALPHABET[weightedSums % 47]; return checkChar === charArray[index].charCodeAt(0); }; exports.default = Code93Reader; /***/ }), /* 71 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _ean_reader = __webpack_require__(4); var _ean_reader2 = _interopRequireDefault(_ean_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function EAN2Reader() { _ean_reader2.default.call(this); } var properties = { FORMAT: { value: "ean_2", writeable: false } }; EAN2Reader.prototype = Object.create(_ean_reader2.default.prototype, properties); EAN2Reader.prototype.constructor = EAN2Reader; EAN2Reader.prototype.decode = function (row, start) { this._row = row; var counters = [0, 0, 0, 0], codeFrequency = 0, i = 0, offset = start, end = this._row.length, code, result = [], decodedCodes = []; for (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 >= this.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; } return { code: result.join(""), decodedCodes: decodedCodes, end: code.end }; }; exports.default = EAN2Reader; /***/ }), /* 72 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _ean_reader = __webpack_require__(4); var _ean_reader2 = _interopRequireDefault(_ean_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function EAN5Reader() { _ean_reader2.default.call(this); } var properties = { FORMAT: { value: "ean_5", writeable: false } }; var CHECK_DIGIT_ENCODINGS = [24, 20, 18, 17, 12, 6, 3, 10, 9, 5]; EAN5Reader.prototype = Object.create(_ean_reader2.default.prototype, properties); EAN5Reader.prototype.constructor = EAN5Reader; EAN5Reader.prototype.decode = function (row, start) { this._row = row; var counters = [0, 0, 0, 0], codeFrequency = 0, i = 0, offset = start, end = this._row.length, code, result = [], decodedCodes = []; for (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 >= this.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; } return { code: result.join(""), decodedCodes: decodedCodes, end: code.end }; }; function determineCheckDigit(codeFrequency) { var i; for (i = 0; i < 10; i++) { if (codeFrequency === CHECK_DIGIT_ENCODINGS[i]) { return i; } } return null; } function extensionChecksum(result) { var length = result.length, sum = 0, i; for (i = length - 2; i >= 0; i -= 2) { sum += result[i]; } sum *= 3; for (i = length - 1; i >= 0; i -= 2) { sum += result[i]; } sum *= 3; return sum % 10; } exports.default = EAN5Reader; /***/ }), /* 73 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _ean_reader = __webpack_require__(4); var _ean_reader2 = _interopRequireDefault(_ean_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function EAN8Reader(opts, supplements) { _ean_reader2.default.call(this, opts, supplements); } var properties = { FORMAT: { value: "ean_8", writeable: false } }; EAN8Reader.prototype = Object.create(_ean_reader2.default.prototype, properties); EAN8Reader.prototype.constructor = EAN8Reader; EAN8Reader.prototype._decodePayload = function (code, result, decodedCodes) { var i, self = this; for (i = 0; i < 4; i++) { code = self._decodeCode(code.end, self.CODE_G_START); if (!code) { return null; } result.push(code.code); decodedCodes.push(code); } code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); if (code === null) { return null; } decodedCodes.push(code); for (i = 0; i < 4; i++) { code = self._decodeCode(code.end, self.CODE_G_START); if (!code) { return null; } decodedCodes.push(code); result.push(code.code); } return code; }; exports.default = EAN8Reader; /***/ }), /* 74 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _merge2 = __webpack_require__(28); var _merge3 = _interopRequireDefault(_merge2); var _barcode_reader = __webpack_require__(1); var _barcode_reader2 = _interopRequireDefault(_barcode_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function I2of5Reader(opts) { opts = (0, _merge3.default)(getDefaulConfig(), opts); _barcode_reader2.default.call(this, opts); this.barSpaceRatio = [1, 1]; if (opts.normalizeBarSpaceWidth) { this.SINGLE_CODE_ERROR = 0.38; this.AVG_CODE_ERROR = 0.09; } } function getDefaulConfig() { var config = {}; Object.keys(I2of5Reader.CONFIG_KEYS).forEach(function (key) { config[key] = I2of5Reader.CONFIG_KEYS[key].default; }); return config; } var N = 1, W = 3, properties = { START_PATTERN: { value: [N, N, N, N] }, STOP_PATTERN: { value: [N, N, W] }, CODE_PATTERN: { value: [[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]] }, SINGLE_CODE_ERROR: { value: 0.78, writable: true }, AVG_CODE_ERROR: { value: 0.38, writable: true }, MAX_CORRECTION_FACTOR: { value: 5 }, FORMAT: { value: "i2of5" } }; I2of5Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties); I2of5Reader.prototype.constructor = I2of5Reader; I2of5Reader.prototype._matchPattern = function (counter, code) { if (this.config.normalizeBarSpaceWidth) { var i, counterSum = [0, 0], codeSum = [0, 0], correction = [0, 0], correctionRatio = this.MAX_CORRECTION_FACTOR, correctionRatioInverse = 1 / correctionRatio; for (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 (i = 0; i < counter.length; i++) { counter[i] *= this.barSpaceRatio[i % 2]; } } return _barcode_reader2.default.prototype._matchPattern.call(this, counter, code); }; I2of5Reader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder) { var counter = [], self = this, i, counterPos = 0, bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0 }, error, j, sum, normalized, epsilon = self.AVG_CODE_ERROR; isWhite = isWhite || false; tryHarder = tryHarder || false; if (!offset) { offset = self._nextSet(self._row); } for (i = 0; i < pattern.length; i++) { counter[i] = 0; } for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; } else { if (counterPos === counter.length - 1) { sum = 0; for (j = 0; j < counter.length; j++) { sum += counter[j]; } error = self._matchPattern(counter, pattern); if (error < epsilon) { bestMatch.error = error; bestMatch.start = i - sum; bestMatch.end = i; return bestMatch; } if (tryHarder) { for (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; }; I2of5Reader.prototype._findStart = function () { var self = this, leadingWhitespaceStart, offset = self._nextSet(self._row), startInfo, narrowBarWidth = 1; while (!startInfo) { startInfo = self._findPattern(self.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 (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) { return startInfo; } } offset = startInfo.end; startInfo = null; } }; I2of5Reader.prototype._verifyTrailingWhitespace = function (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; }; I2of5Reader.prototype._findEnd = function () { var self = this, endInfo, tmp; self._row.reverse(); endInfo = self._findPattern(self.STOP_PATTERN); self._row.reverse(); if (endInfo === null) { return null; } // reverse numbers tmp = endInfo.start; endInfo.start = self._row.length - endInfo.end; endInfo.end = self._row.length - tmp; return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null; }; I2of5Reader.prototype._decodePair = function (counterPair) { var i, code, codes = [], self = this; for (i = 0; i < counterPair.length; i++) { code = self._decodeCode(counterPair[i]); if (!code) { return null; } codes.push(code); } return codes; }; I2of5Reader.prototype._decodeCode = function (counter) { var j, self = this, sum = 0, normalized, error, epsilon = self.AVG_CODE_ERROR, code, bestMatch = { error: Number.MAX_VALUE, code: -1, start: 0, end: 0 }; for (j = 0; j < counter.length; j++) { sum += counter[j]; } for (code = 0; code < self.CODE_PATTERN.length; code++) { error = self._matchPattern(counter, self.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; bestMatch.error = error; } } if (bestMatch.error < epsilon) { return bestMatch; } }; I2of5Reader.prototype._decodePayload = function (counters, result, decodedCodes) { var i, self = this, pos = 0, counterLength = counters.length, counterPair = [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0]], codes; while (pos < counterLength) { for (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 = self._decodePair(counterPair); if (!codes) { return null; } for (i = 0; i < codes.length; i++) { result.push(codes[i].code + ""); decodedCodes.push(codes[i]); } } return codes; }; I2of5Reader.prototype._verifyCounterLength = function (counters) { return counters.length % 10 === 0; }; I2of5Reader.prototype._decode = function () { var startInfo, endInfo, self = this, code, result = [], decodedCodes = [], counters; startInfo = self._findStart(); if (!startInfo) { return null; } decodedCodes.push(startInfo); endInfo = self._findEnd(); if (!endInfo) { return null; } counters = self._fillCounters(startInfo.end, endInfo.start, false); if (!self._verifyCounterLength(counters)) { return null; } code = self._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 }; }; I2of5Reader.CONFIG_KEYS = { normalizeBarSpaceWidth: { 'type': 'boolean', 'default': false, 'description': 'If true, the reader tries to normalize the' + 'width-difference between bars and spaces' } }; exports.default = I2of5Reader; /***/ }), /* 75 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _ean_reader = __webpack_require__(4); var _ean_reader2 = _interopRequireDefault(_ean_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function UPCEReader(opts, supplements) { _ean_reader2.default.call(this, opts, supplements); } var properties = { CODE_FREQUENCY: { value: [[56, 52, 50, 49, 44, 38, 35, 42, 41, 37], [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]] }, STOP_PATTERN: { value: [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7] }, FORMAT: { value: "upc_e", writeable: false } }; UPCEReader.prototype = Object.create(_ean_reader2.default.prototype, properties); UPCEReader.prototype.constructor = UPCEReader; UPCEReader.prototype._decodePayload = function (code, result, decodedCodes) { var i, self = this, codeFrequency = 0x0; for (i = 0; i < 6; i++) { code = self._decodeCode(code.end); if (!code) { return null; } if (code.code >= self.CODE_G_START) { code.code = code.code - self.CODE_G_START; codeFrequency |= 1 << 5 - i; } result.push(code.code); decodedCodes.push(code); } if (!self._determineParity(codeFrequency, result)) { return null; } return code; }; UPCEReader.prototype._determineParity = function (codeFrequency, result) { var i, nrSystem; for (nrSystem = 0; nrSystem < this.CODE_FREQUENCY.length; nrSystem++) { for (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; }; UPCEReader.prototype._convertToUPCA = function (result) { var upca = [result[0]], 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; }; UPCEReader.prototype._checksum = function (result) { return _ean_reader2.default.prototype._checksum.call(this, this._convertToUPCA(result)); }; UPCEReader.prototype._findEnd = function (offset, isWhite) { isWhite = true; return _ean_reader2.default.prototype._findEnd.call(this, offset, isWhite); }; UPCEReader.prototype._verifyTrailingWhitespace = function (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; } } }; exports.default = UPCEReader; /***/ }), /* 76 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; var _ean_reader = __webpack_require__(4); var _ean_reader2 = _interopRequireDefault(_ean_reader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function UPCReader(opts, supplements) { _ean_reader2.default.call(this, opts, supplements); } var properties = { FORMAT: { value: "upc_a", writeable: false } }; UPCReader.prototype = Object.create(_ean_reader2.default.prototype, properties); UPCReader.prototype.constructor = UPCReader; UPCReader.prototype._decode = function () { var result = _ean_reader2.default.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; }; exports.default = UPCReader; /***/ }), /* 77 */ /***/ (function(module, exports) { module.exports = copy /** * Copy the values from one mat2 to another * * @alias mat2.copy * @param {mat2} out the receiving matrix * @param {mat2} 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 } /***/ }), /* 78 */ /***/ (function(module, exports) { module.exports = create /** * Creates a new identity mat2 * * @alias mat2.create * @returns {mat2} a new 2x2 matrix */ function create() { var out = new Float32Array(4) out[0] = 1 out[1] = 0 out[2] = 0 out[3] = 1 return out } /***/ }), /* 79 */ /***/ (function(module, exports) { module.exports = invert /** * Inverts a mat2 * * @alias mat2.invert * @param {mat2} out the receiving matrix * @param {mat2} a the source matrix * @returns {mat2} out */ function invert(out, a) { var a0 = a[0] var a1 = a[1] var a2 = a[2] var a3 = a[3] 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 } /***/ }), /* 80 */ /***/ (function(module, exports) { module.exports = scale /** * Scales a vec2 by a scalar number * * @param {vec2} out the receiving vector * @param {vec2} a the vector to scale * @param {Number} b amount to scale the vector by * @returns {vec2} out */ function scale(out, a, b) { out[0] = a[0] * b out[1] = a[1] * b return out } /***/ }), /* 81 */ /***/ (function(module, exports) { module.exports = transformMat2 /** * Transforms the vec2 with a mat2 * * @param {vec2} out the receiving vector * @param {vec2} a the vector to transform * @param {mat2} 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 } /***/ }), /* 82 */ /***/ (function(module, exports) { module.exports = clone; /** * Creates a new vec3 initialized with values from an existing vector * * @param {vec3} a vector to clone * @returns {vec3} a new 3D vector */ function clone(a) { var out = new Float32Array(3) out[0] = a[0] out[1] = a[1] out[2] = a[2] return out } /***/ }), /* 83 */ /***/ (function(module, exports, __webpack_require__) { var hashClear = __webpack_require__(121), hashDelete = __webpack_require__(122), hashGet = __webpack_require__(123), hashHas = __webpack_require__(124), hashSet = __webpack_require__(125); /** * 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; /***/ }), /* 84 */ /***/ (function(module, exports, __webpack_require__) { var ListCache = __webpack_require__(10), stackClear = __webpack_require__(148), stackDelete = __webpack_require__(149), stackGet = __webpack_require__(150), stackHas = __webpack_require__(151), stackSet = __webpack_require__(152); /** * 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; /***/ }), /* 85 */ /***/ (function(module, exports, __webpack_require__) { var root = __webpack_require__(5); /** Built-in value references. */ var Uint8Array = root.Uint8Array; module.exports = Uint8Array; /***/ }), /* 86 */ /***/ (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; /***/ }), /* 87 */ /***/ (function(module, exports, __webpack_require__) { var baseTimes = __webpack_require__(106), isArguments = __webpack_require__(18), isArray = __webpack_require__(2), isBuffer = __webpack_require__(45), isIndex = __webpack_require__(15), isTypedArray = __webpack_require__(46); /** 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; /***/ }), /* 88 */ /***/ (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; /***/ }), /* 89 */ /***/ (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; /***/ }), /* 90 */ /***/ (function(module, exports, __webpack_require__) { var isObject = __webpack_require__(0); /** 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; /***/ }), /* 91 */ /***/ (function(module, exports, __webpack_require__) { var arrayPush = __webpack_require__(89), isFlattenable = __webpack_require__(127); /** * 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; /***/ }), /* 92 */ /***/ (function(module, exports, __webpack_require__) { var createBaseFor = __webpack_require__(116); /** * 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; /***/ }), /* 93 */ /***/ (function(module, exports, __webpack_require__) { var castPath = __webpack_require__(13), toKey = __webpack_require__(23); /** * 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; /***/ }), /* 94 */ /***/ (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; /***/ }), /* 95 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(8), isObjectLike = __webpack_require__(6); /** `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; /***/ }), /* 96 */ /***/ (function(module, exports, __webpack_require__) { var isFunction = __webpack_require__(25), isMasked = __webpack_require__(131), isObject = __webpack_require__(0), toSource = __webpack_require__(154); /** * 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; /***/ }), /* 97 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(8), isLength = __webpack_require__(26), isObjectLike = __webpack_require__(6); /** `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; /***/ }), /* 98 */ /***/ (function(module, exports, __webpack_require__) { var isObject = __webpack_require__(0), isPrototype = __webpack_require__(40), nativeKeysIn = __webpack_require__(143); /** 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; /***/ }), /* 99 */ /***/ (function(module, exports, __webpack_require__) { var Stack = __webpack_require__(84), assignMergeValue = __webpack_require__(35), baseFor = __webpack_require__(92), baseMergeDeep = __webpack_require__(100), isObject = __webpack_require__(0), keysIn = __webpack_require__(47), safeGet = __webpack_require__(42); /** * 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) { if (isObject(srcValue)) { stack || (stack = new Stack); 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; /***/ }), /* 100 */ /***/ (function(module, exports, __webpack_require__) { var assignMergeValue = __webpack_require__(35), cloneBuffer = __webpack_require__(110), cloneTypedArray = __webpack_require__(111), copyArray = __webpack_require__(112), initCloneObject = __webpack_require__(126), isArguments = __webpack_require__(18), isArray = __webpack_require__(2), isArrayLikeObject = __webpack_require__(158), isBuffer = __webpack_require__(45), isFunction = __webpack_require__(25), isObject = __webpack_require__(0), isPlainObject = __webpack_require__(159), isTypedArray = __webpack_require__(46), safeGet = __webpack_require__(42), toPlainObject = __webpack_require__(163); /** * 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) || (srcIndex && 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; /***/ }), /* 101 */ /***/ (function(module, exports, __webpack_require__) { var basePickBy = __webpack_require__(102), hasIn = __webpack_require__(157); /** * 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; /***/ }), /* 102 */ /***/ (function(module, exports, __webpack_require__) { var baseGet = __webpack_require__(93), baseSet = __webpack_require__(104), castPath = __webpack_require__(13); /** * 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; /***/ }), /* 103 */ /***/ (function(module, exports, __webpack_require__) { var identity = __webpack_require__(44), overRest = __webpack_require__(41), setToString = __webpack_require__(43); /** * 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; /***/ }), /* 104 */ /***/ (function(module, exports, __webpack_require__) { var assignValue = __webpack_require__(36), castPath = __webpack_require__(13), isIndex = __webpack_require__(15), isObject = __webpack_require__(0), toKey = __webpack_require__(23); /** * 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 (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; /***/ }), /* 105 */ /***/ (function(module, exports, __webpack_require__) { var constant = __webpack_require__(155), defineProperty = __webpack_require__(37), identity = __webpack_require__(44); /** * 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; /***/ }), /* 106 */ /***/ (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; /***/ }), /* 107 */ /***/ (function(module, exports, __webpack_require__) { var Symbol = __webpack_require__(11), arrayMap = __webpack_require__(88), isArray = __webpack_require__(2), isSymbol = __webpack_require__(27); /** 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; /***/ }), /* 108 */ /***/ (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; /***/ }), /* 109 */ /***/ (function(module, exports, __webpack_require__) { var Uint8Array = __webpack_require__(85); /** * 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; /***/ }), /* 110 */ /***/ (function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(5); /** Detect free variable `exports`. */ var freeExports = typeof exports == 'object' && 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(exports, __webpack_require__(29)(module))) /***/ }), /* 111 */ /***/ (function(module, exports, __webpack_require__) { var cloneArrayBuffer = __webpack_require__(109); /** * 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; /***/ }), /* 112 */ /***/ (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; /***/ }), /* 113 */ /***/ (function(module, exports, __webpack_require__) { var assignValue = __webpack_require__(36), baseAssignValue = __webpack_require__(21); /** * 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; /***/ }), /* 114 */ /***/ (function(module, exports, __webpack_require__) { var root = __webpack_require__(5); /** Used to detect overreaching core-js shims. */ var coreJsData = root['__core-js_shared__']; module.exports = coreJsData; /***/ }), /* 115 */ /***/ (function(module, exports, __webpack_require__) { var baseRest = __webpack_require__(103), isIterateeCall = __webpack_require__(128); /** * 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; /***/ }), /* 116 */ /***/ (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; /***/ }), /* 117 */ /***/ (function(module, exports, __webpack_require__) { var flatten = __webpack_require__(156), overRest = __webpack_require__(41), setToString = __webpack_require__(43); /** * 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; /***/ }), /* 118 */ /***/ (function(module, exports, __webpack_require__) { var Symbol = __webpack_require__(11); /** 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; /***/ }), /* 119 */ /***/ (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; /***/ }), /* 120 */ /***/ (function(module, exports, __webpack_require__) { var castPath = __webpack_require__(13), isArguments = __webpack_require__(18), isArray = __webpack_require__(2), isIndex = __webpack_require__(15), isLength = __webpack_require__(26), toKey = __webpack_require__(23); /** * 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; /***/ }), /* 121 */ /***/ (function(module, exports, __webpack_require__) { var nativeCreate = __webpack_require__(16); /** * 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; /***/ }), /* 122 */ /***/ (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; /***/ }), /* 123 */ /***/ (function(module, exports, __webpack_require__) { var nativeCreate = __webpack_require__(16); /** 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; /***/ }), /* 124 */ /***/ (function(module, exports, __webpack_require__) { var nativeCreate = __webpack_require__(16); /** 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; /***/ }), /* 125 */ /***/ (function(module, exports, __webpack_require__) { var nativeCreate = __webpack_require__(16); /** 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; /***/ }), /* 126 */ /***/ (function(module, exports, __webpack_require__) { var baseCreate = __webpack_require__(90), getPrototype = __webpack_require__(39), isPrototype = __webpack_require__(40); /** * 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; /***/ }), /* 127 */ /***/ (function(module, exports, __webpack_require__) { var Symbol = __webpack_require__(11), isArguments = __webpack_require__(18), isArray = __webpack_require__(2); /** 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; /***/ }), /* 128 */ /***/ (function(module, exports, __webpack_require__) { var eq = __webpack_require__(17), isArrayLike = __webpack_require__(24), isIndex = __webpack_require__(15), isObject = __webpack_require__(0); /** * 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; /***/ }), /* 129 */ /***/ (function(module, exports, __webpack_require__) { var isArray = __webpack_require__(2), isSymbol = __webpack_require__(27); /** 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; /***/ }), /* 130 */ /***/ (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; /***/ }), /* 131 */ /***/ (function(module, exports, __webpack_require__) { var coreJsData = __webpack_require__(114); /** 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; /***/ }), /* 132 */ /***/ (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; /***/ }), /* 133 */ /***/ (function(module, exports, __webpack_require__) { var assocIndexOf = __webpack_require__(12); /** 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; /***/ }), /* 134 */ /***/ (function(module, exports, __webpack_require__) { var assocIndexOf = __webpack_require__(12); /** * 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; /***/ }), /* 135 */ /***/ (function(module, exports, __webpack_require__) { var assocIndexOf = __webpack_require__(12); /** * 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; /***/ }), /* 136 */ /***/ (function(module, exports, __webpack_require__) { var assocIndexOf = __webpack_require__(12); /** * 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; /***/ }), /* 137 */ /***/ (function(module, exports, __webpack_require__) { var Hash = __webpack_require__(83), ListCache = __webpack_require__(10), Map = __webpack_require__(33); /** * 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; /***/ }), /* 138 */ /***/ (function(module, exports, __webpack_require__) { var getMapData = __webpack_require__(14); /** * 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; /***/ }), /* 139 */ /***/ (function(module, exports, __webpack_require__) { var getMapData = __webpack_require__(14); /** * 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; /***/ }), /* 140 */ /***/ (function(module, exports, __webpack_require__) { var getMapData = __webpack_require__(14); /** * 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; /***/ }), /* 141 */ /***/ (function(module, exports, __webpack_require__) { var getMapData = __webpack_require__(14); /** * 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; /***/ }), /* 142 */ /***/ (function(module, exports, __webpack_require__) { var memoize = __webpack_require__(160); /** 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; /***/ }), /* 143 */ /***/ (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; /***/ }), /* 144 */ /***/ (function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(module) {var freeGlobal = __webpack_require__(38); /** Detect free variable `exports`. */ var freeExports = typeof exports == 'object' && 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(exports, __webpack_require__(29)(module))) /***/ }), /* 145 */ /***/ (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; /***/ }), /* 146 */ /***/ (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; /***/ }), /* 147 */ /***/ (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; /***/ }), /* 148 */ /***/ (function(module, exports, __webpack_require__) { var ListCache = __webpack_require__(10); /** * 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; /***/ }), /* 149 */ /***/ (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; /***/ }), /* 150 */ /***/ (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; /***/ }), /* 151 */ /***/ (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; /***/ }), /* 152 */ /***/ (function(module, exports, __webpack_require__) { var ListCache = __webpack_require__(10), Map = __webpack_require__(33), MapCache = __webpack_require__(34); /** 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; /***/ }), /* 153 */ /***/ (function(module, exports, __webpack_require__) { var memoizeCapped = __webpack_require__(142); /** 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; /***/ }), /* 154 */ /***/ (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; /***/ }), /* 155 */ /***/ (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; /***/ }), /* 156 */ /***/ (function(module, exports, __webpack_require__) { var baseFlatten = __webpack_require__(91); /** * 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; /***/ }), /* 157 */ /***/ (function(module, exports, __webpack_require__) { var baseHasIn = __webpack_require__(94), hasPath = __webpack_require__(120); /** * 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; /***/ }), /* 158 */ /***/ (function(module, exports, __webpack_require__) { var isArrayLike = __webpack_require__(24), isObjectLike = __webpack_require__(6); /** * 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; /***/ }), /* 159 */ /***/ (function(module, exports, __webpack_require__) { var baseGetTag = __webpack_require__(8), getPrototype = __webpack_require__(39), isObjectLike = __webpack_require__(6); /** `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; /***/ }), /* 160 */ /***/ (function(module, exports, __webpack_require__) { var MapCache = __webpack_require__(34); /** 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; /***/ }), /* 161 */ /***/ (function(module, exports, __webpack_require__) { var basePick = __webpack_require__(101), flatRest = __webpack_require__(117); /** * 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; /***/ }), /* 162 */ /***/ (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; /***/ }), /* 163 */ /***/ (function(module, exports, __webpack_require__) { var copyObject = __webpack_require__(113), keysIn = __webpack_require__(47); /** * 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; /***/ }), /* 164 */ /***/ (function(module, exports, __webpack_require__) { var baseToString = __webpack_require__(107); /** * 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; /***/ }), /* 165 */ /***/ (function(module, exports) { module.exports = __WEBPACK_EXTERNAL_MODULE_165__; /***/ }), /* 166 */ /***/ (function(module, exports) { module.exports = __WEBPACK_EXTERNAL_MODULE_166__; /***/ }), /* 167 */ /***/ (function(module, exports) { module.exports = __WEBPACK_EXTERNAL_MODULE_167__; /***/ }), /* 168 */ /***/ (function(module, exports, __webpack_require__) { module.exports = __webpack_require__(49); /***/ }) /******/ ]); }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 1f51d4a969eafeb5a351","webpack:///./~/lodash/isObject.js","webpack:///./src/reader/barcode_reader.js","webpack:///./~/lodash/isArray.js","webpack:///./src/common/array_helper.js","webpack:///./src/reader/ean_reader.js","webpack:///./~/lodash/_root.js","webpack:///./~/lodash/isObjectLike.js","webpack:///./~/gl-vec2/clone.js","webpack:///./~/lodash/_baseGetTag.js","webpack:///./src/common/image_debug.js","webpack:///./~/lodash/_ListCache.js","webpack:///./~/lodash/_Symbol.js","webpack:///./~/lodash/_assocIndexOf.js","webpack:///./~/lodash/_castPath.js","webpack:///./~/lodash/_getMapData.js","webpack:///./~/lodash/_isIndex.js","webpack:///./~/lodash/_nativeCreate.js","webpack:///./~/lodash/eq.js","webpack:///./~/lodash/isArguments.js","webpack:///./src/common/cv_utils.js","webpack:///./src/common/image_wrapper.js","webpack:///./~/lodash/_baseAssignValue.js","webpack:///./~/lodash/_getNative.js","webpack:///./~/lodash/_toKey.js","webpack:///./~/lodash/isArrayLike.js","webpack:///./~/lodash/isFunction.js","webpack:///./~/lodash/isLength.js","webpack:///./~/lodash/isSymbol.js","webpack:///./~/lodash/merge.js","webpack:///(webpack)/buildin/module.js","webpack:///./src/locator/tracer.js","webpack:///./src/reader/code_39_reader.js","webpack:///./~/gl-vec2/dot.js","webpack:///./~/lodash/_Map.js","webpack:///./~/lodash/_MapCache.js","webpack:///./~/lodash/_assignMergeValue.js","webpack:///./~/lodash/_assignValue.js","webpack:///./~/lodash/_defineProperty.js","webpack:///./~/lodash/_freeGlobal.js","webpack:///./~/lodash/_getPrototype.js","webpack:///./~/lodash/_isPrototype.js","webpack:///./~/lodash/_overRest.js","webpack:///./~/lodash/_safeGet.js","webpack:///./~/lodash/_setToString.js","webpack:///./~/lodash/identity.js","webpack:///./~/lodash/isBuffer.js","webpack:///./~/lodash/isTypedArray.js","webpack:///./~/lodash/keysIn.js","webpack:///(webpack)/buildin/global.js","webpack:///./src/quagga.js","webpack:///./lib/frame_grabber.js","webpack:///./lib/input_stream.js","webpack:///./src/analytics/result_collector.js","webpack:///./src/common/cluster.js","webpack:///./src/common/events.js","webpack:///./src/common/mediaDevices.js","webpack:///./src/common/subImage.js","webpack:///./src/common/typedefs.js","webpack:///./src/config/config.js","webpack:///./src/config/config.node.js","webpack:///./src/decoder/barcode_decoder.js","webpack:///./src/decoder/bresenham.js","webpack:///./src/input/camera_access.js","webpack:///./src/locator/barcode_locator.js","webpack:///./src/locator/rasterizer.js","webpack:///./src/locator/skeletonizer.js","webpack:///./src/reader/2of5_reader.js","webpack:///./src/reader/codabar_reader.js","webpack:///./src/reader/code_128_reader.js","webpack:///./src/reader/code_39_vin_reader.js","webpack:///./src/reader/code_93_reader.js","webpack:///./src/reader/ean_2_reader.js","webpack:///./src/reader/ean_5_reader.js","webpack:///./src/reader/ean_8_reader.js","webpack:///./src/reader/i2of5_reader.js","webpack:///./src/reader/upc_e_reader.js","webpack:///./src/reader/upc_reader.js","webpack:///./~/gl-mat2/copy.js","webpack:///./~/gl-mat2/create.js","webpack:///./~/gl-mat2/invert.js","webpack:///./~/gl-vec2/scale.js","webpack:///./~/gl-vec2/transformMat2.js","webpack:///./~/gl-vec3/clone.js","webpack:///./~/lodash/_Hash.js","webpack:///./~/lodash/_Stack.js","webpack:///./~/lodash/_Uint8Array.js","webpack:///./~/lodash/_apply.js","webpack:///./~/lodash/_arrayLikeKeys.js","webpack:///./~/lodash/_arrayMap.js","webpack:///./~/lodash/_arrayPush.js","webpack:///./~/lodash/_baseCreate.js","webpack:///./~/lodash/_baseFlatten.js","webpack:///./~/lodash/_baseFor.js","webpack:///./~/lodash/_baseGet.js","webpack:///./~/lodash/_baseHasIn.js","webpack:///./~/lodash/_baseIsArguments.js","webpack:///./~/lodash/_baseIsNative.js","webpack:///./~/lodash/_baseIsTypedArray.js","webpack:///./~/lodash/_baseKeysIn.js","webpack:///./~/lodash/_baseMerge.js","webpack:///./~/lodash/_baseMergeDeep.js","webpack:///./~/lodash/_basePick.js","webpack:///./~/lodash/_basePickBy.js","webpack:///./~/lodash/_baseRest.js","webpack:///./~/lodash/_baseSet.js","webpack:///./~/lodash/_baseSetToString.js","webpack:///./~/lodash/_baseTimes.js","webpack:///./~/lodash/_baseToString.js","webpack:///./~/lodash/_baseUnary.js","webpack:///./~/lodash/_cloneArrayBuffer.js","webpack:///./~/lodash/_cloneBuffer.js","webpack:///./~/lodash/_cloneTypedArray.js","webpack:///./~/lodash/_copyArray.js","webpack:///./~/lodash/_copyObject.js","webpack:///./~/lodash/_coreJsData.js","webpack:///./~/lodash/_createAssigner.js","webpack:///./~/lodash/_createBaseFor.js","webpack:///./~/lodash/_flatRest.js","webpack:///./~/lodash/_getRawTag.js","webpack:///./~/lodash/_getValue.js","webpack:///./~/lodash/_hasPath.js","webpack:///./~/lodash/_hashClear.js","webpack:///./~/lodash/_hashDelete.js","webpack:///./~/lodash/_hashGet.js","webpack:///./~/lodash/_hashHas.js","webpack:///./~/lodash/_hashSet.js","webpack:///./~/lodash/_initCloneObject.js","webpack:///./~/lodash/_isFlattenable.js","webpack:///./~/lodash/_isIterateeCall.js","webpack:///./~/lodash/_isKey.js","webpack:///./~/lodash/_isKeyable.js","webpack:///./~/lodash/_isMasked.js","webpack:///./~/lodash/_listCacheClear.js","webpack:///./~/lodash/_listCacheDelete.js","webpack:///./~/lodash/_listCacheGet.js","webpack:///./~/lodash/_listCacheHas.js","webpack:///./~/lodash/_listCacheSet.js","webpack:///./~/lodash/_mapCacheClear.js","webpack:///./~/lodash/_mapCacheDelete.js","webpack:///./~/lodash/_mapCacheGet.js","webpack:///./~/lodash/_mapCacheHas.js","webpack:///./~/lodash/_mapCacheSet.js","webpack:///./~/lodash/_memoizeCapped.js","webpack:///./~/lodash/_nativeKeysIn.js","webpack:///./~/lodash/_nodeUtil.js","webpack:///./~/lodash/_objectToString.js","webpack:///./~/lodash/_overArg.js","webpack:///./~/lodash/_shortOut.js","webpack:///./~/lodash/_stackClear.js","webpack:///./~/lodash/_stackDelete.js","webpack:///./~/lodash/_stackGet.js","webpack:///./~/lodash/_stackHas.js","webpack:///./~/lodash/_stackSet.js","webpack:///./~/lodash/_stringToPath.js","webpack:///./~/lodash/_toSource.js","webpack:///./~/lodash/constant.js","webpack:///./~/lodash/flatten.js","webpack:///./~/lodash/hasIn.js","webpack:///./~/lodash/isArrayLikeObject.js","webpack:///./~/lodash/isPlainObject.js","webpack:///./~/lodash/memoize.js","webpack:///./~/lodash/pick.js","webpack:///./~/lodash/stubFalse.js","webpack:///./~/lodash/toPlainObject.js","webpack:///./~/lodash/toString.js","webpack:///external \"get-pixels\"","webpack:///external \"ndarray\"","webpack:///external \"ndarray-linear-interpolate\""],"names":["BarcodeReader","config","supplements","_row","prototype","_nextUnset","line","start","i","undefined","length","_matchPattern","counter","code","maxSingleError","error","singleError","sum","modulo","barWidth","count","scaled","SINGLE_CODE_ERROR","Number","MAX_VALUE","Math","abs","_nextSet","offset","_correctBars","correction","indices","tmp","_matchTrace","cmpCounter","epsilon","self","isWhite","counterPos","bestMatch","push","end","decodePattern","pattern","result","_decode","reverse","direction","DIRECTION","REVERSE","FORWARD","format","FORMAT","_matchRange","value","_fillCounters","counters","_toCounters","numCounters","ArrayHelper","init","Object","defineProperty","writeable","Exception","StartNotFoundException","CodeNotFoundException","PatternNotFoundException","CONFIG_KEYS","arr","val","l","shuffle","j","x","floor","random","toPointList","row","rows","join","threshold","scoreFunc","queue","apply","maxIndex","max","EANReader","opts","getDefaulConfig","call","keys","forEach","key","default","properties","CODE_L_START","CODE_G_START","START_PATTERN","STOP_PATTERN","MIDDLE_PATTERN","EXTENSION_START_PATTERN","CODE_PATTERN","CODE_FREQUENCY","AVG_CODE_ERROR","create","constructor","_decodeCode","coderange","_findPattern","tryHarder","_findStart","leadingWhitespaceStart","startInfo","_verifyTrailingWhitespace","endInfo","trailingWhitespaceEnd","_findEnd","_calculateFirstDigit","codeFrequency","_decodePayload","decodedCodes","firstDigit","unshift","resultInfo","_checksum","ext","_decodeExtensions","lastCode","supplement","codeset","decode","drawRect","pos","size","ctx","style","strokeStyle","color","fillStyle","lineWidth","beginPath","strokeRect","y","drawPath","path","def","moveTo","lineTo","closePath","stroke","drawImage","imageData","canvasData","getImageData","data","imageDataPos","canvasDataPos","putImageData","imageRef","computeIntegralImage2","computeIntegralImage","thresholdImage","computeHistogram","sharpenLine","determineOtsuThreshold","otsuThreshold","computeBinaryImage","cluster","dilate","erode","subtract","bitwiseOr","countNonZero","topGeneric","grayArrayFromImage","grayArrayFromContext","grayAndHalfSampleFromCanvasData","computeGray","loadImageArray","halfSample","hsv2rgb","_computeDivisors","calculatePatchSize","_parseCSSDimensionValues","computeImageArea","vec2","clone","require","vec3","that","toVec2","toVec3","round","imageWrapper","integralWrapper","width","height","integralImageData","posA","posB","posC","posD","v","u","targetWrapper","targetData","bitsPerPixel","bitShift","bucketCnt","hist","Int32Array","left","center","right","px","mx","determineThreshold","vet","p1","p2","p12","k","m1","m2","m12","kernel","A","B","C","D","avg","points","property","point","clusters","addToCluster","newPoint","found","fits","add","Cluster2","createPoint","Tracer","trace","vec","iteration","maxIterations","top","centerPos","currentPos","idx","forward","from","to","toIdx","predictedPos","thresholdX","thresholdY","match","predicted","DILATE","ERODE","inImageWrapper","outImageWrapper","inImageData","outImageData","yStart1","yStart2","xStart1","xStart2","aImageWrapper","bImageWrapper","resultImageWrapper","aImageData","bImageData","cImageData","list","minIdx","min","score","hit","item","htmlImage","offsetX","array","ctxData","outArray","topRowIdx","bottomRowIdx","endIdx","outWidth","outImgIdx","inWidth","singleChannel","src","callback","canvas","document","createElement","img","Image","onload","getContext","Uint8Array","inImgWrapper","outImgWrapper","inImg","outImg","hsv","rgb","h","s","c","m","r","g","b","n","largeDivisors","divisors","sqrt","concat","_computeIntersection","arr1","arr2","patchSize","imgSize","divisorsX","divisorsY","wideSide","common","nrOfPatchesList","nrOfPatchesMap","nrOfPatchesIdx","medium","nrOfPatches","desiredPatchSize","optimalPatchSize","findPatchSizeForDivisors","dimension","parseFloat","unit","indexOf","_dimensionsConverters","context","bottom","inputWidth","inputHeight","area","parsedArea","reduce","parsed","calculated","sx","sy","sw","sh","ImageWrapper","ArrayType","initialize","Array","inImageWithBorder","imgRef","border","sample","lx","ly","w","base","a","d","e","clearArray","subImage","SubImage","subImageAsCopy","sizeY","sizeX","copyTo","srcData","dstData","get","getSafe","indexMapping","set","zeroBorder","invert","convolve","kx","ky","kSize","accu","moments","labelcount","ysq","labelsum","label","mu11","mu02","mu20","x_","y_","PI","PI_4","m00","m01","m10","m11","m02","m20","theta","rad","isNaN","atan","cos","sin","show","scale","frame","current","pixel","overlay","whiteRgb","blackRgb","searchDirections","labelWrapper","labelData","edgelabel","cy","dir","cx","vertex2D","next","prev","contourTracing","Fv","Cv","P","ldir","Code39Reader","ALPHABETH_STRING","ALPHABET","CHARACTER_ENCODINGS","ASTERISK","decodedChar","lastStart","nextStart","_toPattern","_patternToChar","pop","patternSize","String","fromCharCode","_findNextWidth","minWidth","maxNarrowWidth","numWideBars","wideBarWidth","patternStart","whiteSpaceMustStart","_inputStream","_framegrabber","_stopped","_canvasContainer","image","dom","_inputImageWrapper","_boxSize","_decoder","_workerPool","_onUIThread","_resultCollector","_config","initializeData","initBuffers","BarcodeDecoder","decoder","initInputStream","cb","video","inputStream","type","InputStream","createVideoStream","createImageStream","$viewport","getViewPort","querySelector","appendChild","createLiveStream","CameraAccess","request","constraints","then","trigger","catch","err","setAttribute","setInputStream","addEventListener","canRecord","bind","target","nodeName","nodeType","selector","BarcodeLocator","checkImageConstraints","locator","initCanvas","FrameGrabber","adjustWorkerPool","numOfWorkers","ready","play","className","getCanvasSize","clearFix","getWidth","getHeight","console","log","getBoundingBoxes","locate","transformResult","topRight","getTopRight","xOffset","yOffset","barcodes","moveLine","box","moveBox","boxes","corner","addResult","filter","barcode","codeResult","hasCodeResult","some","publishResult","resultToPublish","Events","publish","locateAndDecode","decodeFromBoundingBoxes","update","availableWorker","workerThread","busy","attachData","grab","worker","postMessage","cmd","buffer","startContinuousUpdate","delay","frequency","timestamp","window","requestAnimFrame","performance","now","initWorker","blobURL","generateWorkerBlob","Worker","onmessage","event","URL","revokeObjectURL","message","configForWorker","workerInterface","factory","Quagga","onProcessed","setReaders","readers","blob","factorySource","__factorySource__","Blob","toString","createObjectURL","capacity","increaseBy","workersToTerminate","slice","terminate","workerInitialized","Config","stop","release","clearEventHandlers","pause","onDetected","subscribe","offDetected","unsubscribe","offProcessed","registerResultCollector","resultCollector","decodeSingle","resultCallback","sequence","once","ImageDebug","ResultCollector","CVUtils","Ndarray","Interp2D","d2","_that","_streamConfig","getConfig","_video_size","getRealWidth","getRealHeight","_canvasSize","_size","_topRight","_data","_grayData","_canvasData","_grayImageArray","transpose","_canvasImageArray","_targetImageArray","hi","lo","_stepSizeX","_stepSizeY","JSON","stringify","videoSize","shape","canvasSize","stepSize","getData","getFrame","scaleAndCrop","Error","getSize","module","exports","GetPixels","frameIdx","paused","loaded","baseUrl","ended","calculatedWidth","calculatedHeight","_eventNames","_eventHandlers","loadImages","mime","pixels","exit","setTimeout","publishEvent","eventName","args","handlers","setWidth","setHeight","stream","setCurrentTime","time","f","setTopRight","setCanvasSize","contains","every","passesFilter","results","capture","matchesConstraints","blacklist","imageSize","toDataURL","getResults","dot","pointMap","updateCenter","pointToAdd","id","otherPoint","similarity","getPoints","getCenter","events","getEvent","subscribers","clearEvents","publishSubscription","subscription","async","subscriber","enumerateDevices","getUserMedia","navigator","mediaDevices","Promise","reject","I","originalSize","updateData","updateFrom","requestAnimationFrame","webkitRequestAnimationFrame","mozRequestAnimationFrame","oRequestAnimationFrame","msRequestAnimationFrame","imul","ah","al","bh","bl","assign","TypeError","index","arguments","nextSource","nextKey","hasOwnProperty","READERS","code_128_reader","Code128Reader","ean_reader","ean_5_reader","EAN5Reader","ean_2_reader","EAN2Reader","ean_8_reader","EAN8Reader","code_39_reader","code_39_vin_reader","Code39VINReader","codabar_reader","CodabarReader","upc_reader","UPCReader","upc_e_reader","UPCEReader","i2of5_reader","I2of5Reader","TwoOfFiveReader","code_93_reader","Code93Reader","inputImageWrapper","_canvas","_barcodeReaders","initReaders","initConfig","$debug","readerConfig","reader","configuration","map","vis","node","prop","debug","showFrequency","showPattern","display","getExtendedLine","angle","extendLine","amount","extension","ceil","getLine","tryDecode","barcodeLine","Bresenham","getBarcodeLine","printFrequency","toBinaryLine","printPattern","tryDecodeBruteForce","lineAngle","sideLength","pow","slices","xdir","ydir","getLineLength","decodeFromBoundingBox","lineLength","drawBoundingBox","atan2","multiple","Slope","DIR","UP","DOWN","x0","y0","x1","y1","steep","deltax","deltay","ystep","read","slope","slope2","extrema","currentDir","rThreshold","fillColor","fillRect","pickConstraints","facingMatching","streamRef","waitForVideo","resolve","attempts","checkVideo","videoWidth","videoHeight","initCamera","srcObject","deprecatedConstraints","videoConstraints","normalized","minAspectRatio","aspectRatio","facing","facingMode","normalizedConstraints","audio","deviceId","enumerateVideoDevices","devices","device","kind","getActiveTrack","tracks","getVideoTracks","getActiveStreamLabel","track","transformMat2","mat2","copy","_currentImageWrapper","_skelImageWrapper","_subImageWrapper","_labelImageWrapper","_patchGrid","_patchLabelGrid","_imageToPatchGrid","_binaryImageWrapper","_patchSize","binary","_numPatches","_skeletonizer","skeletonImageData","ArrayBuffer","global","useWorker","boxFromPatches","patches","overAvg","patch","transMat","minx","miny","maxx","maxy","binarizeImage","findPatches","patchesFound","rasterizer","rasterResult","skeletonize","Rasterizer","rasterize","describePatch","findBiggestConnectedAreas","maxLabel","labelHist","topLabels","sort","el","findBoxes","similarMoments","topCluster","patchPos","eligibleMoments","matchingMoments","minComponentWeight","rasterizeAngularSimilarity","currIdx","notYetProcessed","currentIdx","currentPatch","createContour2D","firstVertex","insideContours","nextpeer","prevpeer","CONTOUR_DIR","CW_DIR","CCW_DIR","UNKNOWN_DIR","OUTSIDE_EDGE","INSIDE_EDGE","tracer","depthlabel","bc","lc","labelindex","colorMap","vertex","p","cc","sc","connectedCount","drawContour","firstContour","pq","iq","q","Skeletonizer","stdlib","foreign","images","inImagePtr","outImagePtr","aImagePtr","bImagePtr","imagePtr","memcpy","srcImagePtr","dstImagePtr","subImagePtr","erodedImagePtr","tempImagePtr","skelImagePtr","done","barSpaceRatio","N","W","writable","startPatternLength","narrowBarWidth","counterLength","_verifyCounterLength","_counters","START_END","MIN_ENCODED_CHARS","MAX_ACCEPTABLE","PADDING","startCounter","_isStartEnd","_verifyWhitespace","_validateResult","_sumCounters","endCounter","_calculatePatternLength","_thresholdResultPattern","categorization","space","narrow","counts","wide","bar","cat","_charToPattern","newkind","char","charCode","charCodeAt","thresholds","_computeAlternatingThreshold","barThreshold","spaceThreshold","bitmask","CODE_SHIFT","CODE_C","CODE_B","CODE_A","START_CODE_A","START_CODE_B","START_CODE_C","STOP_CODE","MODULE_INDICES","_correct","calculateCorrection","multiplier","checksum","rawResult","shiftNext","removeLastCharacter","splice","expected","sumNormalized","sumExpected","patterns","IOQ","AZ09","replace","_checkChecksum","split","_verifyEnd","_verifyChecksums","_decodeExtended","charArray","nextChar","nextCharCode","_matchCheckChar","maxWeight","arrayToCheck","weightedSums","weight","checkChar","parseInt","CHECK_DIGIT_ENCODINGS","extensionChecksum","determineCheckDigit","normalizeBarSpaceWidth","MAX_CORRECTION_FACTOR","counterSum","codeSum","correctionRatio","correctionRatioInverse","_decodePair","counterPair","codes","_determineParity","nrSystem","_convertToUPCA","upca","lastDigit","charAt","substring"],"mappings":"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jJ,SAAS,CAAT,GAAa,CAAlB,IAAuBkC,OAAO,CAAP,CAAvB;AACA+G,aAAKjJ,SAAS,CAAT,GAAa,CAAlB,IAAuBkC,OAAO,CAAP,CAAvB;AACA+G,aAAKjJ,SAAS,CAAT,GAAa,CAAlB,IAAuB,GAAvB;AACH;AACD6H,QAAIuB,YAAJ,CAAiBqQ,KAAjB,EAAwBtK,KAAKnL,CAA7B,EAAgCmL,KAAK9G,CAArC;AACH,CAtBD;;kBAwBeuN,Y;;;;;;AC5Vf;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,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;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,cAAc;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;;AAEA;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;;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;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;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;;AAEA;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;AACA;;AAEA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;;;;;;;;;;ACrBA;;;AAGA,IAAInH,SAAS;AACTsL,sBAAkB,CAAC,CAAC,CAAD,EAAI,CAAJ,CAAD,EAAS,CAAC,CAAD,EAAI,CAAJ,CAAT,EAAiB,CAAC,CAAD,EAAI,CAAJ,CAAjB,EAAyB,CAAC,CAAD,EAAI,CAAC,CAAL,CAAzB,EAAkC,CAAC,CAAD,EAAI,CAAC,CAAL,CAAlC,EAA2C,CAAC,CAAC,CAAF,EAAK,CAAC,CAAN,CAA3C,EAAqD,CAAC,CAAC,CAAF,EAAK,CAAL,CAArD,EAA8D,CAAC,CAAC,CAAF,EAAK,CAAL,CAA9D,CADT;AAEThU,YAAQ,gBAASyF,YAAT,EAAuBwO,YAAvB,EAAqC;AACzC,YAAIlR,YAAY0C,aAAavC,IAA7B;AAAA,YACIgR,YAAYD,aAAa/Q,IAD7B;AAAA,YAEI8Q,mBAAmB,KAAKA,gBAF5B;AAAA,YAGIrO,QAAQF,aAAa5D,IAAb,CAAkB5D,CAH9B;AAAA,YAII2D,GAJJ;;AAMA,iBAAS+G,MAAT,CAAegL,OAAf,EAAwB1R,KAAxB,EAA+BmQ,KAA/B,EAAsC+B,SAAtC,EAAiD;AAC7C,gBAAIpa,CAAJ,EACIuI,CADJ,EAEIrE,CAFJ;;AAIA,iBAAMlE,IAAI,CAAV,EAAaA,IAAI,CAAjB,EAAoBA,GAApB,EAAyB;AACrBuI,oBAAIqR,QAAQS,EAAR,GAAaJ,iBAAiBL,QAAQU,GAAzB,EAA8B,CAA9B,CAAjB;AACApW,oBAAI0V,QAAQW,EAAR,GAAaN,iBAAiBL,QAAQU,GAAzB,EAA8B,CAA9B,CAAjB;AACAzS,sBAAMU,IAAIqD,KAAJ,GAAY1H,CAAlB;AACA,oBAAK8E,UAAUnB,GAAV,MAAmBK,KAApB,KAAgCiS,UAAUtS,GAAV,MAAmB,CAApB,IAA2BsS,UAAUtS,GAAV,MAAmBwQ,KAA7E,CAAJ,EAA0F;AACtF8B,8BAAUtS,GAAV,IAAiBwQ,KAAjB;AACAuB,4BAAQS,EAAR,GAAa9R,CAAb;AACAqR,4BAAQW,EAAR,GAAarW,CAAb;AACA,2BAAO,IAAP;AACH,iBALD,MAKO;AACH,wBAAIiW,UAAUtS,GAAV,MAAmB,CAAvB,EAA0B;AACtBsS,kCAAUtS,GAAV,IAAiBuS,SAAjB;AACH;AACDR,4BAAQU,GAAR,GAAc,CAACV,QAAQU,GAAR,GAAc,CAAf,IAAoB,CAAlC;AACH;AACJ;AACD,mBAAO,KAAP;AACH;;AAED,iBAASE,QAAT,CAAkBtW,CAAlB,EAAqBqE,CAArB,EAAwB+R,GAAxB,EAA6B;AACzB,mBAAO;AACHA,qBAAKA,GADF;AAEHpW,mBAAGA,CAFA;AAGHqE,mBAAGA,CAHA;AAIHkS,sBAAM,IAJH;AAKHC,sBAAM;AALH,aAAP;AAOH;;AAED,iBAASC,eAAT,CAAwBhF,EAAxB,EAA4BD,EAA5B,EAAgC2C,KAAhC,EAAuCnQ,KAAvC,EAA8CkS,SAA9C,EAAyD;AACrD,gBAAIQ,KAAK,IAAT;AAAA,gBACIC,EADJ;AAAA,gBAEIC,CAFJ;AAAA,gBAGIC,IAHJ;AAAA,gBAIInB,UAAU;AACNW,oBAAI7E,EADE;AAEN2E,oBAAI1E,EAFE;AAGN2E,qBAAK;AAHC,aAJd;;AAUA,gBAAI1L,OAAMgL,OAAN,EAAe1R,KAAf,EAAsBmQ,KAAtB,EAA6B+B,SAA7B,CAAJ,EAA6C;AACzCQ,qBAAKJ,SAAS9E,EAAT,EAAaC,EAAb,EAAiBiE,QAAQU,GAAzB,CAAL;AACAO,qBAAKD,EAAL;AACAG,uBAAOnB,QAAQU,GAAf;AACAQ,oBAAIN,SAASZ,QAAQW,EAAjB,EAAqBX,QAAQS,EAA7B,EAAiC,CAAjC,CAAJ;AACAS,kBAAEJ,IAAF,GAASG,EAAT;AACAA,mBAAGJ,IAAH,GAAUK,CAAV;AACAA,kBAAEL,IAAF,GAAS,IAAT;AACAI,qBAAKC,CAAL;AACA,mBAAG;AACClB,4BAAQU,GAAR,GAAc,CAACV,QAAQU,GAAR,GAAc,CAAf,IAAoB,CAAlC;AACA1L,2BAAMgL,OAAN,EAAe1R,KAAf,EAAsBmQ,KAAtB,EAA6B+B,SAA7B;AACA,wBAAIW,SAASnB,QAAQU,GAArB,EAA0B;AACtBO,2BAAGP,GAAH,GAASV,QAAQU,GAAjB;AACAQ,4BAAIN,SAASZ,QAAQW,EAAjB,EAAqBX,QAAQS,EAA7B,EAAiC,CAAjC,CAAJ;AACAS,0BAAEJ,IAAF,GAASG,EAAT;AACAA,2BAAGJ,IAAH,GAAUK,CAAV;AACAA,0BAAEL,IAAF,GAAS,IAAT;AACAI,6BAAKC,CAAL;AACH,qBAPD,MAOO;AACHD,2BAAGP,GAAH,GAASS,IAAT;AACAF,2BAAG3W,CAAH,GAAO0V,QAAQW,EAAf;AACAM,2BAAGtS,CAAH,GAAOqR,QAAQS,EAAf;AACH;AACDU,2BAAOnB,QAAQU,GAAf;AACH,iBAhBD,QAgBSV,QAAQW,EAAR,KAAe7E,EAAf,IAAqBkE,QAAQS,EAAR,KAAe1E,EAhB7C;AAiBAiF,mBAAGF,IAAH,GAAUG,GAAGH,IAAb;AACAG,mBAAGH,IAAH,CAAQD,IAAR,GAAeG,EAAf;AACH;AACD,mBAAOA,EAAP;AACH;;AAED,eAAO;AACHhM,mBAAO,eAASgL,OAAT,EAAkB1R,KAAlB,EAAyBmQ,KAAzB,EAAgC+B,SAAhC,EAA2C;AAC9C,uBAAOxL,OAAMgL,OAAN,EAAe1R,KAAf,EAAsBmQ,KAAtB,EAA6B+B,SAA7B,CAAP;AACH,aAHE;AAIHO,4BAAgB,wBAAShF,EAAT,EAAaD,EAAb,EAAiB2C,KAAjB,EAAwBnQ,KAAxB,EAA+BkS,SAA/B,EAA0C;AACtD,uBAAOO,gBAAehF,EAAf,EAAmBD,EAAnB,EAAuB2C,KAAvB,EAA8BnQ,KAA9B,EAAqCkS,SAArC,CAAP;AACH;AANE,SAAP;AAQH;AA9FQ,CAAb;;kBAiGgBzL,M;;;;;;;;;;;ACpGhB;;;;AACA;;;;;;AAEA,SAASqM,YAAT,GAAwB;AACpBxb,6BAAc0F,IAAd,CAAmB,IAAnB;AACH;;AAED,IAAIK,aAAa;AACb0V,sBAAkB,EAACnY,OAAO,8CAAR,EADL;AAEboY,cAAU,EAACpY,OAAO,CAAC,EAAD,EAAK,EAAL,EAAS,EAAT,EAAa,EAAb,EAAiB,EAAjB,EAAqB,EAArB,EAAyB,EAAzB,EAA6B,EAA7B,EAAiC,EAAjC,EAAqC,EAArC,EAAyC,EAAzC,EAA6C,EAA7C,EAAiD,EAAjD,EAAqD,EAArD,EAAyD,EAAzD,EAA6D,EAA7D,EAAiE,EAAjE,EAAqE,EAArE,EAAyE,EAAzE,EAA6E,EAA7E,EAAiF,EAAjF,EAAqF,EAArF,EAAyF,EAAzF,EAA6F,EAA7F,EACd,EADc,EACV,EADU,EACN,EADM,EACF,EADE,EACE,EADF,EACM,EADN,EACU,EADV,EACc,EADd,EACkB,EADlB,EACsB,EADtB,EAC0B,EAD1B,EAC8B,EAD9B,EACkC,EADlC,EACsC,EADtC,EAC0C,EAD1C,EAC8C,EAD9C,EACkD,EADlD,EACsD,EADtD,EAC0D,EAD1D,EAC8D,EAD9D,CAAR,EAFG;AAIbqY,yBAAqB,EAACrY,OAAO,CAAC,KAAD,EAAQ,KAAR,EAAe,KAAf,EAAsB,KAAtB,EAA6B,KAA7B,EAAoC,KAApC,EAA2C,KAA3C,EAAkD,KAAlD,EAAyD,KAAzD,EAAgE,KAAhE,EAAuE,KAAvE,EAA8E,KAA9E,EACzB,KADyB,EAClB,KADkB,EACX,KADW,EACJ,KADI,EACG,KADH,EACU,KADV,EACiB,KADjB,EACwB,KADxB,EAC+B,KAD/B,EACsC,KADtC,EAC6C,KAD7C,EACoD,KADpD,EAC2D,KAD3D,EACkE,KADlE,EACyE,KADzE,EACgF,KADhF,EAEzB,KAFyB,EAElB,KAFkB,EAEX,KAFW,EAEJ,KAFI,EAEG,KAFH,EAEU,KAFV,EAEiB,KAFjB,EAEwB,KAFxB,EAE+B,KAF/B,EAEsC,KAFtC,EAE6C,KAF7C,EAEoD,KAFpD,EAE2D,KAF3D,EAEkE,KAFlE,EAEyE,KAFzE,EAEgF,KAFhF,CAAR,EAJR;AAQbsY,cAAU,EAACtY,OAAO,KAAR,EARG;AASbF,YAAQ,EAACE,OAAO,SAAR,EAAmBS,WAAW,KAA9B;AATK,CAAjB;;AAYAyX,aAAapb,SAAb,GAAyByD,OAAO4C,MAAP,CAAczG,yBAAcI,SAA5B,EAAuC2F,UAAvC,CAAzB;AACAyV,aAAapb,SAAb,CAAuBsG,WAAvB,GAAqC8U,YAArC;;AAEAA,aAAapb,SAAb,CAAuByC,OAAvB,GAAiC,YAAW;AACxC,QAAIT,OAAO,IAAX;AAAA,QACIoB,WAAW,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,EAAsB,CAAtB,EAAyB,CAAzB,CADf;AAAA,QAEIZ,SAAS,EAFb;AAAA,QAGIrC,QAAQ6B,KAAK2E,UAAL,EAHZ;AAAA,QAII8U,WAJJ;AAAA,QAKIC,SALJ;AAAA,QAMInZ,OANJ;AAAA,QAOIoZ,SAPJ;;AASA,QAAI,CAACxb,KAAL,EAAY;AACR,eAAO,IAAP;AACH;AACDwb,gBAAY3Z,KAAKT,QAAL,CAAcS,KAAKjC,IAAnB,EAAyBI,MAAMkC,GAA/B,CAAZ;;AAEA,OAAG;AACCe,mBAAWpB,KAAKqB,WAAL,CAAiBsY,SAAjB,EAA4BvY,QAA5B,CAAX;AACAb,kBAAUP,KAAK4Z,UAAL,CAAgBxY,QAAhB,CAAV;AACA,YAAIb,UAAU,CAAd,EAAiB;AACb,mBAAO,IAAP;AACH;AACDkZ,sBAAczZ,KAAK6Z,cAAL,CAAoBtZ,OAApB,CAAd;AACA,YAAIkZ,cAAc,CAAlB,EAAoB;AAChB,mBAAO,IAAP;AACH;AACDjZ,eAAOJ,IAAP,CAAYqZ,WAAZ;AACAC,oBAAYC,SAAZ;AACAA,qBAAapY,uBAAY1C,GAAZ,CAAgBuC,QAAhB,CAAb;AACAuY,oBAAY3Z,KAAKT,QAAL,CAAcS,KAAKjC,IAAnB,EAAyB4b,SAAzB,CAAZ;AACH,KAdD,QAcSF,gBAAgB,GAdzB;AAeAjZ,WAAOsZ,GAAP;;AAEA,QAAI,CAACtZ,OAAOlC,MAAZ,EAAoB;AAChB,eAAO,IAAP;AACH;;AAED,QAAI,CAAC0B,KAAK8E,yBAAL,CAA+B4U,SAA/B,EAA0CC,SAA1C,EAAqDvY,QAArD,CAAL,EAAqE;AACjE,eAAO,IAAP;AACH;;AAED,WAAO;AACH3C,cAAM+B,OAAOoC,IAAP,CAAY,EAAZ,CADH;AAEHzE,eAAOA,MAAMA,KAFV;AAGHkC,aAAKsZ,SAHF;AAIH9U,mBAAW1G,KAJR;AAKHkH,sBAAc7E;AALX,KAAP;AAOH,CA/CD;;AAiDA4Y,aAAapb,SAAb,CAAuB8G,yBAAvB,GAAmD,UAAS4U,SAAT,EAAoBC,SAApB,EAA+BvY,QAA/B,EAAyC;AACxF,QAAI4D,qBAAJ;AAAA,QACI+U,cAAcxY,uBAAY1C,GAAZ,CAAgBuC,QAAhB,CADlB;;AAGA4D,4BAAwB2U,YAAYD,SAAZ,GAAwBK,WAAhD;AACA,QAAK/U,wBAAwB,CAAzB,IAA+B+U,WAAnC,EAAgD;AAC5C,eAAO,IAAP;AACH;AACD,WAAO,KAAP;AACH,CATD;;AAWAX,aAAapb,SAAb,CAAuB6b,cAAvB,GAAwC,UAAStZ,OAAT,EAAkB;AACtD,QAAInC,CAAJ;AAAA,QACI4B,OAAO,IADX;;AAGA,SAAK5B,IAAI,CAAT,EAAYA,IAAI4B,KAAKuZ,mBAAL,CAAyBjb,MAAzC,EAAiDF,GAAjD,EAAsD;AAClD,YAAI4B,KAAKuZ,mBAAL,CAAyBnb,CAAzB,MAAgCmC,OAApC,EAA6C;AACzC,mBAAOyZ,OAAOC,YAAP,CAAoBja,KAAKsZ,QAAL,CAAclb,CAAd,CAApB,CAAP;AACH;AACJ;AACD,WAAO,CAAC,CAAR;AACH,CAVD;;AAYAgb,aAAapb,SAAb,CAAuBkc,cAAvB,GAAwC,UAAS9Y,QAAT,EAAmB4W,OAAnB,EAA4B;AAChE,QAAI5Z,CAAJ;AAAA,QACI+b,WAAWhb,OAAOC,SADtB;;AAGA,SAAKhB,IAAI,CAAT,EAAYA,IAAIgD,SAAS9C,MAAzB,EAAiCF,GAAjC,EAAsC;AAClC,YAAIgD,SAAShD,CAAT,IAAc+b,QAAd,IAA0B/Y,SAAShD,CAAT,IAAc4Z,OAA5C,EAAqD;AACjDmC,uBAAW/Y,SAAShD,CAAT,CAAX;AACH;AACJ;;AAED,WAAO+b,QAAP;AACH,CAXD;;AAaAf,aAAapb,SAAb,CAAuB4b,UAAvB,GAAoC,UAASxY,QAAT,EAAmB;AACnD,QAAIE,cAAcF,SAAS9C,MAA3B;AAAA,QACI8b,iBAAiB,CADrB;AAAA,QAEIC,cAAc/Y,WAFlB;AAAA,QAGIgZ,eAAe,CAHnB;AAAA,QAIIta,OAAO,IAJX;AAAA,QAKIO,OALJ;AAAA,QAMInC,CANJ;;AAQA,WAAOic,cAAc,CAArB,EAAwB;AACpBD,yBAAiBpa,KAAKka,cAAL,CAAoB9Y,QAApB,EAA8BgZ,cAA9B,CAAjB;AACAC,sBAAc,CAAd;AACA9Z,kBAAU,CAAV;AACA,aAAKnC,IAAI,CAAT,EAAYA,IAAIkD,WAAhB,EAA6BlD,GAA7B,EAAkC;AAC9B,gBAAIgD,SAAShD,CAAT,IAAcgc,cAAlB,EAAkC;AAC9B7Z,2BAAW,KAAMe,cAAc,CAAd,GAAkBlD,CAAnC;AACAic;AACAC,gCAAgBlZ,SAAShD,CAAT,CAAhB;AACH;AACJ;;AAED,YAAIic,gBAAgB,CAApB,EAAuB;AACnB,iBAAKjc,IAAI,CAAT,EAAYA,IAAIkD,WAAJ,IAAmB+Y,cAAc,CAA7C,EAAgDjc,GAAhD,EAAqD;AACjD,oBAAIgD,SAAShD,CAAT,IAAcgc,cAAlB,EAAkC;AAC9BC;AACA,wBAAKjZ,SAAShD,CAAT,IAAc,CAAf,IAAqBkc,YAAzB,EAAuC;AACnC,+BAAO,CAAC,CAAR;AACH;AACJ;AACJ;AACD,mBAAO/Z,OAAP;AACH;AACJ;AACD,WAAO,CAAC,CAAR;AACH,CAlCD;;AAoCA6Y,aAAapb,SAAb,CAAuB2G,UAAvB,GAAoC,YAAW;AAC3C,QAAI3E,OAAO,IAAX;AAAA,QACIR,SAASQ,KAAKT,QAAL,CAAcS,KAAKjC,IAAnB,CADb;AAAA,QAEIwc,eAAe/a,MAFnB;AAAA,QAGIhB,UAAU,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,EAAsB,CAAtB,EAAyB,CAAzB,CAHd;AAAA,QAII0B,aAAa,CAJjB;AAAA,QAKID,UAAU,KALd;AAAA,QAMI7B,CANJ;AAAA,QAOIiE,CAPJ;AAAA,QAQImY,mBARJ;;AAUA,SAAMpc,IAAIoB,MAAV,EAAkBpB,IAAI4B,KAAKjC,IAAL,CAAUO,MAAhC,EAAwCF,GAAxC,EAA6C;AACzC,YAAI4B,KAAKjC,IAAL,CAAUK,CAAV,IAAe6B,OAAnB,EAA4B;AACxBzB,oBAAQ0B,UAAR;AACH,SAFD,MAEO;AACH,gBAAIA,eAAe1B,QAAQF,MAAR,GAAiB,CAApC,EAAuC;AACnC;AACA,oBAAI0B,KAAK4Z,UAAL,CAAgBpb,OAAhB,MAA6BwB,KAAKwZ,QAAtC,EAAgD;AAC5CgB,0CAAsBnb,KAAKkD,KAAL,CAAWlD,KAAK6D,GAAL,CAAS,CAAT,EAAYqX,eAAgB,CAACnc,IAAImc,YAAL,IAAqB,CAAjD,CAAX,CAAtB;AACA,wBAAIva,KAAKiB,WAAL,CAAiBuZ,mBAAjB,EAAsCD,YAAtC,EAAoD,CAApD,CAAJ,EAA4D;AACxD,+BAAO;AACHpc,mCAAOoc,YADJ;AAEHla,iCAAKjC;AAFF,yBAAP;AAIH;AACJ;;AAEDmc,gCAAgB/b,QAAQ,CAAR,IAAaA,QAAQ,CAAR,CAA7B;AACA,qBAAM6D,IAAI,CAAV,EAAaA,IAAI,CAAjB,EAAoBA,GAApB,EAAyB;AACrB7D,4BAAQ6D,CAAR,IAAa7D,QAAQ6D,IAAI,CAAZ,CAAb;AACH;AACD7D,wBAAQ,CAAR,IAAa,CAAb;AACAA,wBAAQ,CAAR,IAAa,CAAb;AACA0B;AACH,aAnBD,MAmBO;AACHA;AACH;AACD1B,oBAAQ0B,UAAR,IAAsB,CAAtB;AACAD,sBAAU,CAACA,OAAX;AACH;AACJ;AACD,WAAO,IAAP;AACH,CA1CD;;kBA4CemZ,Y;;;;;;AC3Lf;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,aAAa,OAAO;AACpB;AACA;AACA;AACA,C;;;;;;ACXA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACNA;AACA;AACA;AACA;AACA;;AAEA;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;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;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;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB;AACA,GAAG;AACH,CAAC;;AAED;;;;;;;ACVA;AACA;;AAEA;;;;;;;;ACHA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;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;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;;AAEA;;;;;;;ACbA;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;AACA;;AAEA;AACA;;AAEA;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;AACA;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;;;;;;;AC1BA;AACA;AACA;;AAEA;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;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;;AAEA;AACA;AACA,4CAA4C;;AAE5C;;;;;;;;;;;;;;;;kQCpB0C;;;AAA1C;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;AAEA,IAAM9P,OAAO;AACTC,WAAO,mBAAAC,CAAQ,CAAR;AADE,CAAb;;AAIA,IAAIiR,YAAJ;AAAA,IACIC,aADJ;AAAA,IAEIC,QAFJ;AAAA,IAGIC,mBAAmB;AACfzU,SAAK;AACD0U,eAAO,IADN;AAED3C,iBAAS;AAFR,KADU;AAKf4C,SAAK;AACDD,eAAO,IADN;AAED3C,iBAAS;AAFR;AALU,CAHvB;AAAA,IAaI6C,kBAbJ;AAAA,IAcIC,QAdJ;AAAA,IAeIC,QAfJ;AAAA,IAgBIC,cAAc,EAhBlB;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O/B,IAAjB,IAAyB+B,OAAO/B,IAAP,CAAYH,MAAZ,KAAuB,EAAhD,IAAsDkC,OAAO/B,IAAP,CAAYogC,MAAZ,CAAmB,CAAnB,MAA0B,GAApF,EAAyF;AACrFr+B,eAAO/B,IAAP,GAAc+B,OAAO/B,IAAP,CAAYqgC,SAAZ,CAAsB,CAAtB,CAAd;AACA,eAAOt+B,MAAP;AACH;AACD,WAAO,IAAP;AACH,CARD;;kBAUe8rB,S;;;;;;ACvBf;;AAEA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AChBA;;AAEA;AACA;AACA;AACA;AACA,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;;;;;;AC1BA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA,C;;;;;;ACdA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,C;;;;;;AChBA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,C;;;;;;ACdA;AACA;AACA;AACA;AACA;;AAEA;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;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;;AAEA;AACA;;AAEA;;;;;;;ACLA;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;AACA;AACA;AACA;AACA;AACA;;AAEA;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,MAAM;AACjB,WAAW,SAAS;AACpB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;;;;;;;AC7BA;AACA;;AAEA;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,EAAE;AACf;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvBA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;;AAEA;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;AACA;AACA;;AAEA;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;;AAEA;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;;AAEA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7FA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;AClBA;AACA;AACA;;AAEA;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;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;AACA;AACA;AACA;AACA;;AAEA;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;AACA;AACA;AACA;AACA,+CAA+C;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC9CA;AACA;AACA;;AAEA;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;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;;AAEA;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,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;;AAEA;AACA;AACA;AACA;AACA,WAAW,YAAY;AACvB,aAAa,YAAY;AACzB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;;AClCA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;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;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;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;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;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;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;AACA;AACA;AACA;AACA;AACA;;AAEA;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;;AAEA;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;;AAEA;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;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;;AAEA;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;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,EAAE;AACb,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA;AACA;;AAEA;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;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;;AAEA;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;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;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;;AAEA;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;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH,CAAC;;AAED;;;;;;;;AC7BA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;;AAEA;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;AACA;AACA;;AAEA;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;;AAEA;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;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;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,SAAS;AACtB;AACA;AACA,wCAAwC,SAAS;AACjD;AACA;AACA,WAAW,SAAS,GAAG,SAAS;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;;AAEA;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;;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;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;AACA;;AAEA;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;;AAEA;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;AACA;;AAEA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;;AAEA;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;;AAEA;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,iD;;;;;;ACAA,iD;;;;;;ACAA,iD","file":"quagga.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"get-pixels\"), require(\"ndarray\"), require(\"ndarray-linear-interpolate\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"get-pixels\", \"ndarray\", \"ndarray-linear-interpolate\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Quagga\"] = factory(require(\"get-pixels\"), require(\"ndarray\"), require(\"ndarray-linear-interpolate\"));\n\telse\n\t\troot[\"Quagga\"] = factory(root[\"get-pixels\"], root[\"ndarray\"], root[\"ndarray-linear-interpolate\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE_165__, __WEBPACK_EXTERNAL_MODULE_166__, __WEBPACK_EXTERNAL_MODULE_167__) {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 168);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 1f51d4a969eafeb5a351","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isObject.js\n// module id = 0\n// module chunks = 0","import ArrayHelper from '../common/array_helper';\r\n\r\nfunction BarcodeReader(config, supplements) {\r\n    this._row = [];\r\n    this.config = config || {};\r\n    this.supplements = supplements;\r\n    return this;\r\n}\r\n\r\nBarcodeReader.prototype._nextUnset = function(line, start) {\r\n    var i;\r\n\r\n    if (start === undefined) {\r\n        start = 0;\r\n    }\r\n    for (i = start; i < line.length; i++) {\r\n        if (!line[i]) {\r\n            return i;\r\n        }\r\n    }\r\n    return line.length;\r\n};\r\n\r\nBarcodeReader.prototype._matchPattern = function(counter, code, maxSingleError) {\r\n    var i,\r\n        error = 0,\r\n        singleError = 0,\r\n        sum = 0,\r\n        modulo = 0,\r\n        barWidth,\r\n        count,\r\n        scaled;\r\n\r\n    maxSingleError = maxSingleError || this.SINGLE_CODE_ERROR || 1;\r\n\r\n    for (i = 0; i < counter.length; i++) {\r\n        sum += counter[i];\r\n        modulo += code[i];\r\n    }\r\n    if (sum < modulo) {\r\n        return Number.MAX_VALUE;\r\n    }\r\n    barWidth = sum / modulo;\r\n    maxSingleError *= barWidth;\r\n\r\n    for (i = 0; i < counter.length; i++) {\r\n        count = counter[i];\r\n        scaled = code[i] * barWidth;\r\n        singleError = Math.abs(count - scaled) / scaled;\r\n        if (singleError > maxSingleError) {\r\n            return Number.MAX_VALUE;\r\n        }\r\n        error += singleError;\r\n    }\r\n    return error / modulo;\r\n};\r\n\r\nBarcodeReader.prototype._nextSet = function(line, offset) {\r\n    var i;\r\n\r\n    offset = offset || 0;\r\n    for (i = offset; i < line.length; i++) {\r\n        if (line[i]) {\r\n            return i;\r\n        }\r\n    }\r\n    return line.length;\r\n};\r\n\r\nBarcodeReader.prototype._correctBars = function(counter, correction, indices) {\r\n    var length = indices.length,\r\n        tmp = 0;\r\n    while(length--) {\r\n        tmp = counter[indices[length]] * (1 - ((1 - correction) / 2));\r\n        if (tmp > 1) {\r\n            counter[indices[length]] = tmp;\r\n        }\r\n    }\r\n}\r\n\r\nBarcodeReader.prototype._matchTrace = function(cmpCounter, epsilon) {\r\n    var counter = [],\r\n        i,\r\n        self = this,\r\n        offset = self._nextSet(self._row),\r\n        isWhite = !self._row[offset],\r\n        counterPos = 0,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: 0\r\n        },\r\n        error;\r\n\r\n    if (cmpCounter) {\r\n        for ( i = 0; i < cmpCounter.length; i++) {\r\n            counter.push(0);\r\n        }\r\n        for ( i = offset; i < self._row.length; i++) {\r\n            if (self._row[i] ^ isWhite) {\r\n                counter[counterPos]++;\r\n            } else {\r\n                if (counterPos === counter.length - 1) {\r\n                    error = self._matchPattern(counter, cmpCounter);\r\n\r\n                    if (error < epsilon) {\r\n                        bestMatch.start = i - offset;\r\n                        bestMatch.end = i;\r\n                        bestMatch.counter = counter;\r\n                        return bestMatch;\r\n                    } else {\r\n                        return null;\r\n                    }\r\n                } else {\r\n                    counterPos++;\r\n                }\r\n                counter[counterPos] = 1;\r\n                isWhite = !isWhite;\r\n            }\r\n        }\r\n    } else {\r\n        counter.push(0);\r\n        for ( i = offset; i < self._row.length; i++) {\r\n            if (self._row[i] ^ isWhite) {\r\n                counter[counterPos]++;\r\n            } else {\r\n                counterPos++;\r\n                counter.push(0);\r\n                counter[counterPos] = 1;\r\n                isWhite = !isWhite;\r\n            }\r\n        }\r\n    }\r\n\r\n    // if cmpCounter was not given\r\n    bestMatch.start = offset;\r\n    bestMatch.end = self._row.length - 1;\r\n    bestMatch.counter = counter;\r\n    return bestMatch;\r\n};\r\n\r\nBarcodeReader.prototype.decodePattern = function(pattern) {\r\n    var self = this,\r\n        result;\r\n\r\n    self._row = pattern;\r\n    result = self._decode();\r\n    if (result === null) {\r\n        self._row.reverse();\r\n        result = self._decode();\r\n        if (result) {\r\n            result.direction = BarcodeReader.DIRECTION.REVERSE;\r\n            result.start = self._row.length - result.start;\r\n            result.end = self._row.length - result.end;\r\n        }\r\n    } else {\r\n        result.direction = BarcodeReader.DIRECTION.FORWARD;\r\n    }\r\n    if (result) {\r\n        result.format = self.FORMAT;\r\n    }\r\n    return result;\r\n};\r\n\r\nBarcodeReader.prototype._matchRange = function(start, end, value) {\r\n    var i;\r\n\r\n    start = start < 0 ? 0 : start;\r\n    for (i = start; i < end; i++) {\r\n        if (this._row[i] !== value) {\r\n            return false;\r\n        }\r\n    }\r\n    return true;\r\n};\r\n\r\nBarcodeReader.prototype._fillCounters = function(offset, end, isWhite) {\r\n    var self = this,\r\n        counterPos = 0,\r\n        i,\r\n        counters = [];\r\n\r\n    isWhite = (typeof isWhite !== 'undefined') ? isWhite : true;\r\n    offset = (typeof offset !== 'undefined') ? offset : self._nextUnset(self._row);\r\n    end = end || self._row.length;\r\n\r\n    counters[counterPos] = 0;\r\n    for (i = offset; i < end; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counters[counterPos]++;\r\n        } else {\r\n            counterPos++;\r\n            counters[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return counters;\r\n};\r\n\r\nBarcodeReader.prototype._toCounters = function(start, counter) {\r\n    var self = this,\r\n        numCounters = counter.length,\r\n        end = self._row.length,\r\n        isWhite = !self._row[start],\r\n        i,\r\n        counterPos = 0;\r\n\r\n    ArrayHelper.init(counter, 0);\r\n\r\n    for ( i = start; i < end; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            counterPos++;\r\n            if (counterPos === numCounters) {\r\n                break;\r\n            } else {\r\n                counter[counterPos] = 1;\r\n                isWhite = !isWhite;\r\n            }\r\n        }\r\n    }\r\n\r\n    return counter;\r\n};\r\n\r\nObject.defineProperty(BarcodeReader.prototype, \"FORMAT\", {\r\n    value: 'unknown',\r\n    writeable: false\r\n});\r\n\r\nBarcodeReader.DIRECTION = {\r\n    FORWARD: 1,\r\n    REVERSE: -1\r\n};\r\n\r\nBarcodeReader.Exception = {\r\n    StartNotFoundException: \"Start-Info was not found!\",\r\n    CodeNotFoundException: \"Code could not be found!\",\r\n    PatternNotFoundException: \"Pattern could not be found!\"\r\n};\r\n\r\nBarcodeReader.CONFIG_KEYS = {};\r\n\r\nexport default BarcodeReader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/barcode_reader.js","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArray.js\n// module id = 2\n// module chunks = 0","export default {\r\n    init: function(arr, val) {\r\n        var l = arr.length;\r\n        while (l--) {\r\n            arr[l] = val;\r\n        }\r\n    },\r\n\r\n    /**\r\n     * Shuffles the content of an array\r\n     * @return {Array} the array itself shuffled\r\n     */\r\n    shuffle: function(arr) {\r\n        var i = arr.length - 1, j, x;\r\n        for (i; i >= 0; i--) {\r\n            j = Math.floor(Math.random() * i);\r\n            x = arr[i];\r\n            arr[i] = arr[j];\r\n            arr[j] = x;\r\n        }\r\n        return arr;\r\n    },\r\n\r\n    toPointList: function(arr) {\r\n        var i, j, row = [], rows = [];\r\n        for ( i = 0; i < arr.length; i++) {\r\n            row = [];\r\n            for ( j = 0; j < arr[i].length; j++) {\r\n                row[j] = arr[i][j];\r\n            }\r\n            rows[i] = \"[\" + row.join(\",\") + \"]\";\r\n        }\r\n        return \"[\" + rows.join(\",\\r\\n\") + \"]\";\r\n    },\r\n\r\n    /**\r\n     * returns the elements which's score is bigger than the threshold\r\n     * @return {Array} the reduced array\r\n     */\r\n    threshold: function(arr, threshold, scoreFunc) {\r\n        var i, queue = [];\r\n        for ( i = 0; i < arr.length; i++) {\r\n            if (scoreFunc.apply(arr, [arr[i]]) >= threshold) {\r\n                queue.push(arr[i]);\r\n            }\r\n        }\r\n        return queue;\r\n    },\r\n\r\n    maxIndex: function(arr) {\r\n        var i, max = 0;\r\n        for ( i = 0; i < arr.length; i++) {\r\n            if (arr[i] > arr[max]) {\r\n                max = i;\r\n            }\r\n        }\r\n        return max;\r\n    },\r\n\r\n    max: function(arr) {\r\n        var i, max = 0;\r\n        for ( i = 0; i < arr.length; i++) {\r\n            if (arr[i] > max) {\r\n                max = arr[i];\r\n            }\r\n        }\r\n        return max;\r\n    },\r\n\r\n    sum: function(arr) {\r\n        var length = arr.length,\r\n            sum = 0;\r\n\r\n        while (length--) {\r\n            sum += arr[length];\r\n        }\r\n        return sum;\r\n    }\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/array_helper.js","import BarcodeReader from './barcode_reader';\r\nimport {merge} from 'lodash';\r\n\r\nfunction EANReader(opts, supplements) {\r\n    opts = merge(getDefaulConfig(), opts);\r\n    BarcodeReader.call(this, opts, supplements);\r\n}\r\n\r\nfunction getDefaulConfig() {\r\n    var config = {};\r\n\r\n    Object.keys(EANReader.CONFIG_KEYS).forEach(function(key) {\r\n        config[key] = EANReader.CONFIG_KEYS[key].default;\r\n    });\r\n    return config;\r\n}\r\n\r\nvar properties = {\r\n    CODE_L_START: {value: 0},\r\n    CODE_G_START: {value: 10},\r\n    START_PATTERN: {value: [1, 1, 1]},\r\n    STOP_PATTERN: {value: [1, 1, 1]},\r\n    MIDDLE_PATTERN: {value: [1, 1, 1, 1, 1]},\r\n    EXTENSION_START_PATTERN: {value: [1, 1, 2]},\r\n    CODE_PATTERN: {value: [\r\n        [3, 2, 1, 1],\r\n        [2, 2, 2, 1],\r\n        [2, 1, 2, 2],\r\n        [1, 4, 1, 1],\r\n        [1, 1, 3, 2],\r\n        [1, 2, 3, 1],\r\n        [1, 1, 1, 4],\r\n        [1, 3, 1, 2],\r\n        [1, 2, 1, 3],\r\n        [3, 1, 1, 2],\r\n        [1, 1, 2, 3],\r\n        [1, 2, 2, 2],\r\n        [2, 2, 1, 2],\r\n        [1, 1, 4, 1],\r\n        [2, 3, 1, 1],\r\n        [1, 3, 2, 1],\r\n        [4, 1, 1, 1],\r\n        [2, 1, 3, 1],\r\n        [3, 1, 2, 1],\r\n        [2, 1, 1, 3]\r\n    ]},\r\n    CODE_FREQUENCY: {value: [0, 11, 13, 14, 19, 25, 28, 21, 22, 26]},\r\n    SINGLE_CODE_ERROR: {value: 0.70},\r\n    AVG_CODE_ERROR: {value: 0.48},\r\n    FORMAT: {value: \"ean_13\", writeable: false}\r\n};\r\n\r\nEANReader.prototype = Object.create(BarcodeReader.prototype, properties);\r\nEANReader.prototype.constructor = EANReader;\r\n\r\nEANReader.prototype._decodeCode = function(start, coderange) {\r\n    var counter = [0, 0, 0, 0],\r\n        i,\r\n        self = this,\r\n        offset = start,\r\n        isWhite = !self._row[offset],\r\n        counterPos = 0,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: start,\r\n            end: start\r\n        },\r\n        code,\r\n        error;\r\n\r\n    if (!coderange) {\r\n        coderange = self.CODE_PATTERN.length;\r\n    }\r\n\r\n    for ( i = offset; i < self._row.length; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            if (counterPos === counter.length - 1) {\r\n                for (code = 0; code < coderange; code++) {\r\n                    error = self._matchPattern(counter, self.CODE_PATTERN[code]);\r\n                    if (error < bestMatch.error) {\r\n                        bestMatch.code = code;\r\n                        bestMatch.error = error;\r\n                    }\r\n                }\r\n                bestMatch.end = i;\r\n                if (bestMatch.error > self.AVG_CODE_ERROR) {\r\n                    return null;\r\n                }\r\n                return bestMatch;\r\n            } else {\r\n                counterPos++;\r\n            }\r\n            counter[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nEANReader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder, epsilon) {\r\n    var counter = [],\r\n        self = this,\r\n        i,\r\n        counterPos = 0,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: 0,\r\n            end: 0\r\n        },\r\n        error,\r\n        j,\r\n        sum;\r\n\r\n    if (!offset) {\r\n        offset = self._nextSet(self._row);\r\n    }\r\n\r\n    if (isWhite === undefined) {\r\n        isWhite = false;\r\n    }\r\n\r\n    if (tryHarder === undefined) {\r\n        tryHarder = true;\r\n    }\r\n\r\n    if ( epsilon === undefined) {\r\n        epsilon = self.AVG_CODE_ERROR;\r\n    }\r\n\r\n    for ( i = 0; i < pattern.length; i++) {\r\n        counter[i] = 0;\r\n    }\r\n\r\n    for ( i = offset; i < self._row.length; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            if (counterPos === counter.length - 1) {\r\n                sum = 0;\r\n                for ( j = 0; j < counter.length; j++) {\r\n                    sum += counter[j];\r\n                }\r\n                error = self._matchPattern(counter, pattern);\r\n\r\n                if (error < epsilon) {\r\n                    bestMatch.error = error;\r\n                    bestMatch.start = i - sum;\r\n                    bestMatch.end = i;\r\n                    return bestMatch;\r\n                }\r\n                if (tryHarder) {\r\n                    for ( j = 0; j < counter.length - 2; j++) {\r\n                        counter[j] = counter[j + 2];\r\n                    }\r\n                    counter[counter.length - 2] = 0;\r\n                    counter[counter.length - 1] = 0;\r\n                    counterPos--;\r\n                } else {\r\n                    return null;\r\n                }\r\n            } else {\r\n                counterPos++;\r\n            }\r\n            counter[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nEANReader.prototype._findStart = function() {\r\n    var self = this,\r\n        leadingWhitespaceStart,\r\n        offset = self._nextSet(self._row),\r\n        startInfo;\r\n\r\n    while (!startInfo) {\r\n        startInfo = self._findPattern(self.START_PATTERN, offset);\r\n        if (!startInfo) {\r\n            return null;\r\n        }\r\n        leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);\r\n        if (leadingWhitespaceStart >= 0) {\r\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\r\n                return startInfo;\r\n            }\r\n        }\r\n        offset = startInfo.end;\r\n        startInfo = null;\r\n    }\r\n};\r\n\r\nEANReader.prototype._verifyTrailingWhitespace = function(endInfo) {\r\n    var self = this,\r\n        trailingWhitespaceEnd;\r\n\r\n    trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);\r\n    if (trailingWhitespaceEnd < self._row.length) {\r\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\r\n            return endInfo;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nEANReader.prototype._findEnd = function(offset, isWhite) {\r\n    var self = this,\r\n        endInfo = self._findPattern(self.STOP_PATTERN, offset, isWhite, false);\r\n\r\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\r\n};\r\n\r\nEANReader.prototype._calculateFirstDigit = function(codeFrequency) {\r\n    var i,\r\n        self = this;\r\n\r\n    for ( i = 0; i < self.CODE_FREQUENCY.length; i++) {\r\n        if (codeFrequency === self.CODE_FREQUENCY[i]) {\r\n            return i;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nEANReader.prototype._decodePayload = function(code, result, decodedCodes) {\r\n    var i,\r\n        self = this,\r\n        codeFrequency = 0x0,\r\n        firstDigit;\r\n\r\n    for ( i = 0; i < 6; i++) {\r\n        code = self._decodeCode(code.end);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        if (code.code >= self.CODE_G_START) {\r\n            code.code = code.code - self.CODE_G_START;\r\n            codeFrequency |= 1 << (5 - i);\r\n        } else {\r\n            codeFrequency |= 0 << (5 - i);\r\n        }\r\n        result.push(code.code);\r\n        decodedCodes.push(code);\r\n    }\r\n\r\n    firstDigit = self._calculateFirstDigit(codeFrequency);\r\n    if (firstDigit === null) {\r\n        return null;\r\n    }\r\n    result.unshift(firstDigit);\r\n\r\n    code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);\r\n    if (code === null) {\r\n        return null;\r\n    }\r\n    decodedCodes.push(code);\r\n\r\n    for ( i = 0; i < 6; i++) {\r\n        code = self._decodeCode(code.end, self.CODE_G_START);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        decodedCodes.push(code);\r\n        result.push(code.code);\r\n    }\r\n\r\n    return code;\r\n};\r\n\r\nEANReader.prototype._decode = function() {\r\n    var startInfo,\r\n        self = this,\r\n        code,\r\n        result = [],\r\n        decodedCodes = [],\r\n        resultInfo = {};\r\n\r\n    startInfo = self._findStart();\r\n    if (!startInfo) {\r\n        return null;\r\n    }\r\n    code = {\r\n        code: startInfo.code,\r\n        start: startInfo.start,\r\n        end: startInfo.end\r\n    };\r\n    decodedCodes.push(code);\r\n    code = self._decodePayload(code, result, decodedCodes);\r\n    if (!code) {\r\n        return null;\r\n    }\r\n    code = self._findEnd(code.end, false);\r\n    if (!code){\r\n        return null;\r\n    }\r\n\r\n    decodedCodes.push(code);\r\n\r\n    // Checksum\r\n    if (!self._checksum(result)) {\r\n        return null;\r\n    }\r\n\r\n    if (this.supplements.length > 0) {\r\n        let ext = this._decodeExtensions(code.end);\r\n        if (!ext) {\r\n            return null;\r\n        }\r\n        let lastCode = ext.decodedCodes[ext.decodedCodes.length-1],\r\n            endInfo = {\r\n                start: lastCode.start + (((lastCode.end - lastCode.start) / 2) | 0),\r\n                end: lastCode.end\r\n            };\r\n        if(!self._verifyTrailingWhitespace(endInfo)) {\r\n            return null;\r\n        }\r\n        resultInfo = {\r\n            supplement: ext,\r\n            code: result.join(\"\") + ext.code\r\n        }\r\n    }\r\n\r\n    return {\r\n        code: result.join(\"\"),\r\n        start: startInfo.start,\r\n        end: code.end,\r\n        codeset: \"\",\r\n        startInfo: startInfo,\r\n        decodedCodes: decodedCodes,\r\n        ...resultInfo\r\n    };\r\n};\r\n\r\nEANReader.prototype._decodeExtensions = function(offset) {\r\n    var i,\r\n        start = this._nextSet(this._row, offset),\r\n        startInfo = this._findPattern(this.EXTENSION_START_PATTERN, start, false, false),\r\n        result;\r\n\r\n    if (startInfo === null) {\r\n        return null;\r\n    }\r\n\r\n    for (i = 0; i < this.supplements.length; i++) {\r\n        result = this.supplements[i].decode(this._row, startInfo.end);\r\n        if (result !== null) {\r\n            return {\r\n                code: result.code,\r\n                start,\r\n                startInfo,\r\n                end: result.end,\r\n                codeset: \"\",\r\n                decodedCodes: result.decodedCodes\r\n            }\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nEANReader.prototype._checksum = function(result) {\r\n    var sum = 0, i;\r\n\r\n    for ( i = result.length - 2; i >= 0; i -= 2) {\r\n        sum += result[i];\r\n    }\r\n    sum *= 3;\r\n    for ( i = result.length - 1; i >= 0; i -= 2) {\r\n        sum += result[i];\r\n    }\r\n    return sum % 10 === 0;\r\n};\r\n\r\nEANReader.CONFIG_KEYS = {\r\n    supplements: {\r\n        'type': 'arrayOf(string)',\r\n        'default': [],\r\n        'description': 'Allowed extensions to be decoded (2 and/or 5)'\r\n    }\r\n};\r\n\r\nexport default (EANReader);\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_reader.js","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_root.js\n// module id = 5\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isObjectLike.js\n// module id = 6\n// module chunks = 0","module.exports = clone\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nfunction clone(a) {\n    var out = new Float32Array(2)\n    out[0] = a[0]\n    out[1] = a[1]\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/clone.js\n// module id = 7\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseGetTag.js\n// module id = 8\n// module chunks = 0","export default {\r\n    drawRect: function(pos, size, ctx, style){\r\n        ctx.strokeStyle = style.color;\r\n        ctx.fillStyle = style.color;\r\n        ctx.lineWidth = 1;\r\n        ctx.beginPath();\r\n        ctx.strokeRect(pos.x, pos.y, size.x, size.y);\r\n    },\r\n    drawPath: function(path, def, ctx, style) {\r\n        ctx.strokeStyle = style.color;\r\n        ctx.fillStyle = style.color;\r\n        ctx.lineWidth = style.lineWidth;\r\n        ctx.beginPath();\r\n        ctx.moveTo(path[0][def.x], path[0][def.y]);\r\n        for (var j = 1; j < path.length; j++) {\r\n            ctx.lineTo(path[j][def.x], path[j][def.y]);\r\n        }\r\n        ctx.closePath();\r\n        ctx.stroke();\r\n    },\r\n    drawImage: function(imageData, size, ctx) {\r\n        var canvasData = ctx.getImageData(0, 0, size.x, size.y),\r\n            data = canvasData.data,\r\n            imageDataPos = imageData.length,\r\n            canvasDataPos = data.length,\r\n            value;\r\n\r\n        if (canvasDataPos / imageDataPos !== 4) {\r\n            return false;\r\n        }\r\n        while (imageDataPos--){\r\n            value = imageData[imageDataPos];\r\n            data[--canvasDataPos] = 255;\r\n            data[--canvasDataPos] = value;\r\n            data[--canvasDataPos] = value;\r\n            data[--canvasDataPos] = value;\r\n        }\r\n        ctx.putImageData(canvasData, 0, 0);\r\n        return true;\r\n    }\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/image_debug.js","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_ListCache.js\n// module id = 10\n// module chunks = 0","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Symbol.js\n// module id = 11\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assocIndexOf.js\n// module id = 12\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_castPath.js\n// module id = 13\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getMapData.js\n// module id = 14\n// module chunks = 0","/** 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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isIndex.js\n// module id = 15\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nativeCreate.js\n// module id = 16\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/eq.js\n// module id = 17\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArguments.js\n// module id = 18\n// module chunks = 0","import Cluster2 from './cluster';\r\nimport ArrayHelper from './array_helper';\r\nconst vec2 = {\r\n    clone: require('gl-vec2/clone'),\r\n};\r\nconst vec3 = {\r\n    clone: require('gl-vec3/clone'),\r\n};\r\n\r\n/**\r\n * @param x x-coordinate\r\n * @param y y-coordinate\r\n * @return ImageReference {x,y} Coordinate\r\n */\r\nexport function imageRef(x, y) {\r\n    var that = {\r\n        x: x,\r\n        y: y,\r\n        toVec2: function() {\r\n            return vec2.clone([this.x, this.y]);\r\n        },\r\n        toVec3: function() {\r\n            return vec3.clone([this.x, this.y, 1]);\r\n        },\r\n        round: function() {\r\n            this.x = this.x > 0.0 ? Math.floor(this.x + 0.5) : Math.floor(this.x - 0.5);\r\n            this.y = this.y > 0.0 ? Math.floor(this.y + 0.5) : Math.floor(this.y - 0.5);\r\n            return this;\r\n        }\r\n    };\r\n    return that;\r\n};\r\n\r\n/**\r\n * Computes an integral image of a given grayscale image.\r\n * @param imageDataContainer {ImageDataContainer} the image to be integrated\r\n */\r\nexport function computeIntegralImage2(imageWrapper, integralWrapper) {\r\n    var imageData = imageWrapper.data;\r\n    var width = imageWrapper.size.x;\r\n    var height = imageWrapper.size.y;\r\n    var integralImageData = integralWrapper.data;\r\n    var sum = 0, posA = 0, posB = 0, posC = 0, posD = 0, x, y;\r\n\r\n    // sum up first column\r\n    posB = width;\r\n    sum = 0;\r\n    for ( y = 1; y < height; y++) {\r\n        sum += imageData[posA];\r\n        integralImageData[posB] += sum;\r\n        posA += width;\r\n        posB += width;\r\n    }\r\n\r\n    posA = 0;\r\n    posB = 1;\r\n    sum = 0;\r\n    for ( x = 1; x < width; x++) {\r\n        sum += imageData[posA];\r\n        integralImageData[posB] += sum;\r\n        posA++;\r\n        posB++;\r\n    }\r\n\r\n    for ( y = 1; y < height; y++) {\r\n        posA = y * width + 1;\r\n        posB = (y - 1) * width + 1;\r\n        posC = y * width;\r\n        posD = (y - 1) * width;\r\n        for ( x = 1; x < width; x++) {\r\n            integralImageData[posA] +=\r\n                imageData[posA] + integralImageData[posB] + integralImageData[posC] - integralImageData[posD];\r\n            posA++;\r\n            posB++;\r\n            posC++;\r\n            posD++;\r\n        }\r\n    }\r\n};\r\n\r\nexport function computeIntegralImage(imageWrapper, integralWrapper) {\r\n    var imageData = imageWrapper.data;\r\n    var width = imageWrapper.size.x;\r\n    var height = imageWrapper.size.y;\r\n    var integralImageData = integralWrapper.data;\r\n    var sum = 0;\r\n\r\n    // sum up first row\r\n    for (var i = 0; i < width; i++) {\r\n        sum += imageData[i];\r\n        integralImageData[i] = sum;\r\n    }\r\n\r\n    for (var v = 1; v < height; v++) {\r\n        sum = 0;\r\n        for (var u = 0; u < width; u++) {\r\n            sum += imageData[v * width + u];\r\n            integralImageData[((v) * width) + u] = sum + integralImageData[(v - 1) * width + u];\r\n        }\r\n    }\r\n};\r\n\r\nexport function thresholdImage(imageWrapper, threshold, targetWrapper) {\r\n    if (!targetWrapper) {\r\n        targetWrapper = imageWrapper;\r\n    }\r\n    var imageData = imageWrapper.data, length = imageData.length, targetData = targetWrapper.data;\r\n\r\n    while (length--) {\r\n        targetData[length] = imageData[length] < threshold ? 1 : 0;\r\n    }\r\n};\r\n\r\nexport function computeHistogram(imageWrapper, bitsPerPixel) {\r\n    if (!bitsPerPixel) {\r\n        bitsPerPixel = 8;\r\n    }\r\n    var imageData = imageWrapper.data,\r\n        length = imageData.length,\r\n        bitShift = 8 - bitsPerPixel,\r\n        bucketCnt = 1 << bitsPerPixel,\r\n        hist = new Int32Array(bucketCnt);\r\n\r\n    while (length--) {\r\n        hist[imageData[length] >> bitShift]++;\r\n    }\r\n    return hist;\r\n};\r\n\r\nexport function sharpenLine(line) {\r\n    var i,\r\n        length = line.length,\r\n        left = line[0],\r\n        center = line[1],\r\n        right;\r\n\r\n    for (i = 1; i < length - 1; i++) {\r\n        right = line[i + 1];\r\n        //  -1 4 -1 kernel\r\n        line[i - 1] = (((center * 2) - left - right)) & 255;\r\n        left = center;\r\n        center = right;\r\n    }\r\n    return line;\r\n};\r\n\r\nexport function determineOtsuThreshold(imageWrapper, bitsPerPixel) {\r\n    if (!bitsPerPixel) {\r\n        bitsPerPixel = 8;\r\n    }\r\n    var hist,\r\n        threshold,\r\n        bitShift = 8 - bitsPerPixel;\r\n\r\n    function px(init, end) {\r\n        var sum = 0, i;\r\n        for ( i = init; i <= end; i++) {\r\n            sum += hist[i];\r\n        }\r\n        return sum;\r\n    }\r\n\r\n    function mx(init, end) {\r\n        var i, sum = 0;\r\n\r\n        for ( i = init; i <= end; i++) {\r\n            sum += i * hist[i];\r\n        }\r\n\r\n        return sum;\r\n    }\r\n\r\n    function determineThreshold() {\r\n        var vet = [0], p1, p2, p12, k, m1, m2, m12,\r\n            max = (1 << bitsPerPixel) - 1;\r\n\r\n        hist = computeHistogram(imageWrapper, bitsPerPixel);\r\n        for ( k = 1; k < max; k++) {\r\n            p1 = px(0, k);\r\n            p2 = px(k + 1, max);\r\n            p12 = p1 * p2;\r\n            if (p12 === 0) {\r\n                p12 = 1;\r\n            }\r\n            m1 = mx(0, k) * p2;\r\n            m2 = mx(k + 1, max) * p1;\r\n            m12 = m1 - m2;\r\n            vet[k] = m12 * m12 / p12;\r\n        }\r\n        return ArrayHelper.maxIndex(vet);\r\n    }\r\n\r\n    threshold = determineThreshold();\r\n    return threshold << bitShift;\r\n};\r\n\r\nexport function otsuThreshold(imageWrapper, targetWrapper) {\r\n    var threshold = determineOtsuThreshold(imageWrapper);\r\n\r\n    thresholdImage(imageWrapper, threshold, targetWrapper);\r\n    return threshold;\r\n};\r\n\r\n// local thresholding\r\nexport function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) {\r\n    computeIntegralImage(imageWrapper, integralWrapper);\r\n\r\n    if (!targetWrapper) {\r\n        targetWrapper = imageWrapper;\r\n    }\r\n    var imageData = imageWrapper.data;\r\n    var targetData = targetWrapper.data;\r\n    var width = imageWrapper.size.x;\r\n    var height = imageWrapper.size.y;\r\n    var integralImageData = integralWrapper.data;\r\n    var sum = 0, v, u, kernel = 3, A, B, C, D, avg, size = (kernel * 2 + 1) * (kernel * 2 + 1);\r\n\r\n    // clear out top & bottom-border\r\n    for ( v = 0; v <= kernel; v++) {\r\n        for ( u = 0; u < width; u++) {\r\n            targetData[((v) * width) + u] = 0;\r\n            targetData[(((height - 1) - v) * width) + u] = 0;\r\n        }\r\n    }\r\n\r\n    // clear out left & right border\r\n    for ( v = kernel; v < height - kernel; v++) {\r\n        for ( u = 0; u <= kernel; u++) {\r\n            targetData[((v) * width) + u] = 0;\r\n            targetData[((v) * width) + (width - 1 - u)] = 0;\r\n        }\r\n    }\r\n\r\n    for ( v = kernel + 1; v < height - kernel - 1; v++) {\r\n        for ( u = kernel + 1; u < width - kernel; u++) {\r\n            A = integralImageData[(v - kernel - 1) * width + (u - kernel - 1)];\r\n            B = integralImageData[(v - kernel - 1) * width + (u + kernel)];\r\n            C = integralImageData[(v + kernel) * width + (u - kernel - 1)];\r\n            D = integralImageData[(v + kernel) * width + (u + kernel)];\r\n            sum = D - C - B + A;\r\n            avg = sum / (size);\r\n            targetData[v * width + u] = imageData[v * width + u] > (avg + 5) ? 0 : 1;\r\n        }\r\n    }\r\n};\r\n\r\nexport function cluster(points, threshold, property) {\r\n    var i, k, cluster, point, clusters = [];\r\n\r\n    if (!property) {\r\n        property = \"rad\";\r\n    }\r\n\r\n    function addToCluster(newPoint) {\r\n        var found = false;\r\n        for ( k = 0; k < clusters.length; k++) {\r\n            cluster = clusters[k];\r\n            if (cluster.fits(newPoint)) {\r\n                cluster.add(newPoint);\r\n                found = true;\r\n            }\r\n        }\r\n        return found;\r\n    }\r\n\r\n    // iterate over each cloud\r\n    for ( i = 0; i < points.length; i++) {\r\n        point = Cluster2.createPoint(points[i], i, property);\r\n        if (!addToCluster(point)) {\r\n            clusters.push(Cluster2.create(point, threshold));\r\n        }\r\n    }\r\n    return clusters;\r\n};\r\n\r\nexport const Tracer = {\r\n    trace: function(points, vec) {\r\n        var iteration, maxIterations = 10, top = [], result = [], centerPos = 0, currentPos = 0;\r\n\r\n        function trace(idx, forward) {\r\n            var from, to, toIdx, predictedPos, thresholdX = 1, thresholdY = Math.abs(vec[1] / 10), found = false;\r\n\r\n            function match(pos, predicted) {\r\n                if (pos.x > (predicted.x - thresholdX)\r\n                        && pos.x < (predicted.x + thresholdX)\r\n                        && pos.y > (predicted.y - thresholdY)\r\n                        && pos.y < (predicted.y + thresholdY)) {\r\n                    return true;\r\n                } else {\r\n                    return false;\r\n                }\r\n            }\r\n\r\n            // check if the next index is within the vec specifications\r\n            // if not, check as long as the threshold is met\r\n\r\n            from = points[idx];\r\n            if (forward) {\r\n                predictedPos = {\r\n                    x: from.x + vec[0],\r\n                    y: from.y + vec[1]\r\n                };\r\n            } else {\r\n                predictedPos = {\r\n                    x: from.x - vec[0],\r\n                    y: from.y - vec[1]\r\n                };\r\n            }\r\n\r\n            toIdx = forward ? idx + 1 : idx - 1;\r\n            to = points[toIdx];\r\n            while (to && ( found = match(to, predictedPos)) !== true && (Math.abs(to.y - from.y) < vec[1])) {\r\n                toIdx = forward ? toIdx + 1 : toIdx - 1;\r\n                to = points[toIdx];\r\n            }\r\n\r\n            return found ? toIdx : null;\r\n        }\r\n\r\n        for ( iteration = 0; iteration < maxIterations; iteration++) {\r\n            // randomly select point to start with\r\n            centerPos = Math.floor(Math.random() * points.length);\r\n\r\n            // trace forward\r\n            top = [];\r\n            currentPos = centerPos;\r\n            top.push(points[currentPos]);\r\n            while (( currentPos = trace(currentPos, true)) !== null) {\r\n                top.push(points[currentPos]);\r\n            }\r\n            if (centerPos > 0) {\r\n                currentPos = centerPos;\r\n                while (( currentPos = trace(currentPos, false)) !== null) {\r\n                    top.push(points[currentPos]);\r\n                }\r\n            }\r\n\r\n            if (top.length > result.length) {\r\n                result = top;\r\n            }\r\n        }\r\n        return result;\r\n    }\r\n};\r\n\r\nexport const DILATE = 1;\r\nexport const ERODE = 2;\r\n\r\nexport function dilate(inImageWrapper, outImageWrapper) {\r\n    var v,\r\n        u,\r\n        inImageData = inImageWrapper.data,\r\n        outImageData = outImageWrapper.data,\r\n        height = inImageWrapper.size.y,\r\n        width = inImageWrapper.size.x,\r\n        sum,\r\n        yStart1,\r\n        yStart2,\r\n        xStart1,\r\n        xStart2;\r\n\r\n    for ( v = 1; v < height - 1; v++) {\r\n        for ( u = 1; u < width - 1; u++) {\r\n            yStart1 = v - 1;\r\n            yStart2 = v + 1;\r\n            xStart1 = u - 1;\r\n            xStart2 = u + 1;\r\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] +\r\n            inImageData[v * width + u] +\r\n            inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\r\n            outImageData[v * width + u] = sum > 0 ? 1 : 0;\r\n        }\r\n    }\r\n};\r\n\r\nexport function erode(inImageWrapper, outImageWrapper) {\r\n    var v,\r\n        u,\r\n        inImageData = inImageWrapper.data,\r\n        outImageData = outImageWrapper.data,\r\n        height = inImageWrapper.size.y,\r\n        width = inImageWrapper.size.x,\r\n        sum,\r\n        yStart1,\r\n        yStart2,\r\n        xStart1,\r\n        xStart2;\r\n\r\n    for ( v = 1; v < height - 1; v++) {\r\n        for ( u = 1; u < width - 1; u++) {\r\n            yStart1 = v - 1;\r\n            yStart2 = v + 1;\r\n            xStart1 = u - 1;\r\n            xStart2 = u + 1;\r\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] +\r\n            inImageData[v * width + u] +\r\n            inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\r\n            outImageData[v * width + u] = sum === 5 ? 1 : 0;\r\n        }\r\n    }\r\n};\r\n\r\nexport function subtract(aImageWrapper, bImageWrapper, resultImageWrapper) {\r\n    if (!resultImageWrapper) {\r\n        resultImageWrapper = aImageWrapper;\r\n    }\r\n    var length = aImageWrapper.data.length,\r\n        aImageData = aImageWrapper.data,\r\n        bImageData = bImageWrapper.data,\r\n        cImageData = resultImageWrapper.data;\r\n\r\n    while (length--) {\r\n        cImageData[length] = aImageData[length] - bImageData[length];\r\n    }\r\n};\r\n\r\nexport function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) {\r\n    if (!resultImageWrapper) {\r\n        resultImageWrapper = aImageWrapper;\r\n    }\r\n    var length = aImageWrapper.data.length,\r\n        aImageData = aImageWrapper.data,\r\n        bImageData = bImageWrapper.data,\r\n        cImageData = resultImageWrapper.data;\r\n\r\n    while (length--) {\r\n        cImageData[length] = aImageData[length] || bImageData[length];\r\n    }\r\n};\r\n\r\nexport function countNonZero(imageWrapper) {\r\n    var length = imageWrapper.data.length, data = imageWrapper.data, sum = 0;\r\n\r\n    while (length--) {\r\n        sum += data[length];\r\n    }\r\n    return sum;\r\n};\r\n\r\nexport function topGeneric(list, top, scoreFunc) {\r\n    var i, minIdx = 0, min = 0, queue = [], score, hit, pos;\r\n\r\n    for ( i = 0; i < top; i++) {\r\n        queue[i] = {\r\n            score: 0,\r\n            item: null\r\n        };\r\n    }\r\n\r\n    for ( i = 0; i < list.length; i++) {\r\n        score = scoreFunc.apply(this, [list[i]]);\r\n        if (score > min) {\r\n            hit = queue[minIdx];\r\n            hit.score = score;\r\n            hit.item = list[i];\r\n            min = Number.MAX_VALUE;\r\n            for ( pos = 0; pos < top; pos++) {\r\n                if (queue[pos].score < min) {\r\n                    min = queue[pos].score;\r\n                    minIdx = pos;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    return queue;\r\n};\r\n\r\nexport function grayArrayFromImage(htmlImage, offsetX, ctx, array) {\r\n    ctx.drawImage(htmlImage, offsetX, 0, htmlImage.width, htmlImage.height);\r\n    var ctxData = ctx.getImageData(offsetX, 0, htmlImage.width, htmlImage.height).data;\r\n    computeGray(ctxData, array);\r\n};\r\n\r\nexport function grayArrayFromContext(ctx, size, offset, array) {\r\n    var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data;\r\n    computeGray(ctxData, array);\r\n};\r\n\r\nexport function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {\r\n    var topRowIdx = 0;\r\n    var bottomRowIdx = size.x;\r\n    var endIdx = Math.floor(canvasData.length / 4);\r\n    var outWidth = size.x / 2;\r\n    var outImgIdx = 0;\r\n    var inWidth = size.x;\r\n    var i;\r\n\r\n    while (bottomRowIdx < endIdx) {\r\n        for ( i = 0; i < outWidth; i++) {\r\n            outArray[outImgIdx] = (\r\n                (0.299 * canvasData[topRowIdx * 4 + 0] +\r\n                 0.587 * canvasData[topRowIdx * 4 + 1] +\r\n                 0.114 * canvasData[topRowIdx * 4 + 2]) +\r\n                (0.299 * canvasData[(topRowIdx + 1) * 4 + 0] +\r\n                 0.587 * canvasData[(topRowIdx + 1) * 4 + 1] +\r\n                 0.114 * canvasData[(topRowIdx + 1) * 4 + 2]) +\r\n                (0.299 * canvasData[(bottomRowIdx) * 4 + 0] +\r\n                 0.587 * canvasData[(bottomRowIdx) * 4 + 1] +\r\n                 0.114 * canvasData[(bottomRowIdx) * 4 + 2]) +\r\n                (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] +\r\n                 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] +\r\n                 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4;\r\n            outImgIdx++;\r\n            topRowIdx = topRowIdx + 2;\r\n            bottomRowIdx = bottomRowIdx + 2;\r\n        }\r\n        topRowIdx = topRowIdx + inWidth;\r\n        bottomRowIdx = bottomRowIdx + inWidth;\r\n    }\r\n};\r\n\r\nexport function computeGray(imageData, outArray, config) {\r\n    var l = (imageData.length / 4) | 0,\r\n        i,\r\n        singleChannel = config && config.singleChannel === true;\r\n\r\n    if (singleChannel) {\r\n        for (i = 0; i < l; i++) {\r\n            outArray[i] = imageData[i * 4 + 0];\r\n        }\r\n    } else {\r\n        for (i = 0; i < l; i++) {\r\n            outArray[i] =\r\n                0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2];\r\n        }\r\n    }\r\n};\r\n\r\nexport function loadImageArray(src, callback, canvas) {\r\n    if (!canvas) {\r\n        canvas = document.createElement('canvas');\r\n    }\r\n    var img = new Image();\r\n    img.callback = callback;\r\n    img.onload = function() {\r\n        canvas.width = this.width;\r\n        canvas.height = this.height;\r\n        var ctx = canvas.getContext('2d');\r\n        ctx.drawImage(this, 0, 0);\r\n        var array = new Uint8Array(this.width * this.height);\r\n        ctx.drawImage(this, 0, 0);\r\n        var data = ctx.getImageData(0, 0, this.width, this.height).data;\r\n        computeGray(data, array);\r\n        this.callback(array, {\r\n            x: this.width,\r\n            y: this.height\r\n        }, this);\r\n    };\r\n    img.src = src;\r\n};\r\n\r\n/**\r\n * @param inImg {ImageWrapper} input image to be sampled\r\n * @param outImg {ImageWrapper} to be stored in\r\n */\r\nexport function halfSample(inImgWrapper, outImgWrapper) {\r\n    var inImg = inImgWrapper.data;\r\n    var inWidth = inImgWrapper.size.x;\r\n    var outImg = outImgWrapper.data;\r\n    var topRowIdx = 0;\r\n    var bottomRowIdx = inWidth;\r\n    var endIdx = inImg.length;\r\n    var outWidth = inWidth / 2;\r\n    var outImgIdx = 0;\r\n    while (bottomRowIdx < endIdx) {\r\n        for (var i = 0; i < outWidth; i++) {\r\n            outImg[outImgIdx] = Math.floor(\r\n                (inImg[topRowIdx] + inImg[topRowIdx + 1] + inImg[bottomRowIdx] + inImg[bottomRowIdx + 1]) / 4);\r\n            outImgIdx++;\r\n            topRowIdx = topRowIdx + 2;\r\n            bottomRowIdx = bottomRowIdx + 2;\r\n        }\r\n        topRowIdx = topRowIdx + inWidth;\r\n        bottomRowIdx = bottomRowIdx + inWidth;\r\n    }\r\n};\r\n\r\nexport function hsv2rgb(hsv, rgb) {\r\n    var h = hsv[0],\r\n        s = hsv[1],\r\n        v = hsv[2],\r\n        c = v * s,\r\n        x = c * (1 - Math.abs((h / 60) % 2 - 1)),\r\n        m = v - c,\r\n        r = 0,\r\n        g = 0,\r\n        b = 0;\r\n\r\n    rgb = rgb || [0, 0, 0];\r\n\r\n    if (h < 60) {\r\n        r = c;\r\n        g = x;\r\n    } else if (h < 120) {\r\n        r = x;\r\n        g = c;\r\n    } else if (h < 180) {\r\n        g = c;\r\n        b = x;\r\n    } else if (h < 240) {\r\n        g = x;\r\n        b = c;\r\n    } else if (h < 300) {\r\n        r = x;\r\n        b = c;\r\n    } else if (h < 360) {\r\n        r = c;\r\n        b = x;\r\n    }\r\n    rgb[0] = ((r + m) * 255) | 0;\r\n    rgb[1] = ((g + m) * 255) | 0;\r\n    rgb[2] = ((b + m) * 255) | 0;\r\n    return rgb;\r\n};\r\n\r\nexport function _computeDivisors(n) {\r\n    var largeDivisors = [],\r\n        divisors = [],\r\n        i;\r\n\r\n    for (i = 1; i < Math.sqrt(n) + 1; i++) {\r\n        if (n % i === 0) {\r\n            divisors.push(i);\r\n            if (i !== n / i) {\r\n                largeDivisors.unshift(Math.floor(n / i));\r\n            }\r\n        }\r\n    }\r\n    return divisors.concat(largeDivisors);\r\n};\r\n\r\nfunction _computeIntersection(arr1, arr2) {\r\n    var i = 0,\r\n        j = 0,\r\n        result = [];\r\n\r\n    while (i < arr1.length && j < arr2.length) {\r\n        if (arr1[i] === arr2[j]) {\r\n            result.push(arr1[i]);\r\n            i++;\r\n            j++;\r\n        } else if (arr1[i] > arr2[j]) {\r\n            j++;\r\n        } else {\r\n            i++;\r\n        }\r\n    }\r\n    return result;\r\n};\r\n\r\nexport function calculatePatchSize(patchSize, imgSize) {\r\n    var divisorsX = _computeDivisors(imgSize.x),\r\n        divisorsY = _computeDivisors(imgSize.y),\r\n        wideSide = Math.max(imgSize.x, imgSize.y),\r\n        common = _computeIntersection(divisorsX, divisorsY),\r\n        nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80],\r\n        nrOfPatchesMap = {\r\n            \"x-small\": 5,\r\n            \"small\": 4,\r\n            \"medium\": 3,\r\n            \"large\": 2,\r\n            \"x-large\": 1\r\n        },\r\n        nrOfPatchesIdx = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium,\r\n        nrOfPatches = nrOfPatchesList[nrOfPatchesIdx],\r\n        desiredPatchSize = Math.floor(wideSide / nrOfPatches),\r\n        optimalPatchSize;\r\n\r\n    function findPatchSizeForDivisors(divisors) {\r\n        var i = 0,\r\n            found = divisors[Math.floor(divisors.length / 2)];\r\n\r\n        while (i < (divisors.length - 1) && divisors[i] < desiredPatchSize) {\r\n            i++;\r\n        }\r\n        if (i > 0) {\r\n            if (Math.abs(divisors[i] - desiredPatchSize) > Math.abs(divisors[i - 1] - desiredPatchSize)) {\r\n                found = divisors[i - 1];\r\n            } else {\r\n                found = divisors[i];\r\n            }\r\n        }\r\n        if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIdx + 1] / nrOfPatchesList[nrOfPatchesIdx] &&\r\n            desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIdx - 1] / nrOfPatchesList[nrOfPatchesIdx] ) {\r\n            return {x: found, y: found};\r\n        }\r\n        return null;\r\n    }\r\n\r\n    optimalPatchSize = findPatchSizeForDivisors(common);\r\n    if (!optimalPatchSize) {\r\n        optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide));\r\n        if (!optimalPatchSize) {\r\n            optimalPatchSize = findPatchSizeForDivisors((_computeDivisors(desiredPatchSize * nrOfPatches)));\r\n        }\r\n    }\r\n    return optimalPatchSize;\r\n};\r\n\r\nexport function _parseCSSDimensionValues(value) {\r\n    var dimension = {\r\n        value: parseFloat(value),\r\n        unit: value.indexOf(\"%\") === value.length - 1 ? \"%\" : \"%\"\r\n    };\r\n\r\n    return dimension;\r\n};\r\n\r\nexport const _dimensionsConverters = {\r\n    top: function(dimension, context) {\r\n        if (dimension.unit === \"%\") {\r\n            return Math.floor(context.height * (dimension.value / 100));\r\n        }\r\n    },\r\n    right: function(dimension, context) {\r\n        if (dimension.unit === \"%\") {\r\n            return Math.floor(context.width - (context.width * (dimension.value / 100)));\r\n        }\r\n    },\r\n    bottom: function(dimension, context) {\r\n        if (dimension.unit === \"%\") {\r\n            return Math.floor(context.height - (context.height * (dimension.value / 100)));\r\n        }\r\n    },\r\n    left: function(dimension, context) {\r\n        if (dimension.unit === \"%\") {\r\n            return Math.floor(context.width * (dimension.value / 100));\r\n        }\r\n    }\r\n};\r\n\r\nexport function computeImageArea(inputWidth, inputHeight, area) {\r\n    var context = {width: inputWidth, height: inputHeight};\r\n\r\n    var parsedArea = Object.keys(area).reduce(function(result, key) {\r\n        var value = area[key],\r\n            parsed = _parseCSSDimensionValues(value),\r\n            calculated = _dimensionsConverters[key](parsed, context);\r\n\r\n        result[key] = calculated;\r\n        return result;\r\n    }, {});\r\n\r\n    return {\r\n        sx: parsedArea.left,\r\n        sy: parsedArea.top,\r\n        sw: parsedArea.right - parsedArea.left,\r\n        sh: parsedArea.bottom - parsedArea.top\r\n    };\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/cv_utils.js","import SubImage from './subImage';\r\nimport {hsv2rgb} from '../common/cv_utils';\r\nimport ArrayHelper from '../common/array_helper';\r\nconst vec2 = {\r\n    clone: require('gl-vec2/clone'),\r\n};\r\n\r\n/**\r\n * Represents a basic image combining the data and size.\r\n * In addition, some methods for manipulation are contained.\r\n * @param size {x,y} The size of the image in pixel\r\n * @param data {Array} If given, a flat array containing the pixel data\r\n * @param ArrayType {Type} If given, the desired DataType of the Array (may be typed/non-typed)\r\n * @param initialize {Boolean} Indicating if the array should be initialized on creation.\r\n * @returns {ImageWrapper}\r\n */\r\nfunction ImageWrapper(size, data, ArrayType, initialize) {\r\n    if (!data) {\r\n        if (ArrayType) {\r\n            this.data = new ArrayType(size.x * size.y);\r\n            if (ArrayType === Array && initialize) {\r\n                ArrayHelper.init(this.data, 0);\r\n            }\r\n        } else {\r\n            this.data = new Uint8Array(size.x * size.y);\r\n            if (Uint8Array === Array && initialize) {\r\n                ArrayHelper.init(this.data, 0);\r\n            }\r\n        }\r\n    } else {\r\n        this.data = data;\r\n    }\r\n    this.size = size;\r\n}\r\n\r\n/**\r\n * tests if a position is within the image with a given offset\r\n * @param imgRef {x, y} The location to test\r\n * @param border Number the padding value in pixel\r\n * @returns {Boolean} true if location inside the image's border, false otherwise\r\n * @see cvd/image.h\r\n */\r\nImageWrapper.prototype.inImageWithBorder = function(imgRef, border) {\r\n    return (imgRef.x >= border)\r\n        && (imgRef.y >= border)\r\n        && (imgRef.x < (this.size.x - border))\r\n        && (imgRef.y < (this.size.y - border));\r\n};\r\n\r\n/**\r\n * Performs bilinear sampling\r\n * @param inImg Image to extract sample from\r\n * @param x the x-coordinate\r\n * @param y the y-coordinate\r\n * @returns the sampled value\r\n * @see cvd/vision.h\r\n */\r\nImageWrapper.sample = function(inImg, x, y) {\r\n    var lx = Math.floor(x);\r\n    var ly = Math.floor(y);\r\n    var w = inImg.size.x;\r\n    var base = ly * inImg.size.x + lx;\r\n    var a = inImg.data[base + 0];\r\n    var b = inImg.data[base + 1];\r\n    var c = inImg.data[base + w];\r\n    var d = inImg.data[base + w + 1];\r\n    var e = a - b;\r\n    x -= lx;\r\n    y -= ly;\r\n\r\n    var result = Math.floor(x * (y * (e - c + d) - e) + y * (c - a) + a);\r\n    return result;\r\n};\r\n\r\n/**\r\n * Initializes a given array. Sets each element to zero.\r\n * @param array {Array} The array to initialize\r\n */\r\nImageWrapper.clearArray = function(array) {\r\n    var l = array.length;\r\n    while (l--) {\r\n        array[l] = 0;\r\n    }\r\n};\r\n\r\n/**\r\n * Creates a {SubImage} from the current image ({this}).\r\n * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner)\r\n * @param size {ImageRef} The size of the resulting image\r\n * @returns {SubImage} A shared part of the original image\r\n */\r\nImageWrapper.prototype.subImage = function(from, size) {\r\n    return new SubImage(from, size, this);\r\n};\r\n\r\n/**\r\n * Creates an {ImageWrapper) and copies the needed underlying image-data area\r\n * @param imageWrapper {ImageWrapper} The target {ImageWrapper} where the data should be copied\r\n * @param from {ImageRef} The location where to copy from (top-left location)\r\n */\r\nImageWrapper.prototype.subImageAsCopy = function(imageWrapper, from) {\r\n    var sizeY = imageWrapper.size.y, sizeX = imageWrapper.size.x;\r\n    var x, y;\r\n    for ( x = 0; x < sizeX; x++) {\r\n        for ( y = 0; y < sizeY; y++) {\r\n            imageWrapper.data[y * sizeX + x] = this.data[(from.y + y) * this.size.x + from.x + x];\r\n        }\r\n    }\r\n};\r\n\r\nImageWrapper.prototype.copyTo = function(imageWrapper) {\r\n    var length = this.data.length, srcData = this.data, dstData = imageWrapper.data;\r\n\r\n    while (length--) {\r\n        dstData[length] = srcData[length];\r\n    }\r\n};\r\n\r\n/**\r\n * Retrieves a given pixel position from the image\r\n * @param x {Number} The x-position\r\n * @param y {Number} The y-position\r\n * @returns {Number} The grayscale value at the pixel-position\r\n */\r\nImageWrapper.prototype.get = function(x, y) {\r\n    return this.data[y * this.size.x + x];\r\n};\r\n\r\n/**\r\n * Retrieves a given pixel position from the image\r\n * @param x {Number} The x-position\r\n * @param y {Number} The y-position\r\n * @returns {Number} The grayscale value at the pixel-position\r\n */\r\nImageWrapper.prototype.getSafe = function(x, y) {\r\n    var i;\r\n\r\n    if (!this.indexMapping) {\r\n        this.indexMapping = {\r\n            x: [],\r\n            y: []\r\n        };\r\n        for (i = 0; i < this.size.x; i++) {\r\n            this.indexMapping.x[i] = i;\r\n            this.indexMapping.x[i + this.size.x] = i;\r\n        }\r\n        for (i = 0; i < this.size.y; i++) {\r\n            this.indexMapping.y[i] = i;\r\n            this.indexMapping.y[i + this.size.y] = i;\r\n        }\r\n    }\r\n    return this.data[(this.indexMapping.y[y + this.size.y]) * this.size.x + this.indexMapping.x[x + this.size.x]];\r\n};\r\n\r\n/**\r\n * Sets a given pixel position in the image\r\n * @param x {Number} The x-position\r\n * @param y {Number} The y-position\r\n * @param value {Number} The grayscale value to set\r\n * @returns {ImageWrapper} The Image itself (for possible chaining)\r\n */\r\nImageWrapper.prototype.set = function(x, y, value) {\r\n    this.data[y * this.size.x + x] = value;\r\n    return this;\r\n};\r\n\r\n/**\r\n * Sets the border of the image (1 pixel) to zero\r\n */\r\nImageWrapper.prototype.zeroBorder = function() {\r\n    var i, width = this.size.x, height = this.size.y, data = this.data;\r\n    for ( i = 0; i < width; i++) {\r\n        data[i] = data[(height - 1) * width + i] = 0;\r\n    }\r\n    for ( i = 1; i < height - 1; i++) {\r\n        data[i * width] = data[i * width + (width - 1)] = 0;\r\n    }\r\n};\r\n\r\n/**\r\n * Inverts a binary image in place\r\n */\r\nImageWrapper.prototype.invert = function() {\r\n    var data = this.data, length = data.length;\r\n\r\n    while (length--) {\r\n        data[length] = data[length] ? 0 : 1;\r\n    }\r\n};\r\n\r\nImageWrapper.prototype.convolve = function(kernel) {\r\n    var x, y, kx, ky, kSize = (kernel.length / 2) | 0, accu = 0;\r\n    for ( y = 0; y < this.size.y; y++) {\r\n        for ( x = 0; x < this.size.x; x++) {\r\n            accu = 0;\r\n            for ( ky = -kSize; ky <= kSize; ky++) {\r\n                for ( kx = -kSize; kx <= kSize; kx++) {\r\n                    accu += kernel[ky + kSize][kx + kSize] * this.getSafe(x + kx, y + ky);\r\n                }\r\n            }\r\n            this.data[y * this.size.x + x] = accu;\r\n        }\r\n    }\r\n};\r\n\r\nImageWrapper.prototype.moments = function(labelcount) {\r\n    var data = this.data,\r\n        x,\r\n        y,\r\n        height = this.size.y,\r\n        width = this.size.x,\r\n        val,\r\n        ysq,\r\n        labelsum = [],\r\n        i,\r\n        label,\r\n        mu11,\r\n        mu02,\r\n        mu20,\r\n        x_,\r\n        y_,\r\n        tmp,\r\n        result = [],\r\n        PI = Math.PI,\r\n        PI_4 = PI / 4;\r\n\r\n    if (labelcount <= 0) {\r\n        return result;\r\n    }\r\n\r\n    for ( i = 0; i < labelcount; i++) {\r\n        labelsum[i] = {\r\n            m00: 0,\r\n            m01: 0,\r\n            m10: 0,\r\n            m11: 0,\r\n            m02: 0,\r\n            m20: 0,\r\n            theta: 0,\r\n            rad: 0\r\n        };\r\n    }\r\n\r\n    for ( y = 0; y < height; y++) {\r\n        ysq = y * y;\r\n        for ( x = 0; x < width; x++) {\r\n            val = data[y * width + x];\r\n            if (val > 0) {\r\n                label = labelsum[val - 1];\r\n                label.m00 += 1;\r\n                label.m01 += y;\r\n                label.m10 += x;\r\n                label.m11 += x * y;\r\n                label.m02 += ysq;\r\n                label.m20 += x * x;\r\n            }\r\n        }\r\n    }\r\n\r\n    for ( i = 0; i < labelcount; i++) {\r\n        label = labelsum[i];\r\n        if (!isNaN(label.m00) && label.m00 !== 0) {\r\n            x_ = label.m10 / label.m00;\r\n            y_ = label.m01 / label.m00;\r\n            mu11 = label.m11 / label.m00 - x_ * y_;\r\n            mu02 = label.m02 / label.m00 - y_ * y_;\r\n            mu20 = label.m20 / label.m00 - x_ * x_;\r\n            tmp = (mu02 - mu20) / (2 * mu11);\r\n            tmp = 0.5 * Math.atan(tmp) + (mu11 >= 0 ? PI_4 : -PI_4 ) + PI;\r\n            label.theta = (tmp * 180 / PI + 90) % 180 - 90;\r\n            if (label.theta < 0) {\r\n                label.theta += 180;\r\n            }\r\n            label.rad = tmp > PI ? tmp - PI : tmp;\r\n            label.vec = vec2.clone([Math.cos(tmp), Math.sin(tmp)]);\r\n            result.push(label);\r\n        }\r\n    }\r\n\r\n    return result;\r\n};\r\n\r\n/**\r\n * Displays the {ImageWrapper} in a given canvas\r\n * @param canvas {Canvas} The canvas element to write to\r\n * @param scale {Number} Scale which is applied to each pixel-value\r\n */\r\nImageWrapper.prototype.show = function(canvas, scale) {\r\n    var ctx,\r\n        frame,\r\n        data,\r\n        current,\r\n        pixel,\r\n        x,\r\n        y;\r\n\r\n    if (!scale) {\r\n        scale = 1.0;\r\n    }\r\n    ctx = canvas.getContext('2d');\r\n    canvas.width = this.size.x;\r\n    canvas.height = this.size.y;\r\n    frame = ctx.getImageData(0, 0, canvas.width, canvas.height);\r\n    data = frame.data;\r\n    current = 0;\r\n    for (y = 0; y < this.size.y; y++) {\r\n        for (x = 0; x < this.size.x; x++) {\r\n            pixel = y * this.size.x + x;\r\n            current = this.get(x, y) * scale;\r\n            data[pixel * 4 + 0] = current;\r\n            data[pixel * 4 + 1] = current;\r\n            data[pixel * 4 + 2] = current;\r\n            data[pixel * 4 + 3] = 255;\r\n        }\r\n    }\r\n    //frame.data = data;\r\n    ctx.putImageData(frame, 0, 0);\r\n};\r\n\r\n/**\r\n * Displays the {SubImage} in a given canvas\r\n * @param canvas {Canvas} The canvas element to write to\r\n * @param scale {Number} Scale which is applied to each pixel-value\r\n */\r\nImageWrapper.prototype.overlay = function(canvas, scale, from) {\r\n    if (!scale || scale < 0 || scale > 360) {\r\n        scale = 360;\r\n    }\r\n    var hsv = [0, 1, 1];\r\n    var rgb = [0, 0, 0];\r\n    var whiteRgb = [255, 255, 255];\r\n    var blackRgb = [0, 0, 0];\r\n    var result = [];\r\n    var ctx = canvas.getContext('2d');\r\n    var frame = ctx.getImageData(from.x, from.y, this.size.x, this.size.y);\r\n    var data = frame.data;\r\n    var length = this.data.length;\r\n    while (length--) {\r\n        hsv[0] = this.data[length] * scale;\r\n        result = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : hsv2rgb(hsv, rgb);\r\n        data[length * 4 + 0] = result[0];\r\n        data[length * 4 + 1] = result[1];\r\n        data[length * 4 + 2] = result[2];\r\n        data[length * 4 + 3] = 255;\r\n    }\r\n    ctx.putImageData(frame, from.x, from.y);\r\n};\r\n\r\nexport default ImageWrapper;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/image_wrapper.js","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseAssignValue.js\n// module id = 21\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getNative.js\n// module id = 22\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_toKey.js\n// module id = 23\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArrayLike.js\n// module id = 24\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isFunction.js\n// module id = 25\n// module chunks = 0","/** 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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isLength.js\n// module id = 26\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isSymbol.js\n// module id = 27\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/merge.js\n// module id = 28\n// module chunks = 0","module.exports = function(module) {\r\n\tif(!module.webpackPolyfill) {\r\n\t\tmodule.deprecate = function() {};\r\n\t\tmodule.paths = [];\r\n\t\t// module.parent = undefined by default\r\n\t\tif(!module.children) module.children = [];\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.l;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.i;\r\n\t\t\t}\r\n\t\t});\r\n\t\tmodule.webpackPolyfill = 1;\r\n\t}\r\n\treturn module;\r\n};\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/module.js\n// module id = 29\n// module chunks = 0","/**\r\n * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\r\n */\r\nvar Tracer = {\r\n    searchDirections: [[0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [-1, -1], [-1, 0], [-1, 1]],\r\n    create: function(imageWrapper, labelWrapper) {\r\n        var imageData = imageWrapper.data,\r\n            labelData = labelWrapper.data,\r\n            searchDirections = this.searchDirections,\r\n            width = imageWrapper.size.x,\r\n            pos;\r\n\r\n        function trace(current, color, label, edgelabel) {\r\n            var i,\r\n                y,\r\n                x;\r\n\r\n            for ( i = 0; i < 7; i++) {\r\n                y = current.cy + searchDirections[current.dir][0];\r\n                x = current.cx + searchDirections[current.dir][1];\r\n                pos = y * width + x;\r\n                if ((imageData[pos] === color) && ((labelData[pos] === 0) || (labelData[pos] === label))) {\r\n                    labelData[pos] = label;\r\n                    current.cy = y;\r\n                    current.cx = x;\r\n                    return true;\r\n                } else {\r\n                    if (labelData[pos] === 0) {\r\n                        labelData[pos] = edgelabel;\r\n                    }\r\n                    current.dir = (current.dir + 1) % 8;\r\n                }\r\n            }\r\n            return false;\r\n        }\r\n\r\n        function vertex2D(x, y, dir) {\r\n            return {\r\n                dir: dir,\r\n                x: x,\r\n                y: y,\r\n                next: null,\r\n                prev: null\r\n            };\r\n        }\r\n\r\n        function contourTracing(sy, sx, label, color, edgelabel) {\r\n            var Fv = null,\r\n                Cv,\r\n                P,\r\n                ldir,\r\n                current = {\r\n                    cx: sx,\r\n                    cy: sy,\r\n                    dir: 0\r\n                };\r\n\r\n            if (trace(current, color, label, edgelabel)) {\r\n                Fv = vertex2D(sx, sy, current.dir);\r\n                Cv = Fv;\r\n                ldir = current.dir;\r\n                P = vertex2D(current.cx, current.cy, 0);\r\n                P.prev = Cv;\r\n                Cv.next = P;\r\n                P.next = null;\r\n                Cv = P;\r\n                do {\r\n                    current.dir = (current.dir + 6) % 8;\r\n                    trace(current, color, label, edgelabel);\r\n                    if (ldir !== current.dir) {\r\n                        Cv.dir = current.dir;\r\n                        P = vertex2D(current.cx, current.cy, 0);\r\n                        P.prev = Cv;\r\n                        Cv.next = P;\r\n                        P.next = null;\r\n                        Cv = P;\r\n                    } else {\r\n                        Cv.dir = ldir;\r\n                        Cv.x = current.cx;\r\n                        Cv.y = current.cy;\r\n                    }\r\n                    ldir = current.dir;\r\n                } while (current.cx !== sx || current.cy !== sy);\r\n                Fv.prev = Cv.prev;\r\n                Cv.prev.next = Fv;\r\n            }\r\n            return Fv;\r\n        }\r\n\r\n        return {\r\n            trace: function(current, color, label, edgelabel) {\r\n                return trace(current, color, label, edgelabel);\r\n            },\r\n            contourTracing: function(sy, sx, label, color, edgelabel) {\r\n                return contourTracing(sy, sx, label, color, edgelabel);\r\n            }\r\n        };\r\n    }\r\n};\r\n\r\nexport default (Tracer);\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/tracer.js","import BarcodeReader from './barcode_reader';\r\nimport ArrayHelper from '../common/array_helper';\r\n\r\nfunction Code39Reader() {\r\n    BarcodeReader.call(this);\r\n}\r\n\r\nvar properties = {\r\n    ALPHABETH_STRING: {value: \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%\"},\r\n    ALPHABET: {value: [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78,\r\n        79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 45, 46, 32, 42, 36, 47, 43, 37]},\r\n    CHARACTER_ENCODINGS: {value: [0x034, 0x121, 0x061, 0x160, 0x031, 0x130, 0x070, 0x025, 0x124, 0x064, 0x109, 0x049,\r\n        0x148, 0x019, 0x118, 0x058, 0x00D, 0x10C, 0x04C, 0x01C, 0x103, 0x043, 0x142, 0x013, 0x112, 0x052, 0x007, 0x106,\r\n        0x046, 0x016, 0x181, 0x0C1, 0x1C0, 0x091, 0x190, 0x0D0, 0x085, 0x184, 0x0C4, 0x094, 0x0A8, 0x0A2, 0x08A, 0x02A\r\n    ]},\r\n    ASTERISK: {value: 0x094},\r\n    FORMAT: {value: \"code_39\", writeable: false}\r\n};\r\n\r\nCode39Reader.prototype = Object.create(BarcodeReader.prototype, properties);\r\nCode39Reader.prototype.constructor = Code39Reader;\r\n\r\nCode39Reader.prototype._decode = function() {\r\n    var self = this,\r\n        counters = [0, 0, 0, 0, 0, 0, 0, 0, 0],\r\n        result = [],\r\n        start = self._findStart(),\r\n        decodedChar,\r\n        lastStart,\r\n        pattern,\r\n        nextStart;\r\n\r\n    if (!start) {\r\n        return null;\r\n    }\r\n    nextStart = self._nextSet(self._row, start.end);\r\n\r\n    do {\r\n        counters = self._toCounters(nextStart, counters);\r\n        pattern = self._toPattern(counters);\r\n        if (pattern < 0) {\r\n            return null;\r\n        }\r\n        decodedChar = self._patternToChar(pattern);\r\n        if (decodedChar < 0){\r\n            return null;\r\n        }\r\n        result.push(decodedChar);\r\n        lastStart = nextStart;\r\n        nextStart += ArrayHelper.sum(counters);\r\n        nextStart = self._nextSet(self._row, nextStart);\r\n    } while (decodedChar !== '*');\r\n    result.pop();\r\n\r\n    if (!result.length) {\r\n        return null;\r\n    }\r\n\r\n    if (!self._verifyTrailingWhitespace(lastStart, nextStart, counters)) {\r\n        return null;\r\n    }\r\n\r\n    return {\r\n        code: result.join(\"\"),\r\n        start: start.start,\r\n        end: nextStart,\r\n        startInfo: start,\r\n        decodedCodes: result\r\n    };\r\n};\r\n\r\nCode39Reader.prototype._verifyTrailingWhitespace = function(lastStart, nextStart, counters) {\r\n    var trailingWhitespaceEnd,\r\n        patternSize = ArrayHelper.sum(counters);\r\n\r\n    trailingWhitespaceEnd = nextStart - lastStart - patternSize;\r\n    if ((trailingWhitespaceEnd * 3) >= patternSize) {\r\n        return true;\r\n    }\r\n    return false;\r\n};\r\n\r\nCode39Reader.prototype._patternToChar = function(pattern) {\r\n    var i,\r\n        self = this;\r\n\r\n    for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {\r\n        if (self.CHARACTER_ENCODINGS[i] === pattern) {\r\n            return String.fromCharCode(self.ALPHABET[i]);\r\n        }\r\n    }\r\n    return -1;\r\n};\r\n\r\nCode39Reader.prototype._findNextWidth = function(counters, current) {\r\n    var i,\r\n        minWidth = Number.MAX_VALUE;\r\n\r\n    for (i = 0; i < counters.length; i++) {\r\n        if (counters[i] < minWidth && counters[i] > current) {\r\n            minWidth = counters[i];\r\n        }\r\n    }\r\n\r\n    return minWidth;\r\n};\r\n\r\nCode39Reader.prototype._toPattern = function(counters) {\r\n    var numCounters = counters.length,\r\n        maxNarrowWidth = 0,\r\n        numWideBars = numCounters,\r\n        wideBarWidth = 0,\r\n        self = this,\r\n        pattern,\r\n        i;\r\n\r\n    while (numWideBars > 3) {\r\n        maxNarrowWidth = self._findNextWidth(counters, maxNarrowWidth);\r\n        numWideBars = 0;\r\n        pattern = 0;\r\n        for (i = 0; i < numCounters; i++) {\r\n            if (counters[i] > maxNarrowWidth) {\r\n                pattern |= 1 << (numCounters - 1 - i);\r\n                numWideBars++;\r\n                wideBarWidth += counters[i];\r\n            }\r\n        }\r\n\r\n        if (numWideBars === 3) {\r\n            for (i = 0; i < numCounters && numWideBars > 0; i++) {\r\n                if (counters[i] > maxNarrowWidth) {\r\n                    numWideBars--;\r\n                    if ((counters[i] * 2) >= wideBarWidth) {\r\n                        return -1;\r\n                    }\r\n                }\r\n            }\r\n            return pattern;\r\n        }\r\n    }\r\n    return -1;\r\n};\r\n\r\nCode39Reader.prototype._findStart = function() {\r\n    var self = this,\r\n        offset = self._nextSet(self._row),\r\n        patternStart = offset,\r\n        counter = [0, 0, 0, 0, 0, 0, 0, 0, 0],\r\n        counterPos = 0,\r\n        isWhite = false,\r\n        i,\r\n        j,\r\n        whiteSpaceMustStart;\r\n\r\n    for ( i = offset; i < self._row.length; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            if (counterPos === counter.length - 1) {\r\n                // find start pattern\r\n                if (self._toPattern(counter) === self.ASTERISK) {\r\n                    whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - ((i - patternStart) / 4)));\r\n                    if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) {\r\n                        return {\r\n                            start: patternStart,\r\n                            end: i\r\n                        };\r\n                    }\r\n                }\r\n\r\n                patternStart += counter[0] + counter[1];\r\n                for ( j = 0; j < 7; j++) {\r\n                    counter[j] = counter[j + 2];\r\n                }\r\n                counter[7] = 0;\r\n                counter[8] = 0;\r\n                counterPos--;\r\n            } else {\r\n                counterPos++;\r\n            }\r\n            counter[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nexport default Code39Reader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_39_reader.js","module.exports = dot\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nfunction dot(a, b) {\n    return a[0] * b[0] + a[1] * b[1]\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/dot.js\n// module id = 32\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Map.js\n// module id = 33\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_MapCache.js\n// module id = 34\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assignMergeValue.js\n// module id = 35\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assignValue.js\n// module id = 36\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_defineProperty.js\n// module id = 37\n// module chunks = 0","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_freeGlobal.js\n// module id = 38\n// module chunks = 0","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getPrototype.js\n// module id = 39\n// module chunks = 0","/** 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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isPrototype.js\n// module id = 40\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_overRest.js\n// module id = 41\n// module chunks = 0","/**\n * Gets the value at `key`, unless `key` is \"__proto__\".\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  return key == '__proto__'\n    ? undefined\n    : object[key];\n}\n\nmodule.exports = safeGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_safeGet.js\n// module id = 42\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_setToString.js\n// module id = 43\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/identity.js\n// module id = 44\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isBuffer.js\n// module id = 45\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isTypedArray.js\n// module id = 46\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/keysIn.js\n// module id = 47\n// module chunks = 0","var g;\r\n\r\n// This works in non-strict mode\r\ng = (function() {\r\n\treturn this;\r\n})();\r\n\r\ntry {\r\n\t// This works if eval is allowed (see CSP)\r\n\tg = g || Function(\"return this\")() || (1,eval)(\"this\");\r\n} catch(e) {\r\n\t// This works if the window reference is available\r\n\tif(typeof window === \"object\")\r\n\t\tg = window;\r\n}\r\n\r\n// g can still be undefined, but nothing to do about it...\r\n// We return undefined, instead of nothing here, so it's\r\n// easier to handle this case. if(!global) { ...}\r\n\r\nmodule.exports = g;\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/global.js\n// module id = 48\n// module chunks = 0","import TypeDefs from './common/typedefs'; // eslint-disable-line no-unused-vars\r\nimport ImageWrapper from './common/image_wrapper';\r\nimport BarcodeLocator from './locator/barcode_locator';\r\nimport BarcodeDecoder from './decoder/barcode_decoder';\r\nimport Events from './common/events';\r\nimport CameraAccess from './input/camera_access';\r\nimport ImageDebug from './common/image_debug';\r\nimport ResultCollector from './analytics/result_collector';\r\nimport Config from './config/config';\r\nimport InputStream from 'input_stream';\r\nimport FrameGrabber from 'frame_grabber';\r\nimport {merge} from 'lodash';\r\nconst vec2 = {\r\n    clone: require('gl-vec2/clone')\r\n};\r\n\r\nvar _inputStream,\r\n    _framegrabber,\r\n    _stopped,\r\n    _canvasContainer = {\r\n        ctx: {\r\n            image: null,\r\n            overlay: null\r\n        },\r\n        dom: {\r\n            image: null,\r\n            overlay: null\r\n        }\r\n    },\r\n    _inputImageWrapper,\r\n    _boxSize,\r\n    _decoder,\r\n    _workerPool = [],\r\n    _onUIThread = true,\r\n    _resultCollector,\r\n    _config = {};\r\n\r\nfunction initializeData(imageWrapper) {\r\n    initBuffers(imageWrapper);\r\n    _decoder = BarcodeDecoder.create(_config.decoder, _inputImageWrapper);\r\n}\r\n\r\nfunction initInputStream(cb) {\r\n    var video;\r\n    if (_config.inputStream.type === \"VideoStream\") {\r\n        video = document.createElement(\"video\");\r\n        _inputStream = InputStream.createVideoStream(video);\r\n    } else if (_config.inputStream.type === \"ImageStream\") {\r\n        _inputStream = InputStream.createImageStream();\r\n    } else if (_config.inputStream.type === \"LiveStream\") {\r\n        var $viewport = getViewPort();\r\n        if ($viewport) {\r\n            video = $viewport.querySelector(\"video\");\r\n            if (!video) {\r\n                video = document.createElement(\"video\");\r\n                $viewport.appendChild(video);\r\n            }\r\n        }\r\n        _inputStream = InputStream.createLiveStream(video);\r\n        CameraAccess.request(video, _config.inputStream.constraints)\r\n        .then(() => {\r\n            _inputStream.trigger(\"canrecord\");\r\n        }).catch((err) => {\r\n            return cb(err);\r\n        });\r\n    }\r\n\r\n    _inputStream.setAttribute(\"preload\", \"auto\");\r\n    _inputStream.setInputStream(_config.inputStream);\r\n    _inputStream.addEventListener(\"canrecord\", canRecord.bind(undefined, cb));\r\n}\r\n\r\nfunction getViewPort() {\r\n    var target = _config.inputStream.target;\r\n    // Check if target is already a DOM element\r\n    if (target && target.nodeName && target.nodeType === 1) {\r\n        return target;\r\n    } else {\r\n        // Use '#interactive.viewport' as a fallback selector (backwards compatibility)\r\n        var selector = typeof target === 'string' ? target : '#interactive.viewport';\r\n        return document.querySelector(selector);\r\n    }\r\n}\r\n\r\nfunction canRecord(cb) {\r\n    BarcodeLocator.checkImageConstraints(_inputStream, _config.locator);\r\n    initCanvas(_config);\r\n    _framegrabber = FrameGrabber.create(_inputStream, _canvasContainer.dom.image);\r\n\r\n    adjustWorkerPool(_config.numOfWorkers, function() {\r\n        if (_config.numOfWorkers === 0) {\r\n            initializeData();\r\n        }\r\n        ready(cb);\r\n    });\r\n}\r\n\r\nfunction ready(cb){\r\n    _inputStream.play();\r\n    cb();\r\n}\r\n\r\nfunction initCanvas() {\r\n    if (typeof document !== \"undefined\") {\r\n        var $viewport = getViewPort();\r\n        _canvasContainer.dom.image = document.querySelector(\"canvas.imgBuffer\");\r\n        if (!_canvasContainer.dom.image) {\r\n            _canvasContainer.dom.image = document.createElement(\"canvas\");\r\n            _canvasContainer.dom.image.className = \"imgBuffer\";\r\n            if ($viewport && _config.inputStream.type === \"ImageStream\") {\r\n                $viewport.appendChild(_canvasContainer.dom.image);\r\n            }\r\n        }\r\n        _canvasContainer.ctx.image = _canvasContainer.dom.image.getContext(\"2d\");\r\n        _canvasContainer.dom.image.width = _inputStream.getCanvasSize().x;\r\n        _canvasContainer.dom.image.height = _inputStream.getCanvasSize().y;\r\n\r\n        _canvasContainer.dom.overlay = document.querySelector(\"canvas.drawingBuffer\");\r\n        if (!_canvasContainer.dom.overlay) {\r\n            _canvasContainer.dom.overlay = document.createElement(\"canvas\");\r\n            _canvasContainer.dom.overlay.className = \"drawingBuffer\";\r\n            if ($viewport) {\r\n                $viewport.appendChild(_canvasContainer.dom.overlay);\r\n            }\r\n            var clearFix = document.createElement(\"br\");\r\n            clearFix.setAttribute(\"clear\", \"all\");\r\n            if ($viewport) {\r\n                $viewport.appendChild(clearFix);\r\n            }\r\n        }\r\n        _canvasContainer.ctx.overlay = _canvasContainer.dom.overlay.getContext(\"2d\");\r\n        _canvasContainer.dom.overlay.width = _inputStream.getCanvasSize().x;\r\n        _canvasContainer.dom.overlay.height = _inputStream.getCanvasSize().y;\r\n    }\r\n}\r\n\r\nfunction initBuffers(imageWrapper) {\r\n    if (imageWrapper) {\r\n        _inputImageWrapper = imageWrapper;\r\n    } else {\r\n        _inputImageWrapper = new ImageWrapper({\r\n            x: _inputStream.getWidth(),\r\n            y: _inputStream.getHeight()\r\n        });\r\n    }\r\n\r\n    if (ENV.development) {\r\n        console.log(_inputImageWrapper.size);\r\n    }\r\n    _boxSize = [\r\n        vec2.clone([0, 0]),\r\n        vec2.clone([0, _inputImageWrapper.size.y]),\r\n        vec2.clone([_inputImageWrapper.size.x, _inputImageWrapper.size.y]),\r\n        vec2.clone([_inputImageWrapper.size.x, 0])\r\n    ];\r\n    BarcodeLocator.init(_inputImageWrapper, _config.locator);\r\n}\r\n\r\nfunction getBoundingBoxes() {\r\n    if (_config.locate) {\r\n        return BarcodeLocator.locate();\r\n    } else {\r\n        return [[\r\n            vec2.clone(_boxSize[0]),\r\n            vec2.clone(_boxSize[1]),\r\n            vec2.clone(_boxSize[2]),\r\n            vec2.clone(_boxSize[3])]];\r\n    }\r\n}\r\n\r\nfunction transformResult(result) {\r\n    var topRight = _inputStream.getTopRight(),\r\n        xOffset = topRight.x,\r\n        yOffset = topRight.y,\r\n        i;\r\n\r\n    if (xOffset === 0 && yOffset === 0) {\r\n        return;\r\n    }\r\n\r\n    if (result.barcodes) {\r\n        for (i = 0; i < result.barcodes.length; i++) {\r\n            transformResult(result.barcodes[i]);\r\n        }\r\n    }\r\n\r\n    if (result.line && result.line.length === 2) {\r\n        moveLine(result.line);\r\n    }\r\n\r\n    if (result.box) {\r\n        moveBox(result.box);\r\n    }\r\n\r\n    if (result.boxes && result.boxes.length > 0) {\r\n        for (i = 0; i < result.boxes.length; i++) {\r\n            moveBox(result.boxes[i]);\r\n        }\r\n    }\r\n\r\n    function moveBox(box) {\r\n        var corner = box.length;\r\n\r\n        while (corner--) {\r\n            box[corner][0] += xOffset;\r\n            box[corner][1] += yOffset;\r\n        }\r\n    }\r\n\r\n    function moveLine(line) {\r\n        line[0].x += xOffset;\r\n        line[0].y += yOffset;\r\n        line[1].x += xOffset;\r\n        line[1].y += yOffset;\r\n    }\r\n}\r\n\r\nfunction addResult (result, imageData) {\r\n    if (!imageData || !_resultCollector) {\r\n        return;\r\n    }\r\n\r\n    if (result.barcodes) {\r\n        result.barcodes.filter(barcode => barcode.codeResult)\r\n            .forEach(barcode => addResult(barcode, imageData));\r\n    } else if (result.codeResult) {\r\n        _resultCollector.addResult(imageData, _inputStream.getCanvasSize(), result.codeResult);\r\n    }\r\n}\r\n\r\nfunction hasCodeResult (result) {\r\n    return result && (result.barcodes ?\r\n      result.barcodes.some(barcode => barcode.codeResult) :\r\n      result.codeResult);\r\n}\r\n\r\nfunction publishResult(result, imageData) {\r\n    let resultToPublish = result;\r\n\r\n    if (result && _onUIThread) {\r\n        transformResult(result);\r\n        addResult(result, imageData);\r\n        resultToPublish = result.barcodes || result;\r\n    }\r\n\r\n    Events.publish(\"processed\", resultToPublish);\r\n    if (hasCodeResult(result)) {\r\n        Events.publish(\"detected\", resultToPublish);\r\n    }\r\n}\r\n\r\nfunction locateAndDecode() {\r\n    var result,\r\n        boxes;\r\n\r\n    boxes = getBoundingBoxes();\r\n    if (boxes) {\r\n        result = _decoder.decodeFromBoundingBoxes(boxes);\r\n        result = result || {};\r\n        result.boxes = boxes;\r\n        publishResult(result, _inputImageWrapper.data);\r\n    } else {\r\n        publishResult();\r\n    }\r\n}\r\n\r\nfunction update() {\r\n    var availableWorker;\r\n\r\n    if (_onUIThread) {\r\n        if (_workerPool.length > 0) {\r\n            availableWorker = _workerPool.filter(function(workerThread) {\r\n                return !workerThread.busy;\r\n            })[0];\r\n            if (availableWorker) {\r\n                _framegrabber.attachData(availableWorker.imageData);\r\n            } else {\r\n                return; // all workers are busy\r\n            }\r\n        } else {\r\n            _framegrabber.attachData(_inputImageWrapper.data);\r\n        }\r\n        if (_framegrabber.grab()) {\r\n            if (availableWorker) {\r\n                availableWorker.busy = true;\r\n                availableWorker.worker.postMessage({\r\n                    cmd: 'process',\r\n                    imageData: availableWorker.imageData\r\n                }, [availableWorker.imageData.buffer]);\r\n            } else {\r\n                locateAndDecode();\r\n            }\r\n        }\r\n    } else {\r\n        locateAndDecode();\r\n    }\r\n}\r\n\r\nfunction startContinuousUpdate() {\r\n    var next = null,\r\n        delay = 1000 / (_config.frequency || 60);\r\n\r\n    _stopped = false;\r\n    (function frame(timestamp) {\r\n        next = next || timestamp;\r\n        if (!_stopped) {\r\n            if (timestamp >= next) {\r\n                next += delay;\r\n                update();\r\n            }\r\n            window.requestAnimFrame(frame);\r\n        }\r\n    }(performance.now()));\r\n}\r\n\r\nfunction start() {\r\n    if (_onUIThread && _config.inputStream.type === \"LiveStream\") {\r\n        startContinuousUpdate();\r\n    } else {\r\n        update();\r\n    }\r\n}\r\n\r\nfunction initWorker(cb) {\r\n    var blobURL,\r\n        workerThread = {\r\n            worker: undefined,\r\n            imageData: new Uint8Array(_inputStream.getWidth() * _inputStream.getHeight()),\r\n            busy: true\r\n        };\r\n\r\n    blobURL = generateWorkerBlob();\r\n    workerThread.worker = new Worker(blobURL);\r\n\r\n    workerThread.worker.onmessage = function(e) {\r\n        if (e.data.event === 'initialized') {\r\n            URL.revokeObjectURL(blobURL);\r\n            workerThread.busy = false;\r\n            workerThread.imageData = new Uint8Array(e.data.imageData);\r\n            if (ENV.development) {\r\n                console.log(\"Worker initialized\");\r\n            }\r\n            return cb(workerThread);\r\n        } else if (e.data.event === 'processed') {\r\n            workerThread.imageData = new Uint8Array(e.data.imageData);\r\n            workerThread.busy = false;\r\n            publishResult(e.data.result, workerThread.imageData);\r\n        } else if (e.data.event === 'error') {\r\n            if (ENV.development) {\r\n                console.log(\"Worker error: \" + e.data.message);\r\n            }\r\n        }\r\n    };\r\n\r\n    workerThread.worker.postMessage({\r\n        cmd: 'init',\r\n        size: {x: _inputStream.getWidth(), y: _inputStream.getHeight()},\r\n        imageData: workerThread.imageData,\r\n        config: configForWorker(_config)\r\n    }, [workerThread.imageData.buffer]);\r\n}\r\n\r\nfunction configForWorker(config) {\r\n    return {\r\n        ...config,\r\n        inputStream: {\r\n            ...config.inputStream,\r\n            target: null\r\n        }\r\n    };\r\n}\r\n\r\nfunction workerInterface(factory) {\r\n    /* eslint-disable no-undef*/\r\n    if (factory) {\r\n        var Quagga = factory().default;\r\n        if (!Quagga) {\r\n            self.postMessage({'event': 'error', message: 'Quagga could not be created'});\r\n            return;\r\n        }\r\n    }\r\n    var imageWrapper;\r\n\r\n    self.onmessage = function(e) {\r\n        if (e.data.cmd === 'init') {\r\n            var config = e.data.config;\r\n            config.numOfWorkers = 0;\r\n            imageWrapper = new Quagga.ImageWrapper({\r\n                x: e.data.size.x,\r\n                y: e.data.size.y\r\n            }, new Uint8Array(e.data.imageData));\r\n            Quagga.init(config, ready, imageWrapper);\r\n            Quagga.onProcessed(onProcessed);\r\n        } else if (e.data.cmd === 'process') {\r\n            imageWrapper.data = new Uint8Array(e.data.imageData);\r\n            Quagga.start();\r\n        } else if (e.data.cmd === 'setReaders') {\r\n            Quagga.setReaders(e.data.readers);\r\n        }\r\n    };\r\n\r\n    function onProcessed(result) {\r\n        self.postMessage({\r\n            'event': 'processed',\r\n            imageData: imageWrapper.data,\r\n            result: result\r\n        }, [imageWrapper.data.buffer]);\r\n    }\r\n\r\n    function ready() { // eslint-disable-line\r\n        self.postMessage({'event': 'initialized', imageData: imageWrapper.data}, [imageWrapper.data.buffer]);\r\n    }\r\n\r\n    /* eslint-enable */\r\n}\r\n\r\nfunction generateWorkerBlob() {\r\n    var blob,\r\n        factorySource;\r\n\r\n    /* jshint ignore:start */\r\n    if (typeof __factorySource__ !== 'undefined') {\r\n        factorySource = __factorySource__; // eslint-disable-line no-undef\r\n    }\r\n    /* jshint ignore:end */\r\n\r\n    blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'],\r\n        {type: 'text/javascript'});\r\n\r\n    return window.URL.createObjectURL(blob);\r\n}\r\n\r\nfunction setReaders(readers) {\r\n    if (_decoder) {\r\n        _decoder.setReaders(readers);\r\n    } else if (_onUIThread && _workerPool.length > 0) {\r\n        _workerPool.forEach(function(workerThread) {\r\n            workerThread.worker.postMessage({cmd: 'setReaders', readers: readers});\r\n        });\r\n    }\r\n}\r\n\r\nfunction adjustWorkerPool(capacity, cb) {\r\n    const increaseBy = capacity - _workerPool.length;\r\n    if (increaseBy === 0) {\r\n        return cb && cb();\r\n    }\r\n    if (increaseBy < 0) {\r\n        const workersToTerminate = _workerPool.slice(increaseBy);\r\n        workersToTerminate.forEach(function(workerThread) {\r\n            workerThread.worker.terminate();\r\n            if (ENV.development) {\r\n                console.log(\"Worker terminated!\");\r\n            }\r\n        });\r\n        _workerPool = _workerPool.slice(0, increaseBy);\r\n        return cb && cb();\r\n    } else {\r\n        for (var i = 0; i < increaseBy; i++) {\r\n            initWorker(workerInitialized);\r\n        }\r\n\r\n        function workerInitialized(workerThread) {\r\n            _workerPool.push(workerThread);\r\n            if (_workerPool.length >= capacity){\r\n                cb && cb();\r\n            }\r\n        }\r\n    }\r\n}\r\n\r\nexport default {\r\n    init: function(config, cb, imageWrapper) {\r\n        _config = merge({}, Config, config);\r\n        if (imageWrapper) {\r\n            _onUIThread = false;\r\n            initializeData(imageWrapper);\r\n            return cb();\r\n        } else {\r\n            initInputStream(cb);\r\n        }\r\n    },\r\n    start: function() {\r\n        start();\r\n    },\r\n    stop: function() {\r\n        _stopped = true;\r\n        adjustWorkerPool(0);\r\n        if (_config.inputStream.type === \"LiveStream\") {\r\n            CameraAccess.release();\r\n            _inputStream.clearEventHandlers();\r\n        }\r\n    },\r\n    pause: function() {\r\n        _stopped = true;\r\n    },\r\n    onDetected: function(callback) {\r\n        Events.subscribe(\"detected\", callback);\r\n    },\r\n    offDetected: function(callback) {\r\n        Events.unsubscribe(\"detected\", callback);\r\n    },\r\n    onProcessed: function(callback) {\r\n        Events.subscribe(\"processed\", callback);\r\n    },\r\n    offProcessed: function(callback) {\r\n        Events.unsubscribe(\"processed\", callback);\r\n    },\r\n    setReaders: function(readers) {\r\n        setReaders(readers);\r\n    },\r\n    registerResultCollector: function(resultCollector) {\r\n        if (resultCollector && typeof resultCollector.addResult === 'function') {\r\n            _resultCollector = resultCollector;\r\n        }\r\n    },\r\n    canvas: _canvasContainer,\r\n    decodeSingle: function(config, resultCallback) {\r\n        config = merge({\r\n            inputStream: {\r\n                type: \"ImageStream\",\r\n                sequence: false,\r\n                size: 800,\r\n                src: config.src\r\n            },\r\n            numOfWorkers: (ENV.development && config.debug) ? 0 : 1,\r\n            locator: {\r\n                halfSample: false\r\n            }\r\n        }, config);\r\n        this.init(config, () => {\r\n            Events.once(\"processed\", (result) => {\r\n                this.stop();\r\n                resultCallback.call(null, result);\r\n            }, true);\r\n            start();\r\n        });\r\n    },\r\n    ImageWrapper: ImageWrapper,\r\n    ImageDebug: ImageDebug,\r\n    ResultCollector: ResultCollector,\r\n    CameraAccess: CameraAccess,\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/quagga.js","const CVUtils = require('../src/common/cv_utils'),\r\n      Ndarray = require(\"ndarray\"),\r\n      Interp2D = require(\"ndarray-linear-interpolate\").d2;\r\n\r\nvar FrameGrabber = {};\r\n\r\nFrameGrabber.create = function(inputStream) {\r\n    var _that = {},\r\n        _streamConfig = inputStream.getConfig(),\r\n        _video_size = CVUtils.imageRef(inputStream.getRealWidth(), inputStream.getRealHeight()),\r\n        _canvasSize = inputStream.getCanvasSize(),\r\n        _size = CVUtils.imageRef(inputStream.getWidth(), inputStream.getHeight()),\r\n        _topRight = inputStream.getTopRight(),\r\n        _data = new Uint8Array(_size.x * _size.y),\r\n        _grayData = new Uint8Array(_video_size.x * _video_size.y),\r\n        _canvasData = new Uint8Array(_canvasSize.x * _canvasSize.y),\r\n        _grayImageArray = Ndarray(_grayData, [_video_size.y, _video_size.x]).transpose(1, 0),\r\n        _canvasImageArray = Ndarray(_canvasData, [_canvasSize.y, _canvasSize.x]).transpose(1, 0),\r\n        _targetImageArray = _canvasImageArray.hi(_topRight.x + _size.x, _topRight.y + _size.y).lo(_topRight.x, _topRight.y),\r\n        _stepSizeX = _video_size.x/_canvasSize.x,\r\n        _stepSizeY = _video_size.y/_canvasSize.y;\r\n\r\n    console.log(\"FrameGrabber\", JSON.stringify({\r\n        videoSize: _grayImageArray.shape,\r\n        canvasSize: _canvasImageArray.shape,\r\n        stepSize: [_stepSizeX, _stepSizeY],\r\n        size: _targetImageArray.shape,\r\n        topRight: _topRight\r\n    }));\r\n\r\n    /**\r\n     * Uses the given array as frame-buffer\r\n     */\r\n    _that.attachData = function(data) {\r\n        _data = data;\r\n    };\r\n\r\n    /**\r\n     * Returns the used frame-buffer\r\n     */\r\n    _that.getData = function() {\r\n        return _data;\r\n    };\r\n\r\n    /**\r\n     * Fetches a frame from the input-stream and puts into the frame-buffer.\r\n     * The image-data is converted to gray-scale and then half-sampled if configured.\r\n     */\r\n    _that.grab = function() {\r\n        var frame = inputStream.getFrame();\r\n\r\n        if (frame) {\r\n            this.scaleAndCrop(frame);\r\n            return true;\r\n        } else {\r\n            return false;\r\n        }\r\n    };\r\n\r\n    _that.scaleAndCrop = function(frame) {\r\n        var x,\r\n            y;\r\n\r\n        // 1. compute full-sized gray image\r\n        CVUtils.computeGray(frame.data, _grayData);\r\n\r\n        // 2. interpolate\r\n        for (y = 0; y < _canvasSize.y; y++) {\r\n            for (x = 0; x < _canvasSize.x; x++) {\r\n                _canvasImageArray.set(x, y, (Interp2D(_grayImageArray, x * _stepSizeX, y * _stepSizeY)) | 0);\r\n            }\r\n        }\r\n\r\n        // targetImageArray must be equal to targetSize\r\n        if (_targetImageArray.shape[0] !== _size.x ||\r\n            _targetImageArray.shape[1] !== _size.y) {\r\n            throw new Error(\"Shapes do not match!\");\r\n        }\r\n\r\n        // 3. crop\r\n        for (y = 0; y < _size.y; y++) {\r\n            for (x = 0; x < _size.x; x++) {\r\n                _data[y * _size.x + x] = _targetImageArray.get(x, y);\r\n            }\r\n        }\r\n    },\r\n\r\n    _that.getSize = function() {\r\n        return _size;\r\n    };\r\n\r\n    return _that;\r\n};\r\n\r\nmodule.exports = FrameGrabber;\r\n\n\n\n// WEBPACK FOOTER //\n// ./lib/frame_grabber.js","const GetPixels = require(\"get-pixels\");\r\n\r\nvar InputStream = {};\r\n\r\nInputStream.createImageStream = function() {\r\n    var that = {};\r\n    var _config = null;\r\n\r\n    var width = 0,\r\n        height = 0,\r\n        frameIdx = 0,\r\n        paused = true,\r\n        loaded = false,\r\n        frame = null,\r\n        baseUrl,\r\n        ended = false,\r\n        size,\r\n        calculatedWidth,\r\n        calculatedHeight,\r\n        _eventNames = ['canrecord', 'ended'],\r\n        _eventHandlers = {},\r\n        _topRight = {x: 0, y: 0},\r\n        _canvasSize = {x: 0, y: 0};\r\n\r\n    function loadImages() {\r\n        loaded = false;\r\n        GetPixels(baseUrl, _config.mime, function(err, pixels) {\r\n            if (err) {\r\n                console.log(err);\r\n                exit(1);\r\n            }\r\n            loaded = true;\r\n            console.log(pixels.shape);\r\n            frame = pixels;\r\n            width = pixels.shape[0];\r\n            height = pixels.shape[1];\r\n            calculatedWidth = _config.size ? width/height > 1 ? _config.size : Math.floor((width/height) * _config.size) : width;\r\n            calculatedHeight = _config.size ? width/height > 1 ? Math.floor((height/width) * _config.size) : _config.size : height;\r\n\r\n            _canvasSize.x = calculatedWidth;\r\n            _canvasSize.y = calculatedHeight;\r\n\r\n            setTimeout(function() {\r\n                publishEvent(\"canrecord\", []);\r\n            }, 0);\r\n        });\r\n    }\r\n\r\n    function publishEvent(eventName, args) {\r\n        var j,\r\n            handlers = _eventHandlers[eventName];\r\n\r\n        if (handlers && handlers.length > 0) {\r\n            for ( j = 0; j < handlers.length; j++) {\r\n                handlers[j].apply(that, args);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    that.trigger = publishEvent;\r\n\r\n    that.getWidth = function() {\r\n        return calculatedWidth;\r\n    };\r\n\r\n    that.getHeight = function() {\r\n        return calculatedHeight;\r\n    };\r\n\r\n    that.setWidth = function(width) {\r\n        calculatedWidth = width;\r\n    };\r\n\r\n    that.setHeight = function(height) {\r\n        calculatedHeight = height;\r\n    };\r\n\r\n    that.getRealWidth = function() {\r\n        return width;\r\n    };\r\n\r\n    that.getRealHeight = function() {\r\n        return height;\r\n    };\r\n\r\n    that.setInputStream = function(stream) {\r\n        _config = stream;\r\n        baseUrl = _config.src;\r\n        size = 1;\r\n        loadImages();\r\n    };\r\n\r\n    that.ended = function() {\r\n        return ended;\r\n    };\r\n\r\n    that.setAttribute = function() {};\r\n\r\n    that.getConfig = function() {\r\n        return _config;\r\n    };\r\n\r\n    that.pause = function() {\r\n        paused = true;\r\n    };\r\n\r\n    that.play = function() {\r\n        paused = false;\r\n    };\r\n\r\n    that.setCurrentTime = function(time) {\r\n        frameIdx = time;\r\n    };\r\n\r\n    that.addEventListener = function(event, f) {\r\n        if (_eventNames.indexOf(event) !== -1) {\r\n            if (!_eventHandlers[event]) {\r\n                _eventHandlers[event] = [];\r\n            }\r\n            _eventHandlers[event].push(f);\r\n        }\r\n    };\r\n\r\n    that.setTopRight = function(topRight) {\r\n        _topRight.x = topRight.x;\r\n        _topRight.y = topRight.y;\r\n    };\r\n\r\n    that.getTopRight = function() {\r\n        return _topRight;\r\n    };\r\n\r\n    that.setCanvasSize = function(size) {\r\n        _canvasSize.x = size.x;\r\n        _canvasSize.y = size.y;\r\n    };\r\n\r\n    that.getCanvasSize = function() {\r\n        return _canvasSize;\r\n    };\r\n\r\n    that.getFrame = function() {\r\n        if (!loaded){\r\n            return null;\r\n        }\r\n        return frame;\r\n    };\r\n\r\n    return that;\r\n};\r\n\r\nmodule.exports = InputStream;\r\n\n\n\n// WEBPACK FOOTER //\n// ./lib/input_stream.js","import ImageDebug from '../common/image_debug';\r\n\r\nfunction contains(codeResult, list) {\r\n    if (list) {\r\n        return list.some(function (item) {\r\n            return Object.keys(item).every(function (key) {\r\n                return item[key] === codeResult[key];\r\n            });\r\n        });\r\n    }\r\n    return false;\r\n}\r\n\r\nfunction passesFilter(codeResult, filter) {\r\n    if (typeof filter === 'function') {\r\n        return filter(codeResult);\r\n    }\r\n    return true;\r\n}\r\n\r\nexport default {\r\n    create: function(config) {\r\n        var canvas = document.createElement(\"canvas\"),\r\n            ctx = canvas.getContext(\"2d\"),\r\n            results = [],\r\n            capacity = config.capacity || 20,\r\n            capture = config.capture === true;\r\n\r\n        function matchesConstraints(codeResult) {\r\n            return capacity\r\n                && codeResult\r\n                && !contains(codeResult, config.blacklist)\r\n                && passesFilter(codeResult, config.filter);\r\n        }\r\n\r\n        return {\r\n            addResult: function(data, imageSize, codeResult) {\r\n                var result = {};\r\n\r\n                if (matchesConstraints(codeResult)) {\r\n                    capacity--;\r\n                    result.codeResult = codeResult;\r\n                    if (capture) {\r\n                        canvas.width = imageSize.x;\r\n                        canvas.height = imageSize.y;\r\n                        ImageDebug.drawImage(data, imageSize, ctx);\r\n                        result.frame = canvas.toDataURL();\r\n                    }\r\n                    results.push(result);\r\n                }\r\n            },\r\n            getResults: function() {\r\n                return results;\r\n            }\r\n        };\r\n    }\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/analytics/result_collector.js","const vec2 = {\r\n    clone: require('gl-vec2/clone'),\r\n    dot: require('gl-vec2/dot')\r\n}\r\n    /**\r\n     * Creates a cluster for grouping similar orientations of datapoints\r\n     */\r\nexport default {\r\n    create: function(point, threshold) {\r\n        var points = [],\r\n            center = {\r\n                rad: 0,\r\n                vec: vec2.clone([0, 0])\r\n            },\r\n            pointMap = {};\r\n\r\n        function init() {\r\n            add(point);\r\n            updateCenter();\r\n        }\r\n\r\n        function add(pointToAdd) {\r\n            pointMap[pointToAdd.id] = pointToAdd;\r\n            points.push(pointToAdd);\r\n        }\r\n\r\n        function updateCenter() {\r\n            var i, sum = 0;\r\n            for ( i = 0; i < points.length; i++) {\r\n                sum += points[i].rad;\r\n            }\r\n            center.rad = sum / points.length;\r\n            center.vec = vec2.clone([Math.cos(center.rad), Math.sin(center.rad)]);\r\n        }\r\n\r\n        init();\r\n\r\n        return {\r\n            add: function(pointToAdd) {\r\n                if (!pointMap[pointToAdd.id]) {\r\n                    add(pointToAdd);\r\n                    updateCenter();\r\n                }\r\n            },\r\n            fits: function(otherPoint) {\r\n                // check cosine similarity to center-angle\r\n                var similarity = Math.abs(vec2.dot(otherPoint.point.vec, center.vec));\r\n                if (similarity > threshold) {\r\n                    return true;\r\n                }\r\n                return false;\r\n            },\r\n            getPoints: function() {\r\n                return points;\r\n            },\r\n            getCenter: function() {\r\n                return center;\r\n            }\r\n        };\r\n    },\r\n    createPoint: function(newPoint, id, property) {\r\n        return {\r\n            rad: newPoint[property],\r\n            point: newPoint,\r\n            id: id\r\n        };\r\n    }\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/cluster.js","export default (function() {\r\n    var events = {};\r\n\r\n    function getEvent(eventName) {\r\n        if (!events[eventName]) {\r\n            events[eventName] = {\r\n                subscribers: []\r\n            };\r\n        }\r\n        return events[eventName];\r\n    }\r\n\r\n    function clearEvents(){\r\n        events = {};\r\n    }\r\n\r\n    function publishSubscription(subscription, data) {\r\n        if (subscription.async) {\r\n            setTimeout(function() {\r\n                subscription.callback(data);\r\n            }, 4);\r\n        } else {\r\n            subscription.callback(data);\r\n        }\r\n    }\r\n\r\n    function subscribe(event, callback, async) {\r\n        var subscription;\r\n\r\n        if ( typeof callback === \"function\") {\r\n            subscription = {\r\n                callback: callback,\r\n                async: async\r\n            };\r\n        } else {\r\n            subscription = callback;\r\n            if (!subscription.callback) {\r\n                throw \"Callback was not specified on options\";\r\n            }\r\n        }\r\n\r\n        getEvent(event).subscribers.push(subscription);\r\n    }\r\n\r\n    return {\r\n        subscribe: function(event, callback, async) {\r\n            return subscribe(event, callback, async);\r\n        },\r\n        publish: function(eventName, data) {\r\n            var event = getEvent(eventName),\r\n                subscribers = event.subscribers;\r\n\r\n            // Publish one-time subscriptions\r\n            subscribers.filter(function(subscriber) {\r\n                return !!subscriber.once;\r\n            }).forEach((subscriber) => {\r\n                publishSubscription(subscriber, data);\r\n            });\r\n\r\n            // remove them from the subscriber\r\n            event.subscribers = subscribers.filter(function(subscriber) {\r\n                return !subscriber.once;\r\n            });\r\n\r\n            // publish the rest\r\n            event.subscribers.forEach((subscriber) => {\r\n                publishSubscription(subscriber, data);\r\n            });\r\n        },\r\n        once: function(event, callback, async) {\r\n            subscribe(event, {\r\n                callback: callback,\r\n                async: async,\r\n                once: true\r\n            });\r\n        },\r\n        unsubscribe: function(eventName, callback) {\r\n            var event;\r\n\r\n            if (eventName) {\r\n                event = getEvent(eventName);\r\n                if (event && callback) {\r\n                    event.subscribers = event.subscribers.filter(function(subscriber){\r\n                        return subscriber.callback !== callback;\r\n                    });\r\n                } else {\r\n                    event.subscribers = [];\r\n                }\r\n            } else {\r\n                clearEvents();\r\n            }\r\n        }\r\n    };\r\n})();\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/events.js","\r\nexport function enumerateDevices() {\r\n    if (navigator.mediaDevices\r\n            && typeof navigator.mediaDevices.enumerateDevices === 'function') {\r\n        return navigator.mediaDevices.enumerateDevices();\r\n    }\r\n    return Promise.reject(new Error('enumerateDevices is not defined'));\r\n};\r\n\r\nexport function getUserMedia(constraints) {\r\n    if (navigator.mediaDevices\r\n            && typeof navigator.mediaDevices.getUserMedia === 'function') {\r\n        return navigator.mediaDevices\r\n            .getUserMedia(constraints);\r\n    }\r\n    return Promise.reject(new Error('getUserMedia is not defined'));\r\n}\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/mediaDevices.js","/**\r\n * Construct representing a part of another {ImageWrapper}. Shares data\r\n * between the parent and the child.\r\n * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner)\r\n * @param size {ImageRef} The size of the resulting image\r\n * @param I {ImageWrapper} The {ImageWrapper} to share from\r\n * @returns {SubImage} A shared part of the original image\r\n */\r\nfunction SubImage(from, size, I) {\r\n    if (!I) {\r\n        I = {\r\n            data: null,\r\n            size: size\r\n        };\r\n    }\r\n    this.data = I.data;\r\n    this.originalSize = I.size;\r\n    this.I = I;\r\n\r\n    this.from = from;\r\n    this.size = size;\r\n}\r\n\r\n/**\r\n * Displays the {SubImage} in a given canvas\r\n * @param canvas {Canvas} The canvas element to write to\r\n * @param scale {Number} Scale which is applied to each pixel-value\r\n */\r\nSubImage.prototype.show = function(canvas, scale) {\r\n    var ctx,\r\n        frame,\r\n        data,\r\n        current,\r\n        y,\r\n        x,\r\n        pixel;\r\n\r\n    if (!scale) {\r\n        scale = 1.0;\r\n    }\r\n    ctx = canvas.getContext('2d');\r\n    canvas.width = this.size.x;\r\n    canvas.height = this.size.y;\r\n    frame = ctx.getImageData(0, 0, canvas.width, canvas.height);\r\n    data = frame.data;\r\n    current = 0;\r\n    for (y = 0; y < this.size.y; y++) {\r\n        for (x = 0; x < this.size.x; x++) {\r\n            pixel = y * this.size.x + x;\r\n            current = this.get(x, y) * scale;\r\n            data[pixel * 4 + 0] = current;\r\n            data[pixel * 4 + 1] = current;\r\n            data[pixel * 4 + 2] = current;\r\n            data[pixel * 4 + 3] = 255;\r\n        }\r\n    }\r\n    frame.data = data;\r\n    ctx.putImageData(frame, 0, 0);\r\n};\r\n\r\n/**\r\n * Retrieves a given pixel position from the {SubImage}\r\n * @param x {Number} The x-position\r\n * @param y {Number} The y-position\r\n * @returns {Number} The grayscale value at the pixel-position\r\n */\r\nSubImage.prototype.get = function(x, y) {\r\n    return this.data[(this.from.y + y) * this.originalSize.x + this.from.x + x];\r\n};\r\n\r\n/**\r\n * Updates the underlying data from a given {ImageWrapper}\r\n * @param image {ImageWrapper} The updated image\r\n */\r\nSubImage.prototype.updateData = function(image) {\r\n    this.originalSize = image.size;\r\n    this.data = image.data;\r\n};\r\n\r\n/**\r\n * Updates the position of the shared area\r\n * @param from {x,y} The new location\r\n * @returns {SubImage} returns {this} for possible chaining\r\n */\r\nSubImage.prototype.updateFrom = function(from) {\r\n    this.from = from;\r\n    return this;\r\n};\r\n\r\nexport default (SubImage);\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/subImage.js","/*\r\n * typedefs.js\r\n * Normalizes browser-specific prefixes\r\n */\r\n\r\nif (typeof window !== 'undefined') {\r\n    window.requestAnimFrame = (function () {\r\n        return window.requestAnimationFrame ||\r\n            window.webkitRequestAnimationFrame ||\r\n            window.mozRequestAnimationFrame ||\r\n            window.oRequestAnimationFrame ||\r\n            window.msRequestAnimationFrame ||\r\n            function (/* function FrameRequestCallback */ callback) {\r\n                window.setTimeout(callback, 1000 / 60);\r\n            };\r\n    })();\r\n}\r\nMath.imul = Math.imul || function(a, b) {\r\n    var ah = (a >>> 16) & 0xffff,\r\n        al = a & 0xffff,\r\n        bh = (b >>> 16) & 0xffff,\r\n        bl = b & 0xffff;\r\n    // the shift by 0 fixes the sign on the high part\r\n    // the final |0 converts the unsigned value into a signed value\r\n    return ((al * bl) + (((ah * bl + al * bh) << 16) >>> 0) | 0);\r\n};\r\n\r\nif (typeof Object.assign !== 'function') {\r\n    Object.assign = function(target) { // .length of function is 2\r\n        'use strict';\r\n        if (target === null) { // TypeError if undefined or null\r\n            throw new TypeError('Cannot convert undefined or null to object');\r\n        }\r\n\r\n        var to = Object(target);\r\n\r\n        for (var index = 1; index < arguments.length; index++) {\r\n            var nextSource = arguments[index];\r\n\r\n            if (nextSource !== null) { // Skip over if undefined or null\r\n                for (var nextKey in nextSource) {\r\n                    // Avoid bugs when hasOwnProperty is shadowed\r\n                    if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {\r\n                        to[nextKey] = nextSource[nextKey];\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        return to;\r\n    };\r\n}\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/typedefs.js","let config;\r\n\r\nif (ENV.development){\r\n    config = require('./config.dev.js');\r\n} else if (ENV.node) {\r\n    config = require('./config.node.js');\r\n} else {\r\n    config = require('./config.prod.js');\r\n}\r\n\r\nexport default config;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/config/config.js","module.exports = {\r\n    inputStream: {\r\n        type: \"ImageStream\",\r\n        sequence: false,\r\n        size: 800,\r\n        area: {\r\n            top: \"0%\",\r\n            right: \"0%\",\r\n            left: \"0%\",\r\n            bottom: \"0%\"\r\n        },\r\n        singleChannel: false // true: only the red color-channel is read\r\n    },\r\n    locate: true,\r\n    numOfWorkers: 0,\r\n    decoder: {\r\n        readers: [\r\n            'code_128_reader'\r\n        ]\r\n    },\r\n    locator: {\r\n        halfSample: true,\r\n        patchSize: \"medium\" // x-small, small, medium, large, x-large\r\n    }\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/config/config.node.js","import Bresenham from './bresenham';\r\nimport ImageDebug from '../common/image_debug';\r\nimport Code128Reader from '../reader/code_128_reader';\r\nimport EANReader from '../reader/ean_reader';\r\nimport Code39Reader from '../reader/code_39_reader';\r\nimport Code39VINReader from '../reader/code_39_vin_reader';\r\nimport CodabarReader from '../reader/codabar_reader';\r\nimport UPCReader from '../reader/upc_reader';\r\nimport EAN8Reader from '../reader/ean_8_reader';\r\nimport EAN2Reader from '../reader/ean_2_reader';\r\nimport EAN5Reader from '../reader/ean_5_reader';\r\nimport UPCEReader from '../reader/upc_e_reader';\r\nimport I2of5Reader from '../reader/i2of5_reader';\r\nimport TwoOfFiveReader from '../reader/2of5_reader';\r\nimport Code93Reader from '../reader/code_93_reader';\r\n\r\nconst READERS = {\r\n    code_128_reader: Code128Reader,\r\n    ean_reader: EANReader,\r\n    ean_5_reader: EAN5Reader,\r\n    ean_2_reader: EAN2Reader,\r\n    ean_8_reader: EAN8Reader,\r\n    code_39_reader: Code39Reader,\r\n    code_39_vin_reader: Code39VINReader,\r\n    codabar_reader: CodabarReader,\r\n    upc_reader: UPCReader,\r\n    upc_e_reader: UPCEReader,\r\n    i2of5_reader: I2of5Reader,\r\n    '2of5_reader': TwoOfFiveReader,\r\n    code_93_reader: Code93Reader\r\n};\r\nexport default {\r\n    create: function(config, inputImageWrapper) {\r\n        var _canvas = {\r\n                ctx: {\r\n                    frequency: null,\r\n                    pattern: null,\r\n                    overlay: null\r\n                },\r\n                dom: {\r\n                    frequency: null,\r\n                    pattern: null,\r\n                    overlay: null\r\n                }\r\n            },\r\n            _barcodeReaders = [];\r\n\r\n        initCanvas();\r\n        initReaders();\r\n        initConfig();\r\n\r\n        function initCanvas() {\r\n            if (ENV.development && typeof document !== 'undefined') {\r\n                var $debug = document.querySelector(\"#debug.detection\");\r\n                _canvas.dom.frequency = document.querySelector(\"canvas.frequency\");\r\n                if (!_canvas.dom.frequency) {\r\n                    _canvas.dom.frequency = document.createElement(\"canvas\");\r\n                    _canvas.dom.frequency.className = \"frequency\";\r\n                    if ($debug) {\r\n                        $debug.appendChild(_canvas.dom.frequency);\r\n                    }\r\n                }\r\n                _canvas.ctx.frequency = _canvas.dom.frequency.getContext(\"2d\");\r\n\r\n                _canvas.dom.pattern = document.querySelector(\"canvas.patternBuffer\");\r\n                if (!_canvas.dom.pattern) {\r\n                    _canvas.dom.pattern = document.createElement(\"canvas\");\r\n                    _canvas.dom.pattern.className = \"patternBuffer\";\r\n                    if ($debug) {\r\n                        $debug.appendChild(_canvas.dom.pattern);\r\n                    }\r\n                }\r\n                _canvas.ctx.pattern = _canvas.dom.pattern.getContext(\"2d\");\r\n\r\n                _canvas.dom.overlay = document.querySelector(\"canvas.drawingBuffer\");\r\n                if (_canvas.dom.overlay) {\r\n                    _canvas.ctx.overlay = _canvas.dom.overlay.getContext(\"2d\");\r\n                }\r\n            }\r\n        }\r\n\r\n        function initReaders() {\r\n            config.readers.forEach(function(readerConfig) {\r\n                var reader,\r\n                    configuration = {},\r\n                    supplements = [];\r\n\r\n                if (typeof readerConfig === 'object') {\r\n                    reader = readerConfig.format;\r\n                    configuration = readerConfig.config;\r\n                } else if (typeof readerConfig === 'string') {\r\n                    reader = readerConfig;\r\n                }\r\n                if (ENV.development) {\r\n                    console.log(\"Before registering reader: \", reader);\r\n                }\r\n                if (configuration.supplements) {\r\n                    supplements = configuration\r\n                        .supplements.map((supplement) => {\r\n                            return new READERS[supplement]();\r\n                        });\r\n                }\r\n                _barcodeReaders.push(new READERS[reader](configuration, supplements));\r\n            });\r\n            if (ENV.development) {\r\n                console.log(\"Registered Readers: \" + _barcodeReaders\r\n                    .map((reader) => JSON.stringify({format: reader.FORMAT, config: reader.config}))\r\n                    .join(', '));\r\n            }\r\n        }\r\n\r\n        function initConfig() {\r\n            if (ENV.development && typeof document !== 'undefined') {\r\n                var i,\r\n                    vis = [{\r\n                        node: _canvas.dom.frequency,\r\n                        prop: config.debug.showFrequency\r\n                    }, {\r\n                        node: _canvas.dom.pattern,\r\n                        prop: config.debug.showPattern\r\n                    }];\r\n\r\n                for (i = 0; i < vis.length; i++) {\r\n                    if (vis[i].prop === true) {\r\n                        vis[i].node.style.display = \"block\";\r\n                    } else {\r\n                        vis[i].node.style.display = \"none\";\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        /**\r\n         * extend the line on both ends\r\n         * @param {Array} line\r\n         * @param {Number} angle\r\n         */\r\n        function getExtendedLine(line, angle, ext) {\r\n            function extendLine(amount) {\r\n                var extension = {\r\n                    y: amount * Math.sin(angle),\r\n                    x: amount * Math.cos(angle)\r\n                };\r\n\r\n                line[0].y -= extension.y;\r\n                line[0].x -= extension.x;\r\n                line[1].y += extension.y;\r\n                line[1].x += extension.x;\r\n            }\r\n\r\n            // check if inside image\r\n            extendLine(ext);\r\n            while (ext > 1 && (!inputImageWrapper.inImageWithBorder(line[0], 0)\r\n                    || !inputImageWrapper.inImageWithBorder(line[1], 0))) {\r\n                ext -= Math.ceil(ext / 2);\r\n                extendLine(-ext);\r\n            }\r\n            return line;\r\n        }\r\n\r\n        function getLine(box) {\r\n            return [{\r\n                x: (box[1][0] - box[0][0]) / 2 + box[0][0],\r\n                y: (box[1][1] - box[0][1]) / 2 + box[0][1]\r\n            }, {\r\n                x: (box[3][0] - box[2][0]) / 2 + box[2][0],\r\n                y: (box[3][1] - box[2][1]) / 2 + box[2][1]\r\n            }];\r\n        }\r\n\r\n        function tryDecode(line) {\r\n            var result = null,\r\n                i,\r\n                barcodeLine = Bresenham.getBarcodeLine(inputImageWrapper, line[0], line[1]);\r\n\r\n            if (ENV.development && config.debug.showFrequency) {\r\n                ImageDebug.drawPath(line, {x: 'x', y: 'y'}, _canvas.ctx.overlay, {color: 'red', lineWidth: 3});\r\n                Bresenham.debug.printFrequency(barcodeLine.line, _canvas.dom.frequency);\r\n            }\r\n\r\n            Bresenham.toBinaryLine(barcodeLine);\r\n\r\n            if (ENV.development && config.debug.showPattern) {\r\n                Bresenham.debug.printPattern(barcodeLine.line, _canvas.dom.pattern);\r\n            }\r\n\r\n            for ( i = 0; i < _barcodeReaders.length && result === null; i++) {\r\n                result = _barcodeReaders[i].decodePattern(barcodeLine.line);\r\n            }\r\n            if (result === null){\r\n                return null;\r\n            }\r\n            return {\r\n                codeResult: result,\r\n                barcodeLine: barcodeLine\r\n            };\r\n        }\r\n\r\n        /**\r\n         * This method slices the given area apart and tries to detect a barcode-pattern\r\n         * for each slice. It returns the decoded barcode, or null if nothing was found\r\n         * @param {Array} box\r\n         * @param {Array} line\r\n         * @param {Number} lineAngle\r\n         */\r\n        function tryDecodeBruteForce(box, line, lineAngle) {\r\n            var sideLength = Math.sqrt(Math.pow(box[1][0] - box[0][0], 2) + Math.pow((box[1][1] - box[0][1]), 2)),\r\n                i,\r\n                slices = 16,\r\n                result = null,\r\n                dir,\r\n                extension,\r\n                xdir = Math.sin(lineAngle),\r\n                ydir = Math.cos(lineAngle);\r\n\r\n            for ( i = 1; i < slices && result === null; i++) {\r\n                // move line perpendicular to angle\r\n                dir = sideLength / slices * i * (i % 2 === 0 ? -1 : 1);\r\n                extension = {\r\n                    y: dir * xdir,\r\n                    x: dir * ydir\r\n                };\r\n                line[0].y += extension.x;\r\n                line[0].x -= extension.y;\r\n                line[1].y += extension.x;\r\n                line[1].x -= extension.y;\r\n\r\n                result = tryDecode(line);\r\n            }\r\n            return result;\r\n        }\r\n\r\n        function getLineLength(line) {\r\n            return Math.sqrt(\r\n                Math.pow(Math.abs(line[1].y - line[0].y), 2) +\r\n                Math.pow(Math.abs(line[1].x - line[0].x), 2));\r\n        }\r\n\r\n        /**\r\n         * With the help of the configured readers (Code128 or EAN) this function tries to detect a\r\n         * valid barcode pattern within the given area.\r\n         * @param {Object} box The area to search in\r\n         * @returns {Object} the result {codeResult, line, angle, pattern, threshold}\r\n         */\r\n        function decodeFromBoundingBox(box) {\r\n            var line,\r\n                lineAngle,\r\n                ctx = _canvas.ctx.overlay,\r\n                result,\r\n                lineLength;\r\n\r\n            if (ENV.development) {\r\n                if (config.debug.drawBoundingBox && ctx) {\r\n                    ImageDebug.drawPath(box, {x: 0, y: 1}, ctx, {color: \"blue\", lineWidth: 2});\r\n                }\r\n            }\r\n\r\n            line = getLine(box);\r\n            lineLength = getLineLength(line);\r\n            lineAngle = Math.atan2(line[1].y - line[0].y, line[1].x - line[0].x);\r\n            line = getExtendedLine(line, lineAngle, Math.floor(lineLength * 0.1));\r\n            if (line === null){\r\n                return null;\r\n            }\r\n\r\n            result = tryDecode(line);\r\n            if (result === null) {\r\n                result = tryDecodeBruteForce(box, line, lineAngle);\r\n            }\r\n\r\n            if (result === null) {\r\n                return null;\r\n            }\r\n\r\n            if (ENV.development && result && config.debug.drawScanline && ctx) {\r\n                ImageDebug.drawPath(line, {x: 'x', y: 'y'}, ctx, {color: 'red', lineWidth: 3});\r\n            }\r\n\r\n            return {\r\n                codeResult: result.codeResult,\r\n                line: line,\r\n                angle: lineAngle,\r\n                pattern: result.barcodeLine.line,\r\n                threshold: result.barcodeLine.threshold\r\n            };\r\n        }\r\n\r\n        return {\r\n            decodeFromBoundingBox: function(box) {\r\n                return decodeFromBoundingBox(box);\r\n            },\r\n            decodeFromBoundingBoxes: function(boxes) {\r\n                var i, result,\r\n                    barcodes = [],\r\n                    multiple = config.multiple;\r\n\r\n                for ( i = 0; i < boxes.length; i++) {\r\n                    const box = boxes[i];\r\n                    result = decodeFromBoundingBox(box) || {};\r\n                    result.box = box;\r\n\r\n                    if (multiple) {\r\n                        barcodes.push(result);\r\n                    } else if (result.codeResult) {\r\n                        return result;\r\n                    }\r\n                }\r\n\r\n                if (multiple) {\r\n                    return {\r\n                        barcodes\r\n                    };\r\n                }\r\n            },\r\n            setReaders: function(readers) {\r\n                config.readers = readers;\r\n                _barcodeReaders.length = 0;\r\n                initReaders();\r\n            }\r\n        };\r\n    }\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/decoder/barcode_decoder.js","import ImageWrapper from '../common/image_wrapper';\r\n\r\nvar Bresenham = {};\r\n\r\nvar Slope = {\r\n    DIR: {\r\n        UP: 1,\r\n        DOWN: -1\r\n    }\r\n};\r\n/**\r\n * Scans a line of the given image from point p1 to p2 and returns a result object containing\r\n * gray-scale values (0-255) of the underlying pixels in addition to the min\r\n * and max values.\r\n * @param {Object} imageWrapper\r\n * @param {Object} p1 The start point {x,y}\r\n * @param {Object} p2 The end point {x,y}\r\n * @returns {line, min, max}\r\n */\r\nBresenham.getBarcodeLine = function(imageWrapper, p1, p2) {\r\n    var x0 = p1.x | 0,\r\n        y0 = p1.y | 0,\r\n        x1 = p2.x | 0,\r\n        y1 = p2.y | 0,\r\n        steep = Math.abs(y1 - y0) > Math.abs(x1 - x0),\r\n        deltax,\r\n        deltay,\r\n        error,\r\n        ystep,\r\n        y,\r\n        tmp,\r\n        x,\r\n        line = [],\r\n        imageData = imageWrapper.data,\r\n        width = imageWrapper.size.x,\r\n        sum = 0,\r\n        val,\r\n        min = 255,\r\n        max = 0;\r\n\r\n    function read(a, b) {\r\n        val = imageData[b * width + a];\r\n        sum += val;\r\n        min = val < min ? val : min;\r\n        max = val > max ? val : max;\r\n        line.push(val);\r\n    }\r\n\r\n    if (steep) {\r\n        tmp = x0;\r\n        x0 = y0;\r\n        y0 = tmp;\r\n\r\n        tmp = x1;\r\n        x1 = y1;\r\n        y1 = tmp;\r\n    }\r\n    if (x0 > x1) {\r\n        tmp = x0;\r\n        x0 = x1;\r\n        x1 = tmp;\r\n\r\n        tmp = y0;\r\n        y0 = y1;\r\n        y1 = tmp;\r\n    }\r\n    deltax = x1 - x0;\r\n    deltay = Math.abs(y1 - y0);\r\n    error = (deltax / 2) | 0;\r\n    y = y0;\r\n    ystep = y0 < y1 ? 1 : -1;\r\n    for ( x = x0; x < x1; x++) {\r\n        if (steep){\r\n            read(y, x);\r\n        } else {\r\n            read(x, y);\r\n        }\r\n        error = error - deltay;\r\n        if (error < 0) {\r\n            y = y + ystep;\r\n            error = error + deltax;\r\n        }\r\n    }\r\n\r\n    return {\r\n        line: line,\r\n        min: min,\r\n        max: max\r\n    };\r\n};\r\n\r\n/**\r\n * Converts the result from getBarcodeLine into a binary representation\r\n * also considering the frequency and slope of the signal for more robust results\r\n * @param {Object} result {line, min, max}\r\n */\r\nBresenham.toBinaryLine = function(result) {\r\n    var min = result.min,\r\n        max = result.max,\r\n        line = result.line,\r\n        slope,\r\n        slope2,\r\n        center = min + (max - min) / 2,\r\n        extrema = [],\r\n        currentDir,\r\n        dir,\r\n        threshold = (max - min) / 12,\r\n        rThreshold = -threshold,\r\n        i,\r\n        j;\r\n\r\n    // 1. find extrema\r\n    currentDir = line[0] > center ? Slope.DIR.UP : Slope.DIR.DOWN;\r\n    extrema.push({\r\n        pos: 0,\r\n        val: line[0]\r\n    });\r\n    for ( i = 0; i < line.length - 2; i++) {\r\n        slope = (line[i + 1] - line[i]);\r\n        slope2 = (line[i + 2] - line[i + 1]);\r\n        if ((slope + slope2) < rThreshold && line[i + 1] < (center * 1.5)) {\r\n            dir = Slope.DIR.DOWN;\r\n        } else if ((slope + slope2) > threshold && line[i + 1] > (center * 0.5)) {\r\n            dir = Slope.DIR.UP;\r\n        } else {\r\n            dir = currentDir;\r\n        }\r\n\r\n        if (currentDir !== dir) {\r\n            extrema.push({\r\n                pos: i,\r\n                val: line[i]\r\n            });\r\n            currentDir = dir;\r\n        }\r\n    }\r\n    extrema.push({\r\n        pos: line.length,\r\n        val: line[line.length - 1]\r\n    });\r\n\r\n    for ( j = extrema[0].pos; j < extrema[1].pos; j++) {\r\n        line[j] = line[j] > center ? 0 : 1;\r\n    }\r\n\r\n    // iterate over extrema and convert to binary based on avg between minmax\r\n    for ( i = 1; i < extrema.length - 1; i++) {\r\n        if (extrema[i + 1].val > extrema[i].val) {\r\n            threshold = (extrema[i].val + ((extrema[i + 1].val - extrema[i].val) / 3) * 2) | 0;\r\n        } else {\r\n            threshold = (extrema[i + 1].val + ((extrema[i].val - extrema[i + 1].val) / 3)) | 0;\r\n        }\r\n\r\n        for ( j = extrema[i].pos; j < extrema[i + 1].pos; j++) {\r\n            line[j] = line[j] > threshold ? 0 : 1;\r\n        }\r\n    }\r\n\r\n    return {\r\n        line: line,\r\n        threshold: threshold\r\n    };\r\n};\r\n\r\n/**\r\n * Used for development only\r\n */\r\nBresenham.debug = {\r\n    printFrequency: function(line, canvas) {\r\n        var i,\r\n            ctx = canvas.getContext(\"2d\");\r\n        canvas.width = line.length;\r\n        canvas.height = 256;\r\n\r\n        ctx.beginPath();\r\n        ctx.strokeStyle = \"blue\";\r\n        for ( i = 0; i < line.length; i++) {\r\n            ctx.moveTo(i, 255);\r\n            ctx.lineTo(i, 255 - line[i]);\r\n        }\r\n        ctx.stroke();\r\n        ctx.closePath();\r\n    },\r\n\r\n    printPattern: function(line, canvas) {\r\n        var ctx = canvas.getContext(\"2d\"), i;\r\n\r\n        canvas.width = line.length;\r\n        ctx.fillColor = \"black\";\r\n        for ( i = 0; i < line.length; i++) {\r\n            if (line[i] === 1) {\r\n                ctx.fillRect(i, 0, 1, 100);\r\n            }\r\n        }\r\n    }\r\n};\r\n\r\nexport default Bresenham;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/decoder/bresenham.js","import {omit, pick} from 'lodash';\r\nimport {getUserMedia, enumerateDevices} from 'mediaDevices';\r\n\r\nconst facingMatching = {\r\n    \"user\": /front/i,\r\n    \"environment\": /back/i\r\n};\r\n\r\nvar streamRef;\r\n\r\nfunction waitForVideo(video) {\r\n    return new Promise((resolve, reject) => {\r\n        let attempts = 10;\r\n\r\n        function checkVideo() {\r\n            if (attempts > 0) {\r\n                if (video.videoWidth > 10 && video.videoHeight > 10) {\r\n                    if (ENV.development) {\r\n                        console.log(video.videoWidth + \"px x \" + video.videoHeight + \"px\");\r\n                    }\r\n                    resolve();\r\n                } else {\r\n                    window.setTimeout(checkVideo, 500);\r\n                }\r\n            } else {\r\n                reject('Unable to play video stream. Is webcam working?');\r\n            }\r\n            attempts--;\r\n        }\r\n        checkVideo();\r\n    });\r\n}\r\n\r\n/**\r\n * Tries to attach the camera-stream to a given video-element\r\n * and calls the callback function when the content is ready\r\n * @param {Object} constraints\r\n * @param {Object} video\r\n */\r\nfunction initCamera(video, constraints) {\r\n    return getUserMedia(constraints)\r\n    .then((stream) => {\r\n        return new Promise((resolve) => {\r\n            streamRef = stream;\r\n            video.setAttribute(\"autoplay\", true);\r\n            video.setAttribute('muted', true);\r\n            video.setAttribute('playsinline', true);\r\n            video.srcObject = stream;\r\n            video.addEventListener('loadedmetadata', () => {\r\n                video.play();\r\n                resolve();\r\n            });\r\n        });\r\n    })\r\n    .then(waitForVideo.bind(null, video));\r\n}\r\n\r\nfunction deprecatedConstraints(videoConstraints) {\r\n    const normalized = pick(videoConstraints, [\"width\", \"height\", \"facingMode\",\r\n            \"aspectRatio\", \"deviceId\"]);\r\n\r\n    if (typeof videoConstraints.minAspectRatio !== 'undefined' &&\r\n            videoConstraints.minAspectRatio > 0) {\r\n        normalized.aspectRatio = videoConstraints.minAspectRatio;\r\n        console.log(\"WARNING: Constraint 'minAspectRatio' is deprecated; Use 'aspectRatio' instead\");\r\n    }\r\n    if (typeof videoConstraints.facing !== 'undefined') {\r\n        normalized.facingMode = videoConstraints.facing;\r\n        console.log(\"WARNING: Constraint 'facing' is deprecated. Use 'facingMode' instead'\");\r\n    }\r\n    return normalized;\r\n}\r\n\r\nexport function pickConstraints(videoConstraints) {\r\n    const normalizedConstraints = {\r\n        audio: false,\r\n        video: deprecatedConstraints(videoConstraints)\r\n    };\r\n\r\n    if (normalizedConstraints.video.deviceId\r\n            && normalizedConstraints.video.facingMode) {\r\n        delete normalizedConstraints.video.facingMode;\r\n    }\r\n    return Promise.resolve(normalizedConstraints);\r\n}\r\n\r\nfunction enumerateVideoDevices() {\r\n    return enumerateDevices()\r\n    .then(devices => devices.filter(device => device.kind === 'videoinput'));\r\n}\r\n\r\nfunction getActiveTrack() {\r\n    if (streamRef) {\r\n        const tracks = streamRef.getVideoTracks();\r\n        if (tracks && tracks.length) {\r\n            return tracks[0];\r\n        }\r\n    }\r\n}\r\n\r\nexport default {\r\n    request: function(video, videoConstraints) {\r\n        return pickConstraints(videoConstraints)\r\n            .then(initCamera.bind(null, video));\r\n    },\r\n    release: function() {\r\n        var tracks = streamRef && streamRef.getVideoTracks();\r\n        if (tracks && tracks.length) {\r\n            tracks[0].stop();\r\n        }\r\n        streamRef = null;\r\n    },\r\n    enumerateVideoDevices,\r\n    getActiveStreamLabel: function() {\r\n        const track = getActiveTrack();\r\n        return track ? track.label : '';\r\n    },\r\n    getActiveTrack\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/input/camera_access.js","import ImageWrapper from '../common/image_wrapper';\r\nimport {\r\n    calculatePatchSize,\r\n    otsuThreshold,\r\n    hsv2rgb,\r\n    cluster,\r\n    topGeneric,\r\n    imageRef,\r\n    halfSample,\r\n    computeImageArea\r\n} from '../common/cv_utils';\r\nimport ArrayHelper from '../common/array_helper';\r\nimport ImageDebug from '../common/image_debug';\r\nimport Rasterizer from './rasterizer';\r\nimport Tracer from './tracer';\r\nimport skeletonizer from './skeletonizer';\r\nconst vec2 = {\r\n    clone: require('gl-vec2/clone'),\r\n    dot:  require('gl-vec2/dot'),\r\n    scale: require('gl-vec2/scale'),\r\n    transformMat2: require('gl-vec2/transformMat2')\r\n};\r\nconst mat2 = {\r\n    copy: require('gl-mat2/copy'),\r\n    create: require('gl-mat2/create'),\r\n    invert: require('gl-mat2/invert')\r\n}\r\n\r\nvar _config,\r\n    _currentImageWrapper,\r\n    _skelImageWrapper,\r\n    _subImageWrapper,\r\n    _labelImageWrapper,\r\n    _patchGrid,\r\n    _patchLabelGrid,\r\n    _imageToPatchGrid,\r\n    _binaryImageWrapper,\r\n    _patchSize,\r\n    _canvasContainer = {\r\n        ctx: {\r\n            binary: null\r\n        },\r\n        dom: {\r\n            binary: null\r\n        }\r\n    },\r\n    _numPatches = {x: 0, y: 0},\r\n    _inputImageWrapper,\r\n    _skeletonizer;\r\n\r\nfunction initBuffers() {\r\n    var skeletonImageData;\r\n\r\n    if (_config.halfSample) {\r\n        _currentImageWrapper = new ImageWrapper({\r\n            x: _inputImageWrapper.size.x / 2 | 0,\r\n            y: _inputImageWrapper.size.y / 2 | 0\r\n        });\r\n    } else {\r\n        _currentImageWrapper = _inputImageWrapper;\r\n    }\r\n\r\n    _patchSize = calculatePatchSize(_config.patchSize, _currentImageWrapper.size);\r\n\r\n    _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0;\r\n    _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0;\r\n\r\n    _binaryImageWrapper = new ImageWrapper(_currentImageWrapper.size, undefined, Uint8Array, false);\r\n\r\n    _labelImageWrapper = new ImageWrapper(_patchSize, undefined, Array, true);\r\n\r\n    skeletonImageData = new ArrayBuffer(64 * 1024);\r\n    _subImageWrapper = new ImageWrapper(_patchSize,\r\n        new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y));\r\n    _skelImageWrapper = new ImageWrapper(_patchSize,\r\n        new Uint8Array(skeletonImageData, _patchSize.x * _patchSize.y * 3, _patchSize.x * _patchSize.y),\r\n        undefined, true);\r\n    _skeletonizer = skeletonizer((typeof window !== 'undefined') ? window : (typeof self !== 'undefined') ? self : global, {\r\n        size: _patchSize.x\r\n    }, skeletonImageData);\r\n\r\n    _imageToPatchGrid = new ImageWrapper({\r\n        x: (_currentImageWrapper.size.x / _subImageWrapper.size.x) | 0,\r\n        y: (_currentImageWrapper.size.y / _subImageWrapper.size.y) | 0\r\n    }, undefined, Array, true);\r\n    _patchGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, undefined, true);\r\n    _patchLabelGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, Int32Array, true);\r\n}\r\n\r\nfunction initCanvas() {\r\n    if (_config.useWorker || typeof document === 'undefined') {\r\n        return;\r\n    }\r\n    _canvasContainer.dom.binary = document.createElement(\"canvas\");\r\n    _canvasContainer.dom.binary.className = \"binaryBuffer\";\r\n    if (ENV.development && _config.debug.showCanvas === true) {\r\n        document.querySelector(\"#debug\").appendChild(_canvasContainer.dom.binary);\r\n    }\r\n    _canvasContainer.ctx.binary = _canvasContainer.dom.binary.getContext(\"2d\");\r\n    _canvasContainer.dom.binary.width = _binaryImageWrapper.size.x;\r\n    _canvasContainer.dom.binary.height = _binaryImageWrapper.size.y;\r\n}\r\n\r\n/**\r\n * Creates a bounding box which encloses all the given patches\r\n * @returns {Array} The minimal bounding box\r\n */\r\nfunction boxFromPatches(patches) {\r\n    var overAvg,\r\n        i,\r\n        j,\r\n        patch,\r\n        transMat,\r\n        minx =\r\n        _binaryImageWrapper.size.x,\r\n        miny = _binaryImageWrapper.size.y,\r\n        maxx = -_binaryImageWrapper.size.x,\r\n        maxy = -_binaryImageWrapper.size.y,\r\n        box,\r\n        scale;\r\n\r\n    // draw all patches which are to be taken into consideration\r\n    overAvg = 0;\r\n    for ( i = 0; i < patches.length; i++) {\r\n        patch = patches[i];\r\n        overAvg += patch.rad;\r\n        if (ENV.development && _config.debug.showPatches) {\r\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, {color: \"red\"});\r\n        }\r\n    }\r\n\r\n    overAvg /= patches.length;\r\n    overAvg = (overAvg * 180 / Math.PI + 90) % 180 - 90;\r\n    if (overAvg < 0) {\r\n        overAvg += 180;\r\n    }\r\n\r\n    overAvg = (180 - overAvg) * Math.PI / 180;\r\n    transMat = mat2.copy(mat2.create(), [Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]);\r\n\r\n    // iterate over patches and rotate by angle\r\n    for ( i = 0; i < patches.length; i++) {\r\n        patch = patches[i];\r\n        for ( j = 0; j < 4; j++) {\r\n            vec2.transformMat2(patch.box[j], patch.box[j], transMat);\r\n        }\r\n\r\n        if (ENV.development && _config.debug.boxFromPatches.showTransformed) {\r\n            ImageDebug.drawPath(patch.box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#99ff00', lineWidth: 2});\r\n        }\r\n    }\r\n\r\n    // find bounding box\r\n    for ( i = 0; i < patches.length; i++) {\r\n        patch = patches[i];\r\n        for ( j = 0; j < 4; j++) {\r\n            if (patch.box[j][0] < minx) {\r\n                minx = patch.box[j][0];\r\n            }\r\n            if (patch.box[j][0] > maxx) {\r\n                maxx = patch.box[j][0];\r\n            }\r\n            if (patch.box[j][1] < miny) {\r\n                miny = patch.box[j][1];\r\n            }\r\n            if (patch.box[j][1] > maxy) {\r\n                maxy = patch.box[j][1];\r\n            }\r\n        }\r\n    }\r\n\r\n    box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]];\r\n\r\n    if (ENV.development && _config.debug.boxFromPatches.showTransformedBox) {\r\n        ImageDebug.drawPath(box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#ff0000', lineWidth: 2});\r\n    }\r\n\r\n    scale = _config.halfSample ? 2 : 1;\r\n    // reverse rotation;\r\n    transMat = mat2.invert(transMat, transMat);\r\n    for ( j = 0; j < 4; j++) {\r\n        vec2.transformMat2(box[j], box[j], transMat);\r\n    }\r\n\r\n    if (ENV.development && _config.debug.boxFromPatches.showBB) {\r\n        ImageDebug.drawPath(box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#ff0000', lineWidth: 2});\r\n    }\r\n\r\n    for ( j = 0; j < 4; j++) {\r\n        vec2.scale(box[j], box[j], scale);\r\n    }\r\n\r\n    return box;\r\n}\r\n\r\n/**\r\n * Creates a binary image of the current image\r\n */\r\nfunction binarizeImage() {\r\n    otsuThreshold(_currentImageWrapper, _binaryImageWrapper);\r\n    _binaryImageWrapper.zeroBorder();\r\n    if (ENV.development && _config.debug.showCanvas) {\r\n        _binaryImageWrapper.show(_canvasContainer.dom.binary, 255);\r\n    }\r\n}\r\n\r\n/**\r\n * Iterate over the entire image\r\n * extract patches\r\n */\r\nfunction findPatches() {\r\n    var i,\r\n        j,\r\n        x,\r\n        y,\r\n        moments,\r\n        patchesFound = [],\r\n        rasterizer,\r\n        rasterResult,\r\n        patch;\r\n    for (i = 0; i < _numPatches.x; i++) {\r\n        for (j = 0; j < _numPatches.y; j++) {\r\n            x = _subImageWrapper.size.x * i;\r\n            y = _subImageWrapper.size.y * j;\r\n\r\n            // seperate parts\r\n            skeletonize(x, y);\r\n\r\n            // Rasterize, find individual bars\r\n            _skelImageWrapper.zeroBorder();\r\n            ArrayHelper.init(_labelImageWrapper.data, 0);\r\n            rasterizer = Rasterizer.create(_skelImageWrapper, _labelImageWrapper);\r\n            rasterResult = rasterizer.rasterize(0);\r\n\r\n            if (ENV.development && _config.debug.showLabels) {\r\n                _labelImageWrapper.overlay(_canvasContainer.dom.binary, Math.floor(360 / rasterResult.count),\r\n                    {x: x, y: y});\r\n            }\r\n\r\n            // calculate moments from the skeletonized patch\r\n            moments = _labelImageWrapper.moments(rasterResult.count);\r\n\r\n            // extract eligible patches\r\n            patchesFound = patchesFound.concat(describePatch(moments, [i, j], x, y));\r\n        }\r\n    }\r\n\r\n    if (ENV.development && _config.debug.showFoundPatches) {\r\n        for ( i = 0; i < patchesFound.length; i++) {\r\n            patch = patchesFound[i];\r\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\r\n                {color: \"#99ff00\", lineWidth: 2});\r\n        }\r\n    }\r\n\r\n    return patchesFound;\r\n}\r\n\r\n/**\r\n * Finds those connected areas which contain at least 6 patches\r\n * and returns them ordered DESC by the number of contained patches\r\n * @param {Number} maxLabel\r\n */\r\nfunction findBiggestConnectedAreas(maxLabel){\r\n    var i,\r\n        sum,\r\n        labelHist = [],\r\n        topLabels = [];\r\n\r\n    for ( i = 0; i < maxLabel; i++) {\r\n        labelHist.push(0);\r\n    }\r\n    sum = _patchLabelGrid.data.length;\r\n    while (sum--) {\r\n        if (_patchLabelGrid.data[sum] > 0) {\r\n            labelHist[_patchLabelGrid.data[sum] - 1]++;\r\n        }\r\n    }\r\n\r\n    labelHist = labelHist.map(function(val, idx) {\r\n        return {\r\n            val: val,\r\n            label: idx + 1\r\n        };\r\n    });\r\n\r\n    labelHist.sort(function(a, b) {\r\n        return b.val - a.val;\r\n    });\r\n\r\n    // extract top areas with at least 6 patches present\r\n    topLabels = labelHist.filter(function(el) {\r\n        return el.val >= 5;\r\n    });\r\n\r\n    return topLabels;\r\n}\r\n\r\n/**\r\n *\r\n */\r\nfunction findBoxes(topLabels, maxLabel) {\r\n    var i,\r\n        j,\r\n        sum,\r\n        patches = [],\r\n        patch,\r\n        box,\r\n        boxes = [],\r\n        hsv = [0, 1, 1],\r\n        rgb = [0, 0, 0];\r\n\r\n    for ( i = 0; i < topLabels.length; i++) {\r\n        sum = _patchLabelGrid.data.length;\r\n        patches.length = 0;\r\n        while (sum--) {\r\n            if (_patchLabelGrid.data[sum] === topLabels[i].label) {\r\n                patch = _imageToPatchGrid.data[sum];\r\n                patches.push(patch);\r\n            }\r\n        }\r\n        box = boxFromPatches(patches);\r\n        if (box) {\r\n            boxes.push(box);\r\n\r\n            // draw patch-labels if requested\r\n            if (ENV.development && _config.debug.showRemainingPatchLabels) {\r\n                for ( j = 0; j < patches.length; j++) {\r\n                    patch = patches[j];\r\n                    hsv[0] = (topLabels[i].label / (maxLabel + 1)) * 360;\r\n                    hsv2rgb(hsv, rgb);\r\n                    ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\r\n                        {color: \"rgb(\" + rgb.join(\",\") + \")\", lineWidth: 2});\r\n                }\r\n            }\r\n        }\r\n    }\r\n    return boxes;\r\n}\r\n\r\n/**\r\n * Find similar moments (via cluster)\r\n * @param {Object} moments\r\n */\r\nfunction similarMoments(moments) {\r\n    var clusters = cluster(moments, 0.90);\r\n    var topCluster = topGeneric(clusters, 1, function(e) {\r\n        return e.getPoints().length;\r\n    });\r\n    var points = [], result = [];\r\n    if (topCluster.length === 1) {\r\n        points = topCluster[0].item.getPoints();\r\n        for (var i = 0; i < points.length; i++) {\r\n            result.push(points[i].point);\r\n        }\r\n    }\r\n    return result;\r\n}\r\n\r\nfunction skeletonize(x, y) {\r\n    _binaryImageWrapper.subImageAsCopy(_subImageWrapper, imageRef(x, y));\r\n    _skeletonizer.skeletonize();\r\n\r\n    // Show skeleton if requested\r\n    if (ENV.development && _config.debug.showSkeleton) {\r\n        _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, imageRef(x, y));\r\n    }\r\n}\r\n\r\n/**\r\n * Extracts and describes those patches which seem to contain a barcode pattern\r\n * @param {Array} moments\r\n * @param {Object} patchPos,\r\n * @param {Number} x\r\n * @param {Number} y\r\n * @returns {Array} list of patches\r\n */\r\nfunction describePatch(moments, patchPos, x, y) {\r\n    var k,\r\n        avg,\r\n        eligibleMoments = [],\r\n        matchingMoments,\r\n        patch,\r\n        patchesFound = [],\r\n        minComponentWeight = Math.ceil(_patchSize.x / 3);\r\n\r\n    if (moments.length >= 2) {\r\n        // only collect moments which's area covers at least minComponentWeight pixels.\r\n        for ( k = 0; k < moments.length; k++) {\r\n            if (moments[k].m00 > minComponentWeight) {\r\n                eligibleMoments.push(moments[k]);\r\n            }\r\n        }\r\n\r\n        // if at least 2 moments are found which have at least minComponentWeights covered\r\n        if (eligibleMoments.length >= 2) {\r\n            matchingMoments = similarMoments(eligibleMoments);\r\n            avg = 0;\r\n            // determine the similarity of the moments\r\n            for ( k = 0; k < matchingMoments.length; k++) {\r\n                avg += matchingMoments[k].rad;\r\n            }\r\n\r\n            // Only two of the moments are allowed not to fit into the equation\r\n            // add the patch to the set\r\n            if (matchingMoments.length > 1\r\n                    && matchingMoments.length >= (eligibleMoments.length / 4) * 3\r\n                    && matchingMoments.length > moments.length / 4) {\r\n                avg /= matchingMoments.length;\r\n                patch = {\r\n                    index: patchPos[1] * _numPatches.x + patchPos[0],\r\n                    pos: {\r\n                        x: x,\r\n                        y: y\r\n                    },\r\n                    box: [\r\n                        vec2.clone([x, y]),\r\n                        vec2.clone([x + _subImageWrapper.size.x, y]),\r\n                        vec2.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]),\r\n                        vec2.clone([x, y + _subImageWrapper.size.y])\r\n                    ],\r\n                    moments: matchingMoments,\r\n                    rad: avg,\r\n                    vec: vec2.clone([Math.cos(avg), Math.sin(avg)])\r\n                };\r\n                patchesFound.push(patch);\r\n            }\r\n        }\r\n    }\r\n    return patchesFound;\r\n}\r\n\r\n/**\r\n * finds patches which are connected and share the same orientation\r\n * @param {Object} patchesFound\r\n */\r\nfunction rasterizeAngularSimilarity(patchesFound) {\r\n    var label = 0,\r\n        threshold = 0.95,\r\n        currIdx = 0,\r\n        j,\r\n        patch,\r\n        hsv = [0, 1, 1],\r\n        rgb = [0, 0, 0];\r\n\r\n    function notYetProcessed() {\r\n        var i;\r\n        for ( i = 0; i < _patchLabelGrid.data.length; i++) {\r\n            if (_patchLabelGrid.data[i] === 0 && _patchGrid.data[i] === 1) {\r\n                return i;\r\n            }\r\n        }\r\n        return _patchLabelGrid.length;\r\n    }\r\n\r\n    function trace(currentIdx) {\r\n        var x,\r\n            y,\r\n            currentPatch,\r\n            idx,\r\n            dir,\r\n            current = {\r\n                x: currentIdx % _patchLabelGrid.size.x,\r\n                y: (currentIdx / _patchLabelGrid.size.x) | 0\r\n            },\r\n            similarity;\r\n\r\n        if (currentIdx < _patchLabelGrid.data.length) {\r\n            currentPatch = _imageToPatchGrid.data[currentIdx];\r\n            // assign label\r\n            _patchLabelGrid.data[currentIdx] = label;\r\n            for ( dir = 0; dir < Tracer.searchDirections.length; dir++) {\r\n                y = current.y + Tracer.searchDirections[dir][0];\r\n                x = current.x + Tracer.searchDirections[dir][1];\r\n                idx = y * _patchLabelGrid.size.x + x;\r\n\r\n                // continue if patch empty\r\n                if (_patchGrid.data[idx] === 0) {\r\n                    _patchLabelGrid.data[idx] = Number.MAX_VALUE;\r\n                    continue;\r\n                }\r\n\r\n                if (_patchLabelGrid.data[idx] === 0) {\r\n                    similarity = Math.abs(vec2.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec));\r\n                    if (similarity > threshold) {\r\n                        trace(idx);\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    // prepare for finding the right patches\r\n    ArrayHelper.init(_patchGrid.data, 0);\r\n    ArrayHelper.init(_patchLabelGrid.data, 0);\r\n    ArrayHelper.init(_imageToPatchGrid.data, null);\r\n\r\n    for ( j = 0; j < patchesFound.length; j++) {\r\n        patch = patchesFound[j];\r\n        _imageToPatchGrid.data[patch.index] = patch;\r\n        _patchGrid.data[patch.index] = 1;\r\n    }\r\n\r\n    // rasterize the patches found to determine area\r\n    _patchGrid.zeroBorder();\r\n\r\n    while (( currIdx = notYetProcessed()) < _patchLabelGrid.data.length) {\r\n        label++;\r\n        trace(currIdx);\r\n    }\r\n\r\n    // draw patch-labels if requested\r\n    if (ENV.development && _config.debug.showPatchLabels) {\r\n        for ( j = 0; j < _patchLabelGrid.data.length; j++) {\r\n            if (_patchLabelGrid.data[j] > 0 && _patchLabelGrid.data[j] <= label) {\r\n                patch = _imageToPatchGrid.data[j];\r\n                hsv[0] = (_patchLabelGrid.data[j] / (label + 1)) * 360;\r\n                hsv2rgb(hsv, rgb);\r\n                ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\r\n                    {color: \"rgb(\" + rgb.join(\",\") + \")\", lineWidth: 2});\r\n            }\r\n        }\r\n    }\r\n\r\n    return label;\r\n}\r\n\r\nexport default {\r\n    init: function(inputImageWrapper, config) {\r\n        _config = config;\r\n        _inputImageWrapper = inputImageWrapper;\r\n\r\n        initBuffers();\r\n        initCanvas();\r\n    },\r\n\r\n    locate: function() {\r\n        var patchesFound,\r\n            topLabels,\r\n            boxes;\r\n\r\n        if (_config.halfSample) {\r\n            halfSample(_inputImageWrapper, _currentImageWrapper);\r\n        }\r\n\r\n        binarizeImage();\r\n        patchesFound = findPatches();\r\n        // return unless 5% or more patches are found\r\n        if (patchesFound.length < _numPatches.x * _numPatches.y * 0.05) {\r\n            return null;\r\n        }\r\n\r\n        // rasterrize area by comparing angular similarity;\r\n        var maxLabel = rasterizeAngularSimilarity(patchesFound);\r\n        if (maxLabel < 1) {\r\n            return null;\r\n        }\r\n\r\n        // search for area with the most patches (biggest connected area)\r\n        topLabels = findBiggestConnectedAreas(maxLabel);\r\n        if (topLabels.length === 0) {\r\n            return null;\r\n        }\r\n\r\n        boxes = findBoxes(topLabels, maxLabel);\r\n        return boxes;\r\n    },\r\n\r\n    checkImageConstraints: function(inputStream, config) {\r\n        var patchSize,\r\n            width = inputStream.getWidth(),\r\n            height = inputStream.getHeight(),\r\n            halfSample = config.halfSample ? 0.5 : 1,\r\n            size,\r\n            area;\r\n\r\n        // calculate width and height based on area\r\n        if (inputStream.getConfig().area) {\r\n            area = computeImageArea(width, height, inputStream.getConfig().area);\r\n            inputStream.setTopRight({x: area.sx, y: area.sy});\r\n            inputStream.setCanvasSize({x: width, y: height});\r\n            width = area.sw;\r\n            height = area.sh;\r\n        }\r\n\r\n        size = {\r\n            x: Math.floor(width * halfSample),\r\n            y: Math.floor(height * halfSample)\r\n        };\r\n\r\n        patchSize = calculatePatchSize(config.patchSize, size);\r\n        if (ENV.development) {\r\n            console.log(\"Patch-Size: \" + JSON.stringify(patchSize));\r\n        }\r\n\r\n        inputStream.setWidth(Math.floor(Math.floor(size.x / patchSize.x) * (1 / halfSample) * patchSize.x));\r\n        inputStream.setHeight(Math.floor(Math.floor(size.y / patchSize.y) * (1 / halfSample) * patchSize.y));\r\n\r\n        if ((inputStream.getWidth() % patchSize.x) === 0 && (inputStream.getHeight() % patchSize.y) === 0) {\r\n            return true;\r\n        }\r\n\r\n        throw new Error(\"Image dimensions do not comply with the current settings: Width (\" +\r\n            width + \" )and height (\" + height +\r\n            \") must a multiple of \" + patchSize.x);\r\n    }\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/barcode_locator.js","import Tracer from './tracer';\r\n\r\n/**\r\n * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\r\n */\r\nvar Rasterizer = {\r\n    createContour2D: function() {\r\n        return {\r\n            dir: null,\r\n            index: null,\r\n            firstVertex: null,\r\n            insideContours: null,\r\n            nextpeer: null,\r\n            prevpeer: null\r\n        };\r\n    },\r\n    CONTOUR_DIR: {\r\n        CW_DIR: 0,\r\n        CCW_DIR: 1,\r\n        UNKNOWN_DIR: 2\r\n    },\r\n    DIR: {\r\n        OUTSIDE_EDGE: -32767,\r\n        INSIDE_EDGE: -32766\r\n    },\r\n    create: function(imageWrapper, labelWrapper) {\r\n        var imageData = imageWrapper.data,\r\n            labelData = labelWrapper.data,\r\n            width = imageWrapper.size.x,\r\n            height = imageWrapper.size.y,\r\n            tracer = Tracer.create(imageWrapper, labelWrapper);\r\n\r\n        return {\r\n            rasterize: function(depthlabel) {\r\n                var color,\r\n                    bc,\r\n                    lc,\r\n                    labelindex,\r\n                    cx,\r\n                    cy,\r\n                    colorMap = [],\r\n                    vertex,\r\n                    p,\r\n                    cc,\r\n                    sc,\r\n                    pos,\r\n                    connectedCount = 0,\r\n                    i;\r\n\r\n                for ( i = 0; i < 400; i++) {\r\n                    colorMap[i] = 0;\r\n                }\r\n\r\n                colorMap[0] = imageData[0];\r\n                cc = null;\r\n                for ( cy = 1; cy < height - 1; cy++) {\r\n                    labelindex = 0;\r\n                    bc = colorMap[0];\r\n                    for ( cx = 1; cx < width - 1; cx++) {\r\n                        pos = cy * width + cx;\r\n                        if (labelData[pos] === 0) {\r\n                            color = imageData[pos];\r\n                            if (color !== bc) {\r\n                                if (labelindex === 0) {\r\n                                    lc = connectedCount + 1;\r\n                                    colorMap[lc] = color;\r\n                                    bc = color;\r\n                                    vertex = tracer.contourTracing(cy, cx, lc, color, Rasterizer.DIR.OUTSIDE_EDGE);\r\n                                    if (vertex !== null) {\r\n                                        connectedCount++;\r\n                                        labelindex = lc;\r\n                                        p = Rasterizer.createContour2D();\r\n                                        p.dir = Rasterizer.CONTOUR_DIR.CW_DIR;\r\n                                        p.index = labelindex;\r\n                                        p.firstVertex = vertex;\r\n                                        p.nextpeer = cc;\r\n                                        p.insideContours = null;\r\n                                        if (cc !== null) {\r\n                                            cc.prevpeer = p;\r\n                                        }\r\n                                        cc = p;\r\n                                    }\r\n                                } else {\r\n                                    vertex = tracer\r\n                                        .contourTracing(cy, cx, Rasterizer.DIR.INSIDE_EDGE, color, labelindex);\r\n                                    if (vertex !== null) {\r\n                                        p = Rasterizer.createContour2D();\r\n                                        p.firstVertex = vertex;\r\n                                        p.insideContours = null;\r\n                                        if (depthlabel === 0) {\r\n                                            p.dir = Rasterizer.CONTOUR_DIR.CCW_DIR;\r\n                                        } else {\r\n                                            p.dir = Rasterizer.CONTOUR_DIR.CW_DIR;\r\n                                        }\r\n                                        p.index = depthlabel;\r\n                                        sc = cc;\r\n                                        while ((sc !== null) && sc.index !== labelindex) {\r\n                                            sc = sc.nextpeer;\r\n                                        }\r\n                                        if (sc !== null) {\r\n                                            p.nextpeer = sc.insideContours;\r\n                                            if (sc.insideContours !== null) {\r\n                                                sc.insideContours.prevpeer = p;\r\n                                            }\r\n                                            sc.insideContours = p;\r\n                                        }\r\n                                    }\r\n                                }\r\n                            } else {\r\n                                labelData[pos] = labelindex;\r\n                            }\r\n                        } else if (labelData[pos] === Rasterizer.DIR.OUTSIDE_EDGE\r\n                                || labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) {\r\n                            labelindex = 0;\r\n                            if (labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) {\r\n                                bc = imageData[pos];\r\n                            } else {\r\n                                bc = colorMap[0];\r\n                            }\r\n                        } else {\r\n                            labelindex = labelData[pos];\r\n                            bc = colorMap[labelindex];\r\n                        }\r\n                    }\r\n                }\r\n                sc = cc;\r\n                while (sc !== null) {\r\n                    sc.index = depthlabel;\r\n                    sc = sc.nextpeer;\r\n                }\r\n                return {\r\n                    cc: cc,\r\n                    count: connectedCount\r\n                };\r\n            },\r\n            debug: {\r\n                drawContour: function(canvas, firstContour) {\r\n                    var ctx = canvas.getContext(\"2d\"),\r\n                        pq = firstContour,\r\n                        iq,\r\n                        q,\r\n                        p;\r\n\r\n                    ctx.strokeStyle = \"red\";\r\n                    ctx.fillStyle = \"red\";\r\n                    ctx.lineWidth = 1;\r\n\r\n                    if (pq !== null) {\r\n                        iq = pq.insideContours;\r\n                    } else {\r\n                        iq = null;\r\n                    }\r\n\r\n                    while (pq !== null) {\r\n                        if (iq !== null) {\r\n                            q = iq;\r\n                            iq = iq.nextpeer;\r\n                        } else {\r\n                            q = pq;\r\n                            pq = pq.nextpeer;\r\n                            if (pq !== null) {\r\n                                iq = pq.insideContours;\r\n                            } else {\r\n                                iq = null;\r\n                            }\r\n                        }\r\n\r\n                        switch (q.dir) {\r\n                        case Rasterizer.CONTOUR_DIR.CW_DIR:\r\n                            ctx.strokeStyle = \"red\";\r\n                            break;\r\n                        case Rasterizer.CONTOUR_DIR.CCW_DIR:\r\n                            ctx.strokeStyle = \"blue\";\r\n                            break;\r\n                        case Rasterizer.CONTOUR_DIR.UNKNOWN_DIR:\r\n                            ctx.strokeStyle = \"green\";\r\n                            break;\r\n                        }\r\n\r\n                        p = q.firstVertex;\r\n                        ctx.beginPath();\r\n                        ctx.moveTo(p.x, p.y);\r\n                        do {\r\n                            p = p.next;\r\n                            ctx.lineTo(p.x, p.y);\r\n                        } while (p !== q.firstVertex);\r\n                        ctx.stroke();\r\n                    }\r\n                }\r\n            }\r\n        };\r\n    }\r\n};\r\n\r\nexport default Rasterizer;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/rasterizer.js","/* @preserve ASM BEGIN */\r\n/* eslint-disable eqeqeq*/\r\nfunction Skeletonizer(stdlib, foreign, buffer) {\r\n    \"use asm\";\r\n\r\n    var images = new stdlib.Uint8Array(buffer),\r\n        size = foreign.size | 0,\r\n        imul = stdlib.Math.imul;\r\n\r\n    function erode(inImagePtr, outImagePtr) {\r\n        inImagePtr = inImagePtr | 0;\r\n        outImagePtr = outImagePtr | 0;\r\n\r\n        var v = 0,\r\n            u = 0,\r\n            sum = 0,\r\n            yStart1 = 0,\r\n            yStart2 = 0,\r\n            xStart1 = 0,\r\n            xStart2 = 0,\r\n            offset = 0;\r\n\r\n        for ( v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\r\n            offset = (offset + size) | 0;\r\n            for ( u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\r\n                yStart1 = (offset - size) | 0;\r\n                yStart2 = (offset + size) | 0;\r\n                xStart1 = (u - 1) | 0;\r\n                xStart2 = (u + 1) | 0;\r\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\r\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\r\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\r\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\r\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\r\n                if ((sum | 0) == (5 | 0)) {\r\n                    images[(outImagePtr + offset + u) | 0] = 1;\r\n                } else {\r\n                    images[(outImagePtr + offset + u) | 0] = 0;\r\n                }\r\n            }\r\n        }\r\n        return;\r\n    }\r\n\r\n    function subtract(aImagePtr, bImagePtr, outImagePtr) {\r\n        aImagePtr = aImagePtr | 0;\r\n        bImagePtr = bImagePtr | 0;\r\n        outImagePtr = outImagePtr | 0;\r\n\r\n        var length = 0;\r\n\r\n        length = imul(size, size) | 0;\r\n\r\n        while ((length | 0) > 0) {\r\n            length = (length - 1) | 0;\r\n            images[(outImagePtr + length) | 0] =\r\n                ((images[(aImagePtr + length) | 0] | 0) - (images[(bImagePtr + length) | 0] | 0)) | 0;\r\n        }\r\n    }\r\n\r\n    function bitwiseOr(aImagePtr, bImagePtr, outImagePtr) {\r\n        aImagePtr = aImagePtr | 0;\r\n        bImagePtr = bImagePtr | 0;\r\n        outImagePtr = outImagePtr | 0;\r\n\r\n        var length = 0;\r\n\r\n        length = imul(size, size) | 0;\r\n\r\n        while ((length | 0) > 0) {\r\n            length = (length - 1) | 0;\r\n            images[(outImagePtr + length) | 0] =\r\n                ((images[(aImagePtr + length) | 0] | 0) | (images[(bImagePtr + length) | 0] | 0)) | 0;\r\n        }\r\n    }\r\n\r\n    function countNonZero(imagePtr) {\r\n        imagePtr = imagePtr | 0;\r\n\r\n        var sum = 0,\r\n            length = 0;\r\n\r\n        length = imul(size, size) | 0;\r\n\r\n        while ((length | 0) > 0) {\r\n            length = (length - 1) | 0;\r\n            sum = ((sum | 0) + (images[(imagePtr + length) | 0] | 0)) | 0;\r\n        }\r\n\r\n        return (sum | 0);\r\n    }\r\n\r\n    function init(imagePtr, value) {\r\n        imagePtr = imagePtr | 0;\r\n        value = value | 0;\r\n\r\n        var length = 0;\r\n\r\n        length = imul(size, size) | 0;\r\n\r\n        while ((length | 0) > 0) {\r\n            length = (length - 1) | 0;\r\n            images[(imagePtr + length) | 0] = value;\r\n        }\r\n    }\r\n\r\n    function dilate(inImagePtr, outImagePtr) {\r\n        inImagePtr = inImagePtr | 0;\r\n        outImagePtr = outImagePtr | 0;\r\n\r\n        var v = 0,\r\n            u = 0,\r\n            sum = 0,\r\n            yStart1 = 0,\r\n            yStart2 = 0,\r\n            xStart1 = 0,\r\n            xStart2 = 0,\r\n            offset = 0;\r\n\r\n        for ( v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\r\n            offset = (offset + size) | 0;\r\n            for ( u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\r\n                yStart1 = (offset - size) | 0;\r\n                yStart2 = (offset + size) | 0;\r\n                xStart1 = (u - 1) | 0;\r\n                xStart2 = (u + 1) | 0;\r\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\r\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\r\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\r\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\r\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\r\n                if ((sum | 0) > (0 | 0)) {\r\n                    images[(outImagePtr + offset + u) | 0] = 1;\r\n                } else {\r\n                    images[(outImagePtr + offset + u) | 0] = 0;\r\n                }\r\n            }\r\n        }\r\n        return;\r\n    }\r\n\r\n    function memcpy(srcImagePtr, dstImagePtr) {\r\n        srcImagePtr = srcImagePtr | 0;\r\n        dstImagePtr = dstImagePtr | 0;\r\n\r\n        var length = 0;\r\n\r\n        length = imul(size, size) | 0;\r\n\r\n        while ((length | 0) > 0) {\r\n            length = (length - 1) | 0;\r\n            images[(dstImagePtr + length) | 0] = (images[(srcImagePtr + length) | 0] | 0);\r\n        }\r\n    }\r\n\r\n    function zeroBorder(imagePtr) {\r\n        imagePtr = imagePtr | 0;\r\n\r\n        var x = 0,\r\n            y = 0;\r\n\r\n        for ( x = 0; (x | 0) < ((size - 1) | 0); x = (x + 1) | 0) {\r\n            images[(imagePtr + x) | 0] = 0;\r\n            images[(imagePtr + y) | 0] = 0;\r\n            y = ((y + size) - 1) | 0;\r\n            images[(imagePtr + y) | 0] = 0;\r\n            y = (y + 1) | 0;\r\n        }\r\n        for ( x = 0; (x | 0) < (size | 0); x = (x + 1) | 0) {\r\n            images[(imagePtr + y) | 0] = 0;\r\n            y = (y + 1) | 0;\r\n        }\r\n    }\r\n\r\n    function skeletonize() {\r\n        var subImagePtr = 0,\r\n            erodedImagePtr = 0,\r\n            tempImagePtr = 0,\r\n            skelImagePtr = 0,\r\n            sum = 0,\r\n            done = 0;\r\n\r\n        erodedImagePtr = imul(size, size) | 0;\r\n        tempImagePtr = (erodedImagePtr + erodedImagePtr) | 0;\r\n        skelImagePtr = (tempImagePtr + erodedImagePtr) | 0;\r\n\r\n        // init skel-image\r\n        init(skelImagePtr, 0);\r\n        zeroBorder(subImagePtr);\r\n\r\n        do {\r\n            erode(subImagePtr, erodedImagePtr);\r\n            dilate(erodedImagePtr, tempImagePtr);\r\n            subtract(subImagePtr, tempImagePtr, tempImagePtr);\r\n            bitwiseOr(skelImagePtr, tempImagePtr, skelImagePtr);\r\n            memcpy(erodedImagePtr, subImagePtr);\r\n            sum = countNonZero(subImagePtr) | 0;\r\n            done = ((sum | 0) == 0 | 0);\r\n        } while (!done);\r\n    }\r\n    return {\r\n        skeletonize: skeletonize\r\n    };\r\n}\r\n/* @preserve ASM END */\r\nexport default Skeletonizer;\r\n/* eslint-enable eqeqeq*/\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/skeletonizer.js","import BarcodeReader from './barcode_reader';\r\n\r\nfunction TwoOfFiveReader(opts) {\r\n    BarcodeReader.call(this, opts);\r\n    this.barSpaceRatio = [1, 1];\r\n}\r\n\r\nvar N = 1,\r\n    W = 3,\r\n    properties = {\r\n        START_PATTERN: {value: [W, N, W, N, N, N]},\r\n        STOP_PATTERN: {value: [W, N, N, N, W]},\r\n        CODE_PATTERN: {value: [\r\n            [N, N, W, W, N],\r\n            [W, N, N, N, W],\r\n            [N, W, N, N, W],\r\n            [W, W, N, N, N],\r\n            [N, N, W, N, W],\r\n            [W, N, W, N, N],\r\n            [N, W, W, N, N],\r\n            [N, N, N, W, W],\r\n            [W, N, N, W, N],\r\n            [N, W, N, W, N]\r\n        ]},\r\n        SINGLE_CODE_ERROR: {value: 0.78, writable: true},\r\n        AVG_CODE_ERROR: {value: 0.30, writable: true},\r\n        FORMAT: {value: \"2of5\"}\r\n    };\r\n\r\nconst startPatternLength = properties.START_PATTERN.value.reduce((sum, val) => sum + val, 0);\r\n\r\nTwoOfFiveReader.prototype = Object.create(BarcodeReader.prototype, properties);\r\nTwoOfFiveReader.prototype.constructor = TwoOfFiveReader;\r\n\r\nTwoOfFiveReader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder) {\r\n    var counter = [],\r\n        self = this,\r\n        i,\r\n        counterPos = 0,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: 0,\r\n            end: 0\r\n        },\r\n        error,\r\n        j,\r\n        sum,\r\n        epsilon = self.AVG_CODE_ERROR;\r\n\r\n    isWhite = isWhite || false;\r\n    tryHarder = tryHarder || false;\r\n\r\n    if (!offset) {\r\n        offset = self._nextSet(self._row);\r\n    }\r\n\r\n    for ( i = 0; i < pattern.length; i++) {\r\n        counter[i] = 0;\r\n    }\r\n\r\n    for ( i = offset; i < self._row.length; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            if (counterPos === counter.length - 1) {\r\n                sum = 0;\r\n                for ( j = 0; j < counter.length; j++) {\r\n                    sum += counter[j];\r\n                }\r\n                error = self._matchPattern(counter, pattern);\r\n                if (error < epsilon) {\r\n                    bestMatch.error = error;\r\n                    bestMatch.start = i - sum;\r\n                    bestMatch.end = i;\r\n                    return bestMatch;\r\n                }\r\n                if (tryHarder) {\r\n                    for (j = 0; j < counter.length - 2; j++) {\r\n                        counter[j] = counter[j + 2];\r\n                    }\r\n                    counter[counter.length - 2] = 0;\r\n                    counter[counter.length - 1] = 0;\r\n                    counterPos--;\r\n                } else {\r\n                    return null;\r\n                }\r\n            } else {\r\n                counterPos++;\r\n            }\r\n            counter[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nTwoOfFiveReader.prototype._findStart = function() {\r\n    var self = this,\r\n        leadingWhitespaceStart,\r\n        offset = self._nextSet(self._row),\r\n        startInfo,\r\n        narrowBarWidth = 1;\r\n\r\n    while (!startInfo) {\r\n        startInfo = self._findPattern(self.START_PATTERN, offset, false, true);\r\n        if (!startInfo) {\r\n            return null;\r\n        }\r\n        narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / startPatternLength);\r\n        leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5;\r\n        if (leadingWhitespaceStart >= 0) {\r\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\r\n                return startInfo;\r\n            }\r\n        }\r\n        offset = startInfo.end;\r\n        startInfo = null;\r\n    }\r\n};\r\n\r\nTwoOfFiveReader.prototype._verifyTrailingWhitespace = function(endInfo) {\r\n    var self = this,\r\n        trailingWhitespaceEnd;\r\n\r\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\r\n    if (trailingWhitespaceEnd < self._row.length) {\r\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\r\n            return endInfo;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nTwoOfFiveReader.prototype._findEnd = function() {\r\n    var self = this,\r\n        endInfo,\r\n        tmp,\r\n        offset;\r\n\r\n    self._row.reverse();\r\n    offset = self._nextSet(self._row);\r\n    endInfo = self._findPattern(self.STOP_PATTERN, offset, false, true);\r\n    self._row.reverse();\r\n\r\n    if (endInfo === null) {\r\n        return null;\r\n    }\r\n\r\n    // reverse numbers\r\n    tmp = endInfo.start;\r\n    endInfo.start = self._row.length - endInfo.end;\r\n    endInfo.end = self._row.length - tmp;\r\n\r\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\r\n};\r\n\r\nTwoOfFiveReader.prototype._decodeCode = function(counter) {\r\n    var j,\r\n        self = this,\r\n        sum = 0,\r\n        normalized,\r\n        error,\r\n        epsilon = self.AVG_CODE_ERROR,\r\n        code,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: 0,\r\n            end: 0\r\n        };\r\n\r\n    for ( j = 0; j < counter.length; j++) {\r\n        sum += counter[j];\r\n    }\r\n    for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n        error = self._matchPattern(counter, self.CODE_PATTERN[code]);\r\n        if (error < bestMatch.error) {\r\n            bestMatch.code = code;\r\n            bestMatch.error = error;\r\n        }\r\n    }\r\n    if (bestMatch.error < epsilon) {\r\n        return bestMatch;\r\n    }\r\n};\r\n\r\nTwoOfFiveReader.prototype._decodePayload = function(counters, result, decodedCodes) {\r\n    var i,\r\n        self = this,\r\n        pos = 0,\r\n        counterLength = counters.length,\r\n        counter = [0, 0, 0, 0, 0],\r\n        code;\r\n\r\n    while (pos < counterLength) {\r\n        for (i = 0; i < 5; i++) {\r\n            counter[i] = counters[pos] * this.barSpaceRatio[0];\r\n            pos += 2;\r\n        }\r\n        code = self._decodeCode(counter);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        result.push(code.code + \"\");\r\n        decodedCodes.push(code);\r\n    }\r\n    return code;\r\n};\r\n\r\nTwoOfFiveReader.prototype._verifyCounterLength = function(counters) {\r\n    return (counters.length % 10 === 0);\r\n};\r\n\r\nTwoOfFiveReader.prototype._decode = function() {\r\n    var startInfo,\r\n        endInfo,\r\n        self = this,\r\n        code,\r\n        result = [],\r\n        decodedCodes = [],\r\n        counters;\r\n\r\n    startInfo = self._findStart();\r\n    if (!startInfo) {\r\n        return null;\r\n    }\r\n    decodedCodes.push(startInfo);\r\n\r\n    endInfo = self._findEnd();\r\n    if (!endInfo) {\r\n        return null;\r\n    }\r\n\r\n    counters = self._fillCounters(startInfo.end, endInfo.start, false);\r\n    if (!self._verifyCounterLength(counters)) {\r\n        return null;\r\n    }\r\n    code = self._decodePayload(counters, result, decodedCodes);\r\n    if (!code) {\r\n        return null;\r\n    }\r\n    if (result.length < 5) {\r\n        return null;\r\n    }\r\n\r\n    decodedCodes.push(endInfo);\r\n    return {\r\n        code: result.join(\"\"),\r\n        start: startInfo.start,\r\n        end: endInfo.end,\r\n        startInfo: startInfo,\r\n        decodedCodes: decodedCodes\r\n    };\r\n};\r\n\r\nexport default TwoOfFiveReader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/2of5_reader.js","import BarcodeReader from './barcode_reader';\r\n\r\nfunction CodabarReader() {\r\n    BarcodeReader.call(this);\r\n    this._counters = [];\r\n}\r\n\r\nvar properties = {\r\n    ALPHABETH_STRING: {value: \"0123456789-$:/.+ABCD\"},\r\n    ALPHABET: {value: [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 45, 36, 58, 47, 46, 43, 65, 66, 67, 68]},\r\n    CHARACTER_ENCODINGS: {value: [0x003, 0x006, 0x009, 0x060, 0x012, 0x042, 0x021, 0x024, 0x030, 0x048, 0x00c, 0x018,\r\n        0x045, 0x051, 0x054, 0x015, 0x01A, 0x029, 0x00B, 0x00E]},\r\n    START_END: {value: [0x01A, 0x029, 0x00B, 0x00E]},\r\n    MIN_ENCODED_CHARS: {value: 4},\r\n    MAX_ACCEPTABLE: {value: 2.0},\r\n    PADDING: {value: 1.5},\r\n    FORMAT: {value: \"codabar\", writeable: false}\r\n};\r\n\r\nCodabarReader.prototype = Object.create(BarcodeReader.prototype, properties);\r\nCodabarReader.prototype.constructor = CodabarReader;\r\n\r\nCodabarReader.prototype._decode = function() {\r\n    var self = this,\r\n        result = [],\r\n        start,\r\n        decodedChar,\r\n        pattern,\r\n        nextStart,\r\n        end;\r\n\r\n    this._counters = self._fillCounters();\r\n    start = self._findStart();\r\n    if (!start) {\r\n        return null;\r\n    }\r\n    nextStart = start.startCounter;\r\n\r\n    do {\r\n        pattern = self._toPattern(nextStart);\r\n        if (pattern < 0) {\r\n            return null;\r\n        }\r\n        decodedChar = self._patternToChar(pattern);\r\n        if (decodedChar < 0){\r\n            return null;\r\n        }\r\n        result.push(decodedChar);\r\n        nextStart += 8;\r\n        if (result.length > 1 && self._isStartEnd(pattern)) {\r\n            break;\r\n        }\r\n    } while (nextStart < self._counters.length);\r\n\r\n    // verify end\r\n    if ((result.length - 2) < self.MIN_ENCODED_CHARS || !self._isStartEnd(pattern)) {\r\n        return null;\r\n    }\r\n\r\n    // verify end white space\r\n    if (!self._verifyWhitespace(start.startCounter, nextStart - 8)){\r\n        return null;\r\n    }\r\n\r\n    if (!self._validateResult(result, start.startCounter)){\r\n        return null;\r\n    }\r\n\r\n    nextStart = nextStart > self._counters.length ? self._counters.length : nextStart;\r\n    end = start.start + self._sumCounters(start.startCounter, nextStart - 8);\r\n\r\n    return {\r\n        code: result.join(\"\"),\r\n        start: start.start,\r\n        end: end,\r\n        startInfo: start,\r\n        decodedCodes: result\r\n    };\r\n};\r\n\r\nCodabarReader.prototype._verifyWhitespace = function(startCounter, endCounter) {\r\n    if ((startCounter - 1 <= 0)\r\n            || this._counters[startCounter - 1] >= (this._calculatePatternLength(startCounter) / 2.0)) {\r\n        if ((endCounter + 8 >= this._counters.length)\r\n                || this._counters[endCounter + 7] >= (this._calculatePatternLength(endCounter) / 2.0)) {\r\n            return true;\r\n        }\r\n    }\r\n    return false;\r\n};\r\n\r\nCodabarReader.prototype._calculatePatternLength = function(offset) {\r\n    var i,\r\n        sum = 0;\r\n\r\n    for (i = offset; i < offset + 7; i++) {\r\n        sum += this._counters[i];\r\n    }\r\n\r\n    return sum;\r\n};\r\n\r\nCodabarReader.prototype._thresholdResultPattern = function(result, startCounter){\r\n    var self = this,\r\n        categorization = {\r\n            space: {\r\n                narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE},\r\n                wide: {size: 0, counts: 0, min: 0, max: Number.MAX_VALUE}\r\n            },\r\n            bar: {\r\n                narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE},\r\n                wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE}\r\n            }\r\n        },\r\n        kind,\r\n        cat,\r\n        i,\r\n        j,\r\n        pos = startCounter,\r\n        pattern;\r\n\r\n    for (i = 0; i < result.length; i++){\r\n        pattern = self._charToPattern(result[i]);\r\n        for (j = 6; j >= 0; j--) {\r\n            kind = (j & 1) === 2 ? categorization.bar : categorization.space;\r\n            cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\r\n            cat.size += self._counters[pos + j];\r\n            cat.counts++;\r\n            pattern >>= 1;\r\n        }\r\n        pos += 8;\r\n    }\r\n\r\n    [\"space\", \"bar\"].forEach(function(key) {\r\n        var newkind = categorization[key];\r\n        newkind.wide.min =\r\n            Math.floor((newkind.narrow.size / newkind.narrow.counts + newkind.wide.size / newkind.wide.counts) / 2);\r\n        newkind.narrow.max = Math.ceil(newkind.wide.min);\r\n        newkind.wide.max = Math.ceil((newkind.wide.size * self.MAX_ACCEPTABLE + self.PADDING) / newkind.wide.counts);\r\n    });\r\n\r\n    return categorization;\r\n};\r\n\r\nCodabarReader.prototype._charToPattern = function(char) {\r\n    var self = this,\r\n        charCode = char.charCodeAt(0),\r\n        i;\r\n\r\n    for (i = 0; i < self.ALPHABET.length; i++) {\r\n        if (self.ALPHABET[i] === charCode){\r\n            return self.CHARACTER_ENCODINGS[i];\r\n        }\r\n    }\r\n    return 0x0;\r\n};\r\n\r\nCodabarReader.prototype._validateResult = function(result, startCounter) {\r\n    var self = this,\r\n        thresholds = self._thresholdResultPattern(result, startCounter),\r\n        i,\r\n        j,\r\n        kind,\r\n        cat,\r\n        size,\r\n        pos = startCounter,\r\n        pattern;\r\n\r\n    for (i = 0; i < result.length; i++) {\r\n        pattern = self._charToPattern(result[i]);\r\n        for (j = 6; j >= 0; j--) {\r\n            kind = (j & 1) === 0 ? thresholds.bar : thresholds.space;\r\n            cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\r\n            size = self._counters[pos + j];\r\n            if (size < cat.min || size > cat.max) {\r\n                return false;\r\n            }\r\n            pattern >>= 1;\r\n        }\r\n        pos += 8;\r\n    }\r\n    return true;\r\n};\r\n\r\nCodabarReader.prototype._patternToChar = function(pattern) {\r\n    var i,\r\n        self = this;\r\n\r\n    for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {\r\n        if (self.CHARACTER_ENCODINGS[i] === pattern) {\r\n            return String.fromCharCode(self.ALPHABET[i]);\r\n        }\r\n    }\r\n    return -1;\r\n};\r\n\r\nCodabarReader.prototype._computeAlternatingThreshold = function(offset, end) {\r\n    var i,\r\n        min = Number.MAX_VALUE,\r\n        max = 0,\r\n        counter;\r\n\r\n    for (i = offset; i < end; i += 2){\r\n        counter = this._counters[i];\r\n        if (counter > max) {\r\n            max = counter;\r\n        }\r\n        if (counter < min) {\r\n            min = counter;\r\n        }\r\n    }\r\n\r\n    return ((min + max) / 2.0) | 0;\r\n};\r\n\r\nCodabarReader.prototype._toPattern = function(offset) {\r\n    var numCounters = 7,\r\n        end = offset + numCounters,\r\n        barThreshold,\r\n        spaceThreshold,\r\n        bitmask = 1 << (numCounters - 1),\r\n        pattern = 0,\r\n        i,\r\n        threshold;\r\n\r\n    if (end > this._counters.length) {\r\n        return -1;\r\n    }\r\n\r\n    barThreshold = this._computeAlternatingThreshold(offset, end);\r\n    spaceThreshold = this._computeAlternatingThreshold(offset + 1, end);\r\n\r\n    for (i = 0; i < numCounters; i++){\r\n        threshold = (i & 1) === 0 ? barThreshold : spaceThreshold;\r\n        if (this._counters[offset + i] > threshold) {\r\n            pattern |= bitmask;\r\n        }\r\n        bitmask >>= 1;\r\n    }\r\n\r\n    return pattern;\r\n};\r\n\r\nCodabarReader.prototype._isStartEnd = function(pattern) {\r\n    var i;\r\n\r\n    for (i = 0; i < this.START_END.length; i++) {\r\n        if (this.START_END[i] === pattern) {\r\n            return true;\r\n        }\r\n    }\r\n    return false;\r\n};\r\n\r\nCodabarReader.prototype._sumCounters = function(start, end) {\r\n    var i,\r\n        sum = 0;\r\n\r\n    for (i = start; i < end; i++) {\r\n        sum += this._counters[i];\r\n    }\r\n    return sum;\r\n};\r\n\r\nCodabarReader.prototype._findStart = function() {\r\n    var self = this,\r\n        i,\r\n        pattern,\r\n        start = self._nextUnset(self._row),\r\n        end;\r\n\r\n    for (i = 1; i < this._counters.length; i++) {\r\n        pattern = self._toPattern(i);\r\n        if (pattern !== -1 && self._isStartEnd(pattern)) {\r\n            // TODO: Look for whitespace ahead\r\n            start += self._sumCounters(0, i);\r\n            end = start + self._sumCounters(i, i + 8);\r\n            return {\r\n                start: start,\r\n                end: end,\r\n                startCounter: i,\r\n                endCounter: i + 8\r\n            };\r\n        }\r\n    }\r\n};\r\n\r\nexport default CodabarReader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/codabar_reader.js","import BarcodeReader from './barcode_reader';\r\n\r\nfunction Code128Reader() {\r\n    BarcodeReader.call(this);\r\n}\r\n\r\nvar properties = {\r\n    CODE_SHIFT: {value: 98},\r\n    CODE_C: {value: 99},\r\n    CODE_B: {value: 100},\r\n    CODE_A: {value: 101},\r\n    START_CODE_A: {value: 103},\r\n    START_CODE_B: {value: 104},\r\n    START_CODE_C: {value: 105},\r\n    STOP_CODE: {value: 106},\r\n    CODE_PATTERN: {value: [\r\n        [2, 1, 2, 2, 2, 2],\r\n        [2, 2, 2, 1, 2, 2],\r\n        [2, 2, 2, 2, 2, 1],\r\n        [1, 2, 1, 2, 2, 3],\r\n        [1, 2, 1, 3, 2, 2],\r\n        [1, 3, 1, 2, 2, 2],\r\n        [1, 2, 2, 2, 1, 3],\r\n        [1, 2, 2, 3, 1, 2],\r\n        [1, 3, 2, 2, 1, 2],\r\n        [2, 2, 1, 2, 1, 3],\r\n        [2, 2, 1, 3, 1, 2],\r\n        [2, 3, 1, 2, 1, 2],\r\n        [1, 1, 2, 2, 3, 2],\r\n        [1, 2, 2, 1, 3, 2],\r\n        [1, 2, 2, 2, 3, 1],\r\n        [1, 1, 3, 2, 2, 2],\r\n        [1, 2, 3, 1, 2, 2],\r\n        [1, 2, 3, 2, 2, 1],\r\n        [2, 2, 3, 2, 1, 1],\r\n        [2, 2, 1, 1, 3, 2],\r\n        [2, 2, 1, 2, 3, 1],\r\n        [2, 1, 3, 2, 1, 2],\r\n        [2, 2, 3, 1, 1, 2],\r\n        [3, 1, 2, 1, 3, 1],\r\n        [3, 1, 1, 2, 2, 2],\r\n        [3, 2, 1, 1, 2, 2],\r\n        [3, 2, 1, 2, 2, 1],\r\n        [3, 1, 2, 2, 1, 2],\r\n        [3, 2, 2, 1, 1, 2],\r\n        [3, 2, 2, 2, 1, 1],\r\n        [2, 1, 2, 1, 2, 3],\r\n        [2, 1, 2, 3, 2, 1],\r\n        [2, 3, 2, 1, 2, 1],\r\n        [1, 1, 1, 3, 2, 3],\r\n        [1, 3, 1, 1, 2, 3],\r\n        [1, 3, 1, 3, 2, 1],\r\n        [1, 1, 2, 3, 1, 3],\r\n        [1, 3, 2, 1, 1, 3],\r\n        [1, 3, 2, 3, 1, 1],\r\n        [2, 1, 1, 3, 1, 3],\r\n        [2, 3, 1, 1, 1, 3],\r\n        [2, 3, 1, 3, 1, 1],\r\n        [1, 1, 2, 1, 3, 3],\r\n        [1, 1, 2, 3, 3, 1],\r\n        [1, 3, 2, 1, 3, 1],\r\n        [1, 1, 3, 1, 2, 3],\r\n        [1, 1, 3, 3, 2, 1],\r\n        [1, 3, 3, 1, 2, 1],\r\n        [3, 1, 3, 1, 2, 1],\r\n        [2, 1, 1, 3, 3, 1],\r\n        [2, 3, 1, 1, 3, 1],\r\n        [2, 1, 3, 1, 1, 3],\r\n        [2, 1, 3, 3, 1, 1],\r\n        [2, 1, 3, 1, 3, 1],\r\n        [3, 1, 1, 1, 2, 3],\r\n        [3, 1, 1, 3, 2, 1],\r\n        [3, 3, 1, 1, 2, 1],\r\n        [3, 1, 2, 1, 1, 3],\r\n        [3, 1, 2, 3, 1, 1],\r\n        [3, 3, 2, 1, 1, 1],\r\n        [3, 1, 4, 1, 1, 1],\r\n        [2, 2, 1, 4, 1, 1],\r\n        [4, 3, 1, 1, 1, 1],\r\n        [1, 1, 1, 2, 2, 4],\r\n        [1, 1, 1, 4, 2, 2],\r\n        [1, 2, 1, 1, 2, 4],\r\n        [1, 2, 1, 4, 2, 1],\r\n        [1, 4, 1, 1, 2, 2],\r\n        [1, 4, 1, 2, 2, 1],\r\n        [1, 1, 2, 2, 1, 4],\r\n        [1, 1, 2, 4, 1, 2],\r\n        [1, 2, 2, 1, 1, 4],\r\n        [1, 2, 2, 4, 1, 1],\r\n        [1, 4, 2, 1, 1, 2],\r\n        [1, 4, 2, 2, 1, 1],\r\n        [2, 4, 1, 2, 1, 1],\r\n        [2, 2, 1, 1, 1, 4],\r\n        [4, 1, 3, 1, 1, 1],\r\n        [2, 4, 1, 1, 1, 2],\r\n        [1, 3, 4, 1, 1, 1],\r\n        [1, 1, 1, 2, 4, 2],\r\n        [1, 2, 1, 1, 4, 2],\r\n        [1, 2, 1, 2, 4, 1],\r\n        [1, 1, 4, 2, 1, 2],\r\n        [1, 2, 4, 1, 1, 2],\r\n        [1, 2, 4, 2, 1, 1],\r\n        [4, 1, 1, 2, 1, 2],\r\n        [4, 2, 1, 1, 1, 2],\r\n        [4, 2, 1, 2, 1, 1],\r\n        [2, 1, 2, 1, 4, 1],\r\n        [2, 1, 4, 1, 2, 1],\r\n        [4, 1, 2, 1, 2, 1],\r\n        [1, 1, 1, 1, 4, 3],\r\n        [1, 1, 1, 3, 4, 1],\r\n        [1, 3, 1, 1, 4, 1],\r\n        [1, 1, 4, 1, 1, 3],\r\n        [1, 1, 4, 3, 1, 1],\r\n        [4, 1, 1, 1, 1, 3],\r\n        [4, 1, 1, 3, 1, 1],\r\n        [1, 1, 3, 1, 4, 1],\r\n        [1, 1, 4, 1, 3, 1],\r\n        [3, 1, 1, 1, 4, 1],\r\n        [4, 1, 1, 1, 3, 1],\r\n        [2, 1, 1, 4, 1, 2],\r\n        [2, 1, 1, 2, 1, 4],\r\n        [2, 1, 1, 2, 3, 2],\r\n        [2, 3, 3, 1, 1, 1, 2]\r\n    ]},\r\n    SINGLE_CODE_ERROR: {value: 0.64},\r\n    AVG_CODE_ERROR: {value: 0.30},\r\n    FORMAT: {value: \"code_128\", writeable: false},\r\n    MODULE_INDICES: {value: {bar: [0, 2, 4], space: [1, 3, 5]}}\r\n};\r\n\r\nCode128Reader.prototype = Object.create(BarcodeReader.prototype, properties);\r\nCode128Reader.prototype.constructor = Code128Reader;\r\n\r\nCode128Reader.prototype._decodeCode = function(start, correction) {\r\n    var counter = [0, 0, 0, 0, 0, 0],\r\n        i,\r\n        self = this,\r\n        offset = start,\r\n        isWhite = !self._row[offset],\r\n        counterPos = 0,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: start,\r\n            end: start,\r\n            correction: {\r\n                bar: 1,\r\n                space: 1\r\n            }\r\n        },\r\n        code,\r\n        error;\r\n\r\n    for ( i = offset; i < self._row.length; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            if (counterPos === counter.length - 1) {\r\n                if (correction) {\r\n                    self._correct(counter, correction);\r\n                }\r\n                for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n                    error = self._matchPattern(counter, self.CODE_PATTERN[code]);\r\n                    if (error < bestMatch.error) {\r\n                        bestMatch.code = code;\r\n                        bestMatch.error = error;\r\n                    }\r\n                }\r\n                bestMatch.end = i;\r\n                if (bestMatch.code === -1 || bestMatch.error > self.AVG_CODE_ERROR) {\r\n                    return null;\r\n                }\r\n                if (self.CODE_PATTERN[bestMatch.code]) {\r\n                    bestMatch.correction.bar = calculateCorrection(\r\n                        self.CODE_PATTERN[bestMatch.code], counter,\r\n                        this.MODULE_INDICES.bar);\r\n                    bestMatch.correction.space = calculateCorrection(\r\n                        self.CODE_PATTERN[bestMatch.code], counter,\r\n                        this.MODULE_INDICES.space);\r\n                }\r\n                return bestMatch;\r\n            } else {\r\n                counterPos++;\r\n            }\r\n            counter[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nCode128Reader.prototype._correct = function(counter, correction) {\r\n    this._correctBars(counter, correction.bar, this.MODULE_INDICES.bar);\r\n    this._correctBars(counter, correction.space, this.MODULE_INDICES.space);\r\n};\r\n\r\nCode128Reader.prototype._findStart = function() {\r\n    var counter = [0, 0, 0, 0, 0, 0],\r\n        i,\r\n        self = this,\r\n        offset = self._nextSet(self._row),\r\n        isWhite = false,\r\n        counterPos = 0,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: 0,\r\n            end: 0,\r\n            correction: {\r\n                bar: 1,\r\n                space: 1\r\n            }\r\n        },\r\n        code,\r\n        error,\r\n        j,\r\n        sum;\r\n\r\n    for ( i = offset; i < self._row.length; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            if (counterPos === counter.length - 1) {\r\n                sum = 0;\r\n                for ( j = 0; j < counter.length; j++) {\r\n                    sum += counter[j];\r\n                }\r\n                for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) {\r\n                    error = self._matchPattern(counter, self.CODE_PATTERN[code]);\r\n                    if (error < bestMatch.error) {\r\n                        bestMatch.code = code;\r\n                        bestMatch.error = error;\r\n                    }\r\n                }\r\n                if (bestMatch.error < self.AVG_CODE_ERROR) {\r\n                    bestMatch.start = i - sum;\r\n                    bestMatch.end = i;\r\n                    bestMatch.correction.bar = calculateCorrection(\r\n                        self.CODE_PATTERN[bestMatch.code], counter,\r\n                        this.MODULE_INDICES.bar);\r\n                    bestMatch.correction.space = calculateCorrection(\r\n                        self.CODE_PATTERN[bestMatch.code], counter,\r\n                        this.MODULE_INDICES.space);\r\n                    return bestMatch;\r\n                }\r\n\r\n                for ( j = 0; j < 4; j++) {\r\n                    counter[j] = counter[j + 2];\r\n                }\r\n                counter[4] = 0;\r\n                counter[5] = 0;\r\n                counterPos--;\r\n            } else {\r\n                counterPos++;\r\n            }\r\n            counter[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nCode128Reader.prototype._decode = function() {\r\n    var self = this,\r\n        startInfo = self._findStart(),\r\n        code = null,\r\n        done = false,\r\n        result = [],\r\n        multiplier = 0,\r\n        checksum = 0,\r\n        codeset,\r\n        rawResult = [],\r\n        decodedCodes = [],\r\n        shiftNext = false,\r\n        unshift,\r\n        removeLastCharacter = true;\r\n\r\n    if (startInfo === null) {\r\n        return null;\r\n    }\r\n    code = {\r\n        code: startInfo.code,\r\n        start: startInfo.start,\r\n        end: startInfo.end,\r\n        correction: {\r\n            bar: startInfo.correction.bar,\r\n            space: startInfo.correction.space\r\n        }\r\n    };\r\n    decodedCodes.push(code);\r\n    checksum = code.code;\r\n    switch (code.code) {\r\n    case self.START_CODE_A:\r\n        codeset = self.CODE_A;\r\n        break;\r\n    case self.START_CODE_B:\r\n        codeset = self.CODE_B;\r\n        break;\r\n    case self.START_CODE_C:\r\n        codeset = self.CODE_C;\r\n        break;\r\n    default:\r\n        return null;\r\n    }\r\n\r\n    while (!done) {\r\n        unshift = shiftNext;\r\n        shiftNext = false;\r\n        code = self._decodeCode(code.end, code.correction);\r\n        if (code !== null) {\r\n            if (code.code !== self.STOP_CODE) {\r\n                removeLastCharacter = true;\r\n            }\r\n\r\n            if (code.code !== self.STOP_CODE) {\r\n                rawResult.push(code.code);\r\n                multiplier++;\r\n                checksum += multiplier * code.code;\r\n            }\r\n            decodedCodes.push(code);\r\n\r\n            switch (codeset) {\r\n            case self.CODE_A:\r\n                if (code.code < 64) {\r\n                    result.push(String.fromCharCode(32 + code.code));\r\n                } else if (code.code < 96) {\r\n                    result.push(String.fromCharCode(code.code - 64));\r\n                } else {\r\n                    if (code.code !== self.STOP_CODE) {\r\n                        removeLastCharacter = false;\r\n                    }\r\n                    switch (code.code) {\r\n                    case self.CODE_SHIFT:\r\n                        shiftNext = true;\r\n                        codeset = self.CODE_B;\r\n                        break;\r\n                    case self.CODE_B:\r\n                        codeset = self.CODE_B;\r\n                        break;\r\n                    case self.CODE_C:\r\n                        codeset = self.CODE_C;\r\n                        break;\r\n                    case self.STOP_CODE:\r\n                        done = true;\r\n                        break;\r\n                    }\r\n                }\r\n                break;\r\n            case self.CODE_B:\r\n                if (code.code < 96) {\r\n                    result.push(String.fromCharCode(32 + code.code));\r\n                } else {\r\n                    if (code.code !== self.STOP_CODE) {\r\n                        removeLastCharacter = false;\r\n                    }\r\n                    switch (code.code) {\r\n                    case self.CODE_SHIFT:\r\n                        shiftNext = true;\r\n                        codeset = self.CODE_A;\r\n                        break;\r\n                    case self.CODE_A:\r\n                        codeset = self.CODE_A;\r\n                        break;\r\n                    case self.CODE_C:\r\n                        codeset = self.CODE_C;\r\n                        break;\r\n                    case self.STOP_CODE:\r\n                        done = true;\r\n                        break;\r\n                    }\r\n                }\r\n                break;\r\n            case self.CODE_C:\r\n                if (code.code < 100) {\r\n                    result.push(code.code < 10 ? \"0\" + code.code : code.code);\r\n                } else {\r\n                    if (code.code !== self.STOP_CODE) {\r\n                        removeLastCharacter = false;\r\n                    }\r\n                    switch (code.code) {\r\n                    case self.CODE_A:\r\n                        codeset = self.CODE_A;\r\n                        break;\r\n                    case self.CODE_B:\r\n                        codeset = self.CODE_B;\r\n                        break;\r\n                    case self.STOP_CODE:\r\n                        done = true;\r\n                        break;\r\n                    }\r\n                }\r\n                break;\r\n            }\r\n        } else {\r\n            done = true;\r\n        }\r\n        if (unshift) {\r\n            codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A;\r\n        }\r\n    }\r\n\r\n    if (code === null) {\r\n        return null;\r\n    }\r\n\r\n    code.end = self._nextUnset(self._row, code.end);\r\n    if (!self._verifyTrailingWhitespace(code)){\r\n        return null;\r\n    }\r\n\r\n    checksum -= multiplier * rawResult[rawResult.length - 1];\r\n    if (checksum % 103 !== rawResult[rawResult.length - 1]) {\r\n        return null;\r\n    }\r\n\r\n    if (!result.length) {\r\n        return null;\r\n    }\r\n\r\n    // remove last code from result (checksum)\r\n    if (removeLastCharacter) {\r\n        result.splice(result.length - 1, 1);\r\n    }\r\n\r\n\r\n    return {\r\n        code: result.join(\"\"),\r\n        start: startInfo.start,\r\n        end: code.end,\r\n        codeset: codeset,\r\n        startInfo: startInfo,\r\n        decodedCodes: decodedCodes,\r\n        endInfo: code\r\n    };\r\n};\r\n\r\n\r\nBarcodeReader.prototype._verifyTrailingWhitespace = function(endInfo) {\r\n    var self = this,\r\n        trailingWhitespaceEnd;\r\n\r\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\r\n    if (trailingWhitespaceEnd < self._row.length) {\r\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\r\n            return endInfo;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nfunction calculateCorrection(expected, normalized, indices) {\r\n    var length = indices.length,\r\n        sumNormalized = 0,\r\n        sumExpected = 0;\r\n\r\n    while(length--) {\r\n        sumExpected += expected[indices[length]];\r\n        sumNormalized += normalized[indices[length]];\r\n    }\r\n    return sumExpected/sumNormalized;\r\n}\r\n\r\nexport default Code128Reader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_128_reader.js","import Code39Reader from './code_39_reader';\r\n\r\nfunction Code39VINReader() {\r\n    Code39Reader.call(this);\r\n}\r\n\r\nvar patterns = {\r\n    IOQ: /[IOQ]/g,\r\n    AZ09: /[A-Z0-9]{17}/\r\n};\r\n\r\nCode39VINReader.prototype = Object.create(Code39Reader.prototype);\r\nCode39VINReader.prototype.constructor = Code39VINReader;\r\n\r\n// Cribbed from:\r\n// https://github.com/zxing/zxing/blob/master/core/src/main/java/com/google/zxing/client/result/VINResultParser.java\r\nCode39VINReader.prototype._decode = function() {\r\n    var result = Code39Reader.prototype._decode.apply(this);\r\n    if (!result) {\r\n        return null;\r\n    }\r\n\r\n    var code = result.code;\r\n\r\n    if (!code) {\r\n        return null;\r\n    }\r\n\r\n    code = code.replace(patterns.IOQ, '');\r\n\r\n    if (!code.match(patterns.AZ09)) {\r\n        if (ENV.development) {\r\n            console.log('Failed AZ09 pattern code:', code);\r\n        }\r\n        return null;\r\n    }\r\n\r\n    if (!this._checkChecksum(code)) {\r\n        return null;\r\n    }\r\n\r\n    result.code = code;\r\n    return result;\r\n};\r\n\r\nCode39VINReader.prototype._checkChecksum = function(code) {\r\n    // TODO\r\n    return !!code;\r\n};\r\n\r\nexport default Code39VINReader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_39_vin_reader.js","import BarcodeReader from './barcode_reader';\r\nimport ArrayHelper from '../common/array_helper';\r\n\r\nfunction Code93Reader() {\r\n    BarcodeReader.call(this);\r\n}\r\n\r\nconst ALPHABETH_STRING = \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*\";\r\n\r\nvar properties = {\r\n    ALPHABETH_STRING: {value: ALPHABETH_STRING},\r\n    ALPHABET: {value: ALPHABETH_STRING.split('').map(char => char.charCodeAt(0))},\r\n    CHARACTER_ENCODINGS: {value: [\r\n        0x114, 0x148, 0x144, 0x142, 0x128, 0x124, 0x122, 0x150, 0x112, 0x10A,\r\n        0x1A8, 0x1A4, 0x1A2, 0x194, 0x192, 0x18A, 0x168, 0x164, 0x162, 0x134,\r\n        0x11A, 0x158, 0x14C, 0x146, 0x12C, 0x116, 0x1B4, 0x1B2, 0x1AC, 0x1A6,\r\n        0x196, 0x19A, 0x16C, 0x166, 0x136, 0x13A, 0x12E, 0x1D4, 0x1D2, 0x1CA,\r\n        0x16E, 0x176, 0x1AE, 0x126, 0x1DA, 0x1D6, 0x132, 0x15E\r\n    ]},\r\n    ASTERISK: {value: 0x15E},\r\n    FORMAT: {value: \"code_93\", writeable: false}\r\n};\r\n\r\nCode93Reader.prototype = Object.create(BarcodeReader.prototype, properties);\r\nCode93Reader.prototype.constructor = Code93Reader;\r\n\r\nCode93Reader.prototype._decode = function() {\r\n    var self = this,\r\n        counters = [0, 0, 0, 0, 0, 0],\r\n        result = [],\r\n        start = self._findStart(),\r\n        decodedChar,\r\n        lastStart,\r\n        pattern,\r\n        nextStart;\r\n\r\n    if (!start) {\r\n        return null;\r\n    }\r\n    nextStart = self._nextSet(self._row, start.end);\r\n\r\n    do {\r\n        counters = self._toCounters(nextStart, counters);\r\n        pattern = self._toPattern(counters);\r\n        if (pattern < 0) {\r\n            return null;\r\n        }\r\n        decodedChar = self._patternToChar(pattern);\r\n        if (decodedChar < 0){\r\n            return null;\r\n        }\r\n        result.push(decodedChar);\r\n        lastStart = nextStart;\r\n        nextStart += ArrayHelper.sum(counters);\r\n        nextStart = self._nextSet(self._row, nextStart);\r\n    } while (decodedChar !== '*');\r\n    result.pop();\r\n\r\n    if (!result.length) {\r\n        return null;\r\n    }\r\n\r\n    if (!self._verifyEnd(lastStart, nextStart, counters)) {\r\n        return null;\r\n    }\r\n\r\n    if (!self._verifyChecksums(result)) {\r\n        return null;\r\n    }\r\n\r\n    result = result.slice(0, result.length - 2);\r\n    if ((result = self._decodeExtended(result)) === null) {\r\n        return null;\r\n    };\r\n\r\n    return {\r\n        code: result.join(\"\"),\r\n        start: start.start,\r\n        end: nextStart,\r\n        startInfo: start,\r\n        decodedCodes: result\r\n    };\r\n};\r\n\r\nCode93Reader.prototype._verifyEnd = function(lastStart, nextStart) {\r\n    if (lastStart === nextStart || !this._row[nextStart]) {\r\n        return false;\r\n    }\r\n    return true;\r\n};\r\n\r\nCode93Reader.prototype._patternToChar = function(pattern) {\r\n    var i,\r\n        self = this;\r\n\r\n    for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {\r\n        if (self.CHARACTER_ENCODINGS[i] === pattern) {\r\n            return String.fromCharCode(self.ALPHABET[i]);\r\n        }\r\n    }\r\n    return -1;\r\n};\r\n\r\nCode93Reader.prototype._toPattern = function(counters) {\r\n    const numCounters = counters.length;\r\n    let pattern = 0;\r\n    let sum = 0;\r\n    for (let i = 0; i < numCounters; i++) {\r\n        sum += counters[i];\r\n    }\r\n\r\n    for (let i = 0; i < numCounters; i++) {\r\n        let normalized = Math.round(counters[i] * 9 / sum);\r\n        if (normalized < 1 || normalized > 4) {\r\n            return -1;\r\n        }\r\n        if ((i & 1) === 0) {\r\n            for (let j = 0; j < normalized; j++) {\r\n                pattern = (pattern << 1) | 1;\r\n            }\r\n        } else {\r\n            pattern <<= normalized;\r\n        }\r\n    }\r\n\r\n    return pattern;\r\n};\r\n\r\nCode93Reader.prototype._findStart = function() {\r\n    var self = this,\r\n        offset = self._nextSet(self._row),\r\n        patternStart = offset,\r\n        counter = [0, 0, 0, 0, 0, 0],\r\n        counterPos = 0,\r\n        isWhite = false,\r\n        i,\r\n        j,\r\n        whiteSpaceMustStart;\r\n\r\n    for ( i = offset; i < self._row.length; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            if (counterPos === counter.length - 1) {\r\n                // find start pattern\r\n                if (self._toPattern(counter) === self.ASTERISK) {\r\n                    whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - ((i - patternStart) / 4)));\r\n                    if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) {\r\n                        return {\r\n                            start: patternStart,\r\n                            end: i\r\n                        };\r\n                    }\r\n                }\r\n\r\n                patternStart += counter[0] + counter[1];\r\n                for ( j = 0; j < 4; j++) {\r\n                    counter[j] = counter[j + 2];\r\n                }\r\n                counter[4] = 0;\r\n                counter[5] = 0;\r\n                counterPos--;\r\n            } else {\r\n                counterPos++;\r\n            }\r\n            counter[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nCode93Reader.prototype._decodeExtended = function(charArray) {\r\n    const length = charArray.length;\r\n    const result = [];\r\n    for (let i = 0; i < length; i++) {\r\n        const char = charArray[i];\r\n        if (char >= 'a' && char <= 'd') {\r\n            if (i > (length - 2)) {\r\n                return null;\r\n            }\r\n            const nextChar = charArray[++i];\r\n            const nextCharCode = nextChar.charCodeAt(0);\r\n            let decodedChar;\r\n            switch (char) {\r\n            case 'a':\r\n                if (nextChar >= 'A' && nextChar <= 'Z') {\r\n                    decodedChar = String.fromCharCode(nextCharCode - 64);\r\n                } else {\r\n                    return null;\r\n                }\r\n                break;\r\n            case 'b':\r\n                if (nextChar >= 'A' && nextChar <= 'E') {\r\n                    decodedChar = String.fromCharCode(nextCharCode - 38);\r\n                } else if (nextChar >= 'F' && nextChar <= 'J') {\r\n                    decodedChar = String.fromCharCode(nextCharCode - 11);\r\n                } else if (nextChar >= 'K' && nextChar <= 'O') {\r\n                    decodedChar = String.fromCharCode(nextCharCode + 16);\r\n                } else if (nextChar >= 'P' && nextChar <= 'S') {\r\n                    decodedChar = String.fromCharCode(nextCharCode + 43);\r\n                } else if (nextChar >= 'T' && nextChar <= 'Z') {\r\n                    decodedChar = String.fromCharCode(127);\r\n                } else {\r\n                    return null;\r\n                }\r\n                break;\r\n            case 'c':\r\n                if (nextChar >= 'A' && nextChar <= 'O') {\r\n                    decodedChar = String.fromCharCode(nextCharCode - 32);\r\n                } else if (nextChar === 'Z') {\r\n                    decodedChar = ':';\r\n                } else {\r\n                    return null;\r\n                }\r\n                break;\r\n            case 'd':\r\n                if (nextChar >= 'A' && nextChar <= 'Z') {\r\n                    decodedChar = String.fromCharCode(nextCharCode + 32);\r\n                } else {\r\n                    return null;\r\n                }\r\n                break;\r\n            }\r\n            result.push(decodedChar);\r\n        } else {\r\n            result.push(char);\r\n        }\r\n    }\r\n    return result;\r\n};\r\n\r\nCode93Reader.prototype._verifyChecksums = function(charArray) {\r\n    return this._matchCheckChar(charArray, charArray.length - 2, 20)\r\n        && this._matchCheckChar(charArray, charArray.length - 1, 15);\r\n};\r\n\r\nCode93Reader.prototype._matchCheckChar = function(charArray, index, maxWeight) {\r\n    const arrayToCheck = charArray.slice(0, index);\r\n    const length = arrayToCheck.length;\r\n    const weightedSums = arrayToCheck.reduce((sum, char, i) => {\r\n        const weight = (((i * -1) + (length - 1)) % maxWeight) + 1;\r\n        const value = this.ALPHABET.indexOf(char.charCodeAt(0));\r\n        return sum + (weight * value);\r\n    }, 0);\r\n\r\n    const checkChar = this.ALPHABET[(weightedSums % 47)];\r\n    return checkChar === charArray[index].charCodeAt(0);\r\n};\r\n\r\nexport default Code93Reader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_93_reader.js","import EANReader from './ean_reader';\r\n\r\nfunction EAN2Reader() {\r\n    EANReader.call(this);\r\n}\r\n\r\nvar properties = {\r\n    FORMAT: {value: \"ean_2\", writeable: false}\r\n};\r\n\r\nEAN2Reader.prototype = Object.create(EANReader.prototype, properties);\r\nEAN2Reader.prototype.constructor = EAN2Reader;\r\n\r\nEAN2Reader.prototype.decode = function(row, start) {\r\n    this._row = row;\r\n    var counters = [0, 0, 0, 0],\r\n        codeFrequency = 0,\r\n        i = 0,\r\n        offset = start,\r\n        end = this._row.length,\r\n        code,\r\n        result = [],\r\n        decodedCodes = [];\r\n\r\n    for (i = 0; i < 2 && offset < end; i++) {\r\n        code = this._decodeCode(offset);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        decodedCodes.push(code);\r\n        result.push(code.code % 10);\r\n        if (code.code >= this.CODE_G_START) {\r\n            codeFrequency |= 1 << (1 - i);\r\n        }\r\n        if (i != 1) {\r\n            offset = this._nextSet(this._row, code.end);\r\n            offset = this._nextUnset(this._row, offset);\r\n        }\r\n    }\r\n\r\n    if (result.length != 2 || (parseInt(result.join(\"\")) % 4)  !== codeFrequency) {\r\n        return null;\r\n    }\r\n    return {\r\n        code: result.join(\"\"),\r\n        decodedCodes,\r\n        end: code.end\r\n    };\r\n};\r\n\r\nexport default EAN2Reader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_2_reader.js","import EANReader from './ean_reader';\r\n\r\nfunction EAN5Reader() {\r\n    EANReader.call(this);\r\n}\r\n\r\nvar properties = {\r\n    FORMAT: {value: \"ean_5\", writeable: false}\r\n};\r\n\r\nconst CHECK_DIGIT_ENCODINGS = [24, 20, 18, 17, 12, 6, 3, 10, 9, 5];\r\n\r\nEAN5Reader.prototype = Object.create(EANReader.prototype, properties);\r\nEAN5Reader.prototype.constructor = EAN5Reader;\r\n\r\nEAN5Reader.prototype.decode = function(row, start) {\r\n    this._row = row;\r\n    var counters = [0, 0, 0, 0],\r\n        codeFrequency = 0,\r\n        i = 0,\r\n        offset = start,\r\n        end = this._row.length,\r\n        code,\r\n        result = [],\r\n        decodedCodes = [];\r\n\r\n    for (i = 0; i < 5 && offset < end; i++) {\r\n        code = this._decodeCode(offset);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        decodedCodes.push(code);\r\n        result.push(code.code % 10);\r\n        if (code.code >= this.CODE_G_START) {\r\n            codeFrequency |= 1 << (4 - i);\r\n        }\r\n        if (i != 4) {\r\n            offset = this._nextSet(this._row, code.end);\r\n            offset = this._nextUnset(this._row, offset);\r\n        }\r\n    }\r\n\r\n    if (result.length != 5) {\r\n        return null;\r\n    }\r\n\r\n    if (extensionChecksum(result) !== determineCheckDigit(codeFrequency)) {\r\n        return null;\r\n    }\r\n    return {\r\n        code: result.join(\"\"),\r\n        decodedCodes,\r\n        end: code.end\r\n    };\r\n};\r\n\r\nfunction determineCheckDigit(codeFrequency) {\r\n    var i;\r\n    for (i = 0; i < 10; i++) {\r\n        if (codeFrequency === CHECK_DIGIT_ENCODINGS[i]) {\r\n            return i;\r\n        }\r\n    }\r\n    return null;\r\n}\r\n\r\n\r\nfunction extensionChecksum(result) {\r\n    var length = result.length,\r\n        sum = 0,\r\n        i;\r\n\r\n    for (i = length - 2; i >= 0; i -= 2) {\r\n        sum += result[i];\r\n    }\r\n    sum *= 3;\r\n    for (i = length - 1; i >= 0; i -= 2) {\r\n        sum += result[i];\r\n    }\r\n    sum *= 3;\r\n    return sum % 10;\r\n}\r\n\r\nexport default EAN5Reader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_5_reader.js","import EANReader from './ean_reader';\r\n\r\nfunction EAN8Reader(opts, supplements) {\r\n    EANReader.call(this, opts, supplements);\r\n}\r\n\r\nvar properties = {\r\n    FORMAT: {value: \"ean_8\", writeable: false}\r\n};\r\n\r\nEAN8Reader.prototype = Object.create(EANReader.prototype, properties);\r\nEAN8Reader.prototype.constructor = EAN8Reader;\r\n\r\nEAN8Reader.prototype._decodePayload = function(code, result, decodedCodes) {\r\n    var i,\r\n        self = this;\r\n\r\n    for ( i = 0; i < 4; i++) {\r\n        code = self._decodeCode(code.end, self.CODE_G_START);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        result.push(code.code);\r\n        decodedCodes.push(code);\r\n    }\r\n\r\n    code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);\r\n    if (code === null) {\r\n        return null;\r\n    }\r\n    decodedCodes.push(code);\r\n\r\n    for ( i = 0; i < 4; i++) {\r\n        code = self._decodeCode(code.end, self.CODE_G_START);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        decodedCodes.push(code);\r\n        result.push(code.code);\r\n    }\r\n\r\n    return code;\r\n};\r\n\r\nexport default EAN8Reader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_8_reader.js","import BarcodeReader from './barcode_reader';\r\nimport {merge} from 'lodash';\r\n\r\nfunction I2of5Reader(opts) {\r\n    opts = merge(getDefaulConfig(), opts);\r\n    BarcodeReader.call(this, opts);\r\n    this.barSpaceRatio = [1, 1];\r\n    if (opts.normalizeBarSpaceWidth) {\r\n        this.SINGLE_CODE_ERROR = 0.38;\r\n        this.AVG_CODE_ERROR = 0.09;\r\n    }\r\n}\r\n\r\nfunction getDefaulConfig() {\r\n    var config = {};\r\n\r\n    Object.keys(I2of5Reader.CONFIG_KEYS).forEach(function(key) {\r\n        config[key] = I2of5Reader.CONFIG_KEYS[key].default;\r\n    });\r\n    return config;\r\n}\r\n\r\nvar N = 1,\r\n    W = 3,\r\n    properties = {\r\n        START_PATTERN: {value: [N, N, N, N]},\r\n        STOP_PATTERN: {value: [N, N, W]},\r\n        CODE_PATTERN: {value: [\r\n            [N, N, W, W, N],\r\n            [W, N, N, N, W],\r\n            [N, W, N, N, W],\r\n            [W, W, N, N, N],\r\n            [N, N, W, N, W],\r\n            [W, N, W, N, N],\r\n            [N, W, W, N, N],\r\n            [N, N, N, W, W],\r\n            [W, N, N, W, N],\r\n            [N, W, N, W, N]\r\n        ]},\r\n        SINGLE_CODE_ERROR: {value: 0.78, writable: true},\r\n        AVG_CODE_ERROR: {value: 0.38, writable: true},\r\n        MAX_CORRECTION_FACTOR: {value: 5},\r\n        FORMAT: {value: \"i2of5\"}\r\n    };\r\n\r\nI2of5Reader.prototype = Object.create(BarcodeReader.prototype, properties);\r\nI2of5Reader.prototype.constructor = I2of5Reader;\r\n\r\nI2of5Reader.prototype._matchPattern = function(counter, code) {\r\n    if (this.config.normalizeBarSpaceWidth) {\r\n        var i,\r\n            counterSum = [0, 0],\r\n            codeSum = [0, 0],\r\n            correction = [0, 0],\r\n            correctionRatio = this.MAX_CORRECTION_FACTOR,\r\n            correctionRatioInverse = 1 / correctionRatio;\r\n\r\n        for (i = 0; i < counter.length; i++) {\r\n            counterSum[i % 2] += counter[i];\r\n            codeSum[i % 2] += code[i];\r\n        }\r\n        correction[0] = codeSum[0] / counterSum[0];\r\n        correction[1] = codeSum[1] / counterSum[1];\r\n\r\n        correction[0] = Math.max(Math.min(correction[0], correctionRatio), correctionRatioInverse);\r\n        correction[1] = Math.max(Math.min(correction[1], correctionRatio), correctionRatioInverse);\r\n        this.barSpaceRatio = correction;\r\n        for (i = 0; i < counter.length; i++) {\r\n            counter[i] *= this.barSpaceRatio[i % 2];\r\n        }\r\n    }\r\n    return BarcodeReader.prototype._matchPattern.call(this, counter, code);\r\n};\r\n\r\nI2of5Reader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder) {\r\n    var counter = [],\r\n        self = this,\r\n        i,\r\n        counterPos = 0,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: 0,\r\n            end: 0\r\n        },\r\n        error,\r\n        j,\r\n        sum,\r\n        normalized,\r\n        epsilon = self.AVG_CODE_ERROR;\r\n\r\n    isWhite = isWhite || false;\r\n    tryHarder = tryHarder || false;\r\n\r\n    if (!offset) {\r\n        offset = self._nextSet(self._row);\r\n    }\r\n\r\n    for ( i = 0; i < pattern.length; i++) {\r\n        counter[i] = 0;\r\n    }\r\n\r\n    for ( i = offset; i < self._row.length; i++) {\r\n        if (self._row[i] ^ isWhite) {\r\n            counter[counterPos]++;\r\n        } else {\r\n            if (counterPos === counter.length - 1) {\r\n                sum = 0;\r\n                for ( j = 0; j < counter.length; j++) {\r\n                    sum += counter[j];\r\n                }\r\n                error = self._matchPattern(counter, pattern);\r\n                if (error < epsilon) {\r\n                    bestMatch.error = error;\r\n                    bestMatch.start = i - sum;\r\n                    bestMatch.end = i;\r\n                    return bestMatch;\r\n                }\r\n                if (tryHarder) {\r\n                    for (j = 0; j < counter.length - 2; j++) {\r\n                        counter[j] = counter[j + 2];\r\n                    }\r\n                    counter[counter.length - 2] = 0;\r\n                    counter[counter.length - 1] = 0;\r\n                    counterPos--;\r\n                } else {\r\n                    return null;\r\n                }\r\n            } else {\r\n                counterPos++;\r\n            }\r\n            counter[counterPos] = 1;\r\n            isWhite = !isWhite;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nI2of5Reader.prototype._findStart = function() {\r\n    var self = this,\r\n        leadingWhitespaceStart,\r\n        offset = self._nextSet(self._row),\r\n        startInfo,\r\n        narrowBarWidth = 1;\r\n\r\n    while (!startInfo) {\r\n        startInfo = self._findPattern(self.START_PATTERN, offset, false, true);\r\n        if (!startInfo) {\r\n            return null;\r\n        }\r\n        narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / 4);\r\n        leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10;\r\n        if (leadingWhitespaceStart >= 0) {\r\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\r\n                return startInfo;\r\n            }\r\n        }\r\n        offset = startInfo.end;\r\n        startInfo = null;\r\n    }\r\n};\r\n\r\nI2of5Reader.prototype._verifyTrailingWhitespace = function(endInfo) {\r\n    var self = this,\r\n        trailingWhitespaceEnd;\r\n\r\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\r\n    if (trailingWhitespaceEnd < self._row.length) {\r\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\r\n            return endInfo;\r\n        }\r\n    }\r\n    return null;\r\n};\r\n\r\nI2of5Reader.prototype._findEnd = function() {\r\n    var self = this,\r\n        endInfo,\r\n        tmp;\r\n\r\n    self._row.reverse();\r\n    endInfo = self._findPattern(self.STOP_PATTERN);\r\n    self._row.reverse();\r\n\r\n    if (endInfo === null) {\r\n        return null;\r\n    }\r\n\r\n    // reverse numbers\r\n    tmp = endInfo.start;\r\n    endInfo.start = self._row.length - endInfo.end;\r\n    endInfo.end = self._row.length - tmp;\r\n\r\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\r\n};\r\n\r\nI2of5Reader.prototype._decodePair = function(counterPair) {\r\n    var i,\r\n        code,\r\n        codes = [],\r\n        self = this;\r\n\r\n    for (i = 0; i < counterPair.length; i++) {\r\n        code = self._decodeCode(counterPair[i]);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        codes.push(code);\r\n    }\r\n    return codes;\r\n};\r\n\r\nI2of5Reader.prototype._decodeCode = function(counter) {\r\n    var j,\r\n        self = this,\r\n        sum = 0,\r\n        normalized,\r\n        error,\r\n        epsilon = self.AVG_CODE_ERROR,\r\n        code,\r\n        bestMatch = {\r\n            error: Number.MAX_VALUE,\r\n            code: -1,\r\n            start: 0,\r\n            end: 0\r\n        };\r\n\r\n    for ( j = 0; j < counter.length; j++) {\r\n        sum += counter[j];\r\n    }\r\n    for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n        error = self._matchPattern(counter, self.CODE_PATTERN[code]);\r\n        if (error < bestMatch.error) {\r\n            bestMatch.code = code;\r\n            bestMatch.error = error;\r\n        }\r\n    }\r\n    if (bestMatch.error < epsilon) {\r\n        return bestMatch;\r\n    }\r\n};\r\n\r\nI2of5Reader.prototype._decodePayload = function(counters, result, decodedCodes) {\r\n    var i,\r\n        self = this,\r\n        pos = 0,\r\n        counterLength = counters.length,\r\n        counterPair = [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0]],\r\n        codes;\r\n\r\n    while (pos < counterLength) {\r\n        for (i = 0; i < 5; i++) {\r\n            counterPair[0][i] = counters[pos] * this.barSpaceRatio[0];\r\n            counterPair[1][i] = counters[pos + 1] * this.barSpaceRatio[1];\r\n            pos += 2;\r\n        }\r\n        codes = self._decodePair(counterPair);\r\n        if (!codes) {\r\n            return null;\r\n        }\r\n        for (i = 0; i < codes.length; i++) {\r\n            result.push(codes[i].code + \"\");\r\n            decodedCodes.push(codes[i]);\r\n        }\r\n    }\r\n    return codes;\r\n};\r\n\r\nI2of5Reader.prototype._verifyCounterLength = function(counters) {\r\n    return (counters.length % 10 === 0);\r\n};\r\n\r\nI2of5Reader.prototype._decode = function() {\r\n    var startInfo,\r\n        endInfo,\r\n        self = this,\r\n        code,\r\n        result = [],\r\n        decodedCodes = [],\r\n        counters;\r\n\r\n    startInfo = self._findStart();\r\n    if (!startInfo) {\r\n        return null;\r\n    }\r\n    decodedCodes.push(startInfo);\r\n\r\n    endInfo = self._findEnd();\r\n    if (!endInfo) {\r\n        return null;\r\n    }\r\n\r\n    counters = self._fillCounters(startInfo.end, endInfo.start, false);\r\n    if (!self._verifyCounterLength(counters)) {\r\n        return null;\r\n    }\r\n    code = self._decodePayload(counters, result, decodedCodes);\r\n    if (!code) {\r\n        return null;\r\n    }\r\n    if (result.length % 2 !== 0 ||\r\n            result.length < 6) {\r\n        return null;\r\n    }\r\n\r\n    decodedCodes.push(endInfo);\r\n    return {\r\n        code: result.join(\"\"),\r\n        start: startInfo.start,\r\n        end: endInfo.end,\r\n        startInfo: startInfo,\r\n        decodedCodes: decodedCodes\r\n    };\r\n};\r\n\r\nI2of5Reader.CONFIG_KEYS = {\r\n    normalizeBarSpaceWidth: {\r\n        'type': 'boolean',\r\n        'default': false,\r\n        'description': 'If true, the reader tries to normalize the' +\r\n        'width-difference between bars and spaces'\r\n    }\r\n};\r\n\r\nexport default I2of5Reader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/i2of5_reader.js","import EANReader from './ean_reader';\r\n\r\nfunction UPCEReader(opts, supplements) {\r\n    EANReader.call(this, opts, supplements);\r\n}\r\n\r\nvar properties = {\r\n    CODE_FREQUENCY: {value: [\r\n        [ 56, 52, 50, 49, 44, 38, 35, 42, 41, 37 ],\r\n        [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]]},\r\n    STOP_PATTERN: { value: [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7]},\r\n    FORMAT: {value: \"upc_e\", writeable: false}\r\n};\r\n\r\nUPCEReader.prototype = Object.create(EANReader.prototype, properties);\r\nUPCEReader.prototype.constructor = UPCEReader;\r\n\r\nUPCEReader.prototype._decodePayload = function(code, result, decodedCodes) {\r\n    var i,\r\n        self = this,\r\n        codeFrequency = 0x0;\r\n\r\n    for ( i = 0; i < 6; i++) {\r\n        code = self._decodeCode(code.end);\r\n        if (!code) {\r\n            return null;\r\n        }\r\n        if (code.code >= self.CODE_G_START) {\r\n            code.code = code.code - self.CODE_G_START;\r\n            codeFrequency |= 1 << (5 - i);\r\n        }\r\n        result.push(code.code);\r\n        decodedCodes.push(code);\r\n    }\r\n    if (!self._determineParity(codeFrequency, result)) {\r\n        return null;\r\n    }\r\n\r\n    return code;\r\n};\r\n\r\nUPCEReader.prototype._determineParity = function(codeFrequency, result) {\r\n    var i,\r\n        nrSystem;\r\n\r\n    for (nrSystem = 0; nrSystem < this.CODE_FREQUENCY.length; nrSystem++){\r\n        for ( i = 0; i < this.CODE_FREQUENCY[nrSystem].length; i++) {\r\n            if (codeFrequency === this.CODE_FREQUENCY[nrSystem][i]) {\r\n                result.unshift(nrSystem);\r\n                result.push(i);\r\n                return true;\r\n            }\r\n        }\r\n    }\r\n    return false;\r\n};\r\n\r\nUPCEReader.prototype._convertToUPCA = function(result) {\r\n    var upca = [result[0]],\r\n        lastDigit = result[result.length - 2];\r\n\r\n    if (lastDigit <= 2) {\r\n        upca = upca.concat(result.slice(1, 3))\r\n            .concat([lastDigit, 0, 0, 0, 0])\r\n            .concat(result.slice(3, 6));\r\n    } else if (lastDigit === 3) {\r\n        upca = upca.concat(result.slice(1, 4))\r\n            .concat([0, 0, 0, 0, 0])\r\n            .concat(result.slice(4, 6));\r\n    } else if (lastDigit === 4) {\r\n        upca = upca.concat(result.slice(1, 5))\r\n            .concat([0, 0, 0, 0, 0, result[5]]);\r\n    } else {\r\n        upca = upca.concat(result.slice(1, 6))\r\n            .concat([0, 0, 0, 0, lastDigit]);\r\n    }\r\n\r\n    upca.push(result[result.length - 1]);\r\n    return upca;\r\n};\r\n\r\nUPCEReader.prototype._checksum = function(result) {\r\n    return EANReader.prototype._checksum.call(this, this._convertToUPCA(result));\r\n};\r\n\r\nUPCEReader.prototype._findEnd = function(offset, isWhite) {\r\n    isWhite = true;\r\n    return EANReader.prototype._findEnd.call(this, offset, isWhite);\r\n};\r\n\r\nUPCEReader.prototype._verifyTrailingWhitespace = function(endInfo) {\r\n    var self = this,\r\n        trailingWhitespaceEnd;\r\n\r\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\r\n    if (trailingWhitespaceEnd < self._row.length) {\r\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\r\n            return endInfo;\r\n        }\r\n    }\r\n};\r\n\r\nexport default UPCEReader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/upc_e_reader.js","import EANReader from './ean_reader';\r\n\r\nfunction UPCReader(opts, supplements) {\r\n    EANReader.call(this, opts, supplements);\r\n}\r\n\r\nvar properties = {\r\n    FORMAT: {value: \"upc_a\", writeable: false}\r\n};\r\n\r\nUPCReader.prototype = Object.create(EANReader.prototype, properties);\r\nUPCReader.prototype.constructor = UPCReader;\r\n\r\nUPCReader.prototype._decode = function() {\r\n    var result = EANReader.prototype._decode.call(this);\r\n\r\n    if (result && result.code && result.code.length === 13 && result.code.charAt(0) === \"0\") {\r\n        result.code = result.code.substring(1);\r\n        return result;\r\n    }\r\n    return null;\r\n};\r\n\r\nexport default UPCReader;\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/upc_reader.js","module.exports = copy\n\n/**\n * Copy the values from one mat2 to another\n *\n * @alias mat2.copy\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nfunction 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\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/copy.js\n// module id = 77\n// module chunks = 0","module.exports = create\n\n/**\n * Creates a new identity mat2\n *\n * @alias mat2.create\n * @returns {mat2} a new 2x2 matrix\n */\nfunction create() {\n  var out = new Float32Array(4)\n  out[0] = 1\n  out[1] = 0\n  out[2] = 0\n  out[3] = 1\n  return out\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/create.js\n// module id = 78\n// module chunks = 0","module.exports = invert\n\n/**\n * Inverts a mat2\n *\n * @alias mat2.invert\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nfunction invert(out, a) {\n  var a0 = a[0]\n  var a1 = a[1]\n  var a2 = a[2]\n  var a3 = a[3]\n  var det = a0 * a3 - a2 * a1\n\n  if (!det) return null\n  det = 1.0 / det\n\n  out[0] =  a3 * det\n  out[1] = -a1 * det\n  out[2] = -a2 * det\n  out[3] =  a0 * det\n\n  return out\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/invert.js\n// module id = 79\n// module chunks = 0","module.exports = scale\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nfunction scale(out, a, b) {\n    out[0] = a[0] * b\n    out[1] = a[1] * b\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/scale.js\n// module id = 80\n// module chunks = 0","module.exports = transformMat2\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nfunction 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//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/transformMat2.js\n// module id = 81\n// module chunks = 0","module.exports = clone;\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {vec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nfunction clone(a) {\n    var out = new Float32Array(3)\n    out[0] = a[0]\n    out[1] = a[1]\n    out[2] = a[2]\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec3/clone.js\n// module id = 82\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Hash.js\n// module id = 83\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Stack.js\n// module id = 84\n// module chunks = 0","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Uint8Array.js\n// module id = 85\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_apply.js\n// module id = 86\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayLikeKeys.js\n// module id = 87\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayMap.js\n// module id = 88\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayPush.js\n// module id = 89\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseCreate.js\n// module id = 90\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseFlatten.js\n// module id = 91\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseFor.js\n// module id = 92\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseGet.js\n// module id = 93\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseHasIn.js\n// module id = 94\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsArguments.js\n// module id = 95\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsNative.js\n// module id = 96\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsTypedArray.js\n// module id = 97\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseKeysIn.js\n// module id = 98\n// module chunks = 0","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    if (isObject(srcValue)) {\n      stack || (stack = new Stack);\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseMerge.js\n// module id = 99\n// module chunks = 0","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) || (srcIndex && 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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseMergeDeep.js\n// module id = 100\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_basePick.js\n// module id = 101\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_basePickBy.js\n// module id = 102\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseRest.js\n// module id = 103\n// module chunks = 0","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 (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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseSet.js\n// module id = 104\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseSetToString.js\n// module id = 105\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseTimes.js\n// module id = 106\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseToString.js\n// module id = 107\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseUnary.js\n// module id = 108\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneArrayBuffer.js\n// module id = 109\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneBuffer.js\n// module id = 110\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneTypedArray.js\n// module id = 111\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_copyArray.js\n// module id = 112\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_copyObject.js\n// module id = 113\n// module chunks = 0","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_coreJsData.js\n// module id = 114\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_createAssigner.js\n// module id = 115\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_createBaseFor.js\n// module id = 116\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_flatRest.js\n// module id = 117\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getRawTag.js\n// module id = 118\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getValue.js\n// module id = 119\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hasPath.js\n// module id = 120\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashClear.js\n// module id = 121\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashDelete.js\n// module id = 122\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashGet.js\n// module id = 123\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashHas.js\n// module id = 124\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashSet.js\n// module id = 125\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_initCloneObject.js\n// module id = 126\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isFlattenable.js\n// module id = 127\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isIterateeCall.js\n// module id = 128\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isKey.js\n// module id = 129\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isKeyable.js\n// module id = 130\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isMasked.js\n// module id = 131\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheClear.js\n// module id = 132\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheDelete.js\n// module id = 133\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheGet.js\n// module id = 134\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheHas.js\n// module id = 135\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheSet.js\n// module id = 136\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheClear.js\n// module id = 137\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheDelete.js\n// module id = 138\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheGet.js\n// module id = 139\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheHas.js\n// module id = 140\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheSet.js\n// module id = 141\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_memoizeCapped.js\n// module id = 142\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nativeKeysIn.js\n// module id = 143\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nodeUtil.js\n// module id = 144\n// module chunks = 0","/** 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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_objectToString.js\n// module id = 145\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_overArg.js\n// module id = 146\n// module chunks = 0","/** 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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_shortOut.js\n// module id = 147\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackClear.js\n// module id = 148\n// module chunks = 0","/**\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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackDelete.js\n// module id = 149\n// module chunks = 0","/**\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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackGet.js\n// module id = 150\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackHas.js\n// module id = 151\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackSet.js\n// module id = 152\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stringToPath.js\n// module id = 153\n// module chunks = 0","/** 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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_toSource.js\n// module id = 154\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/constant.js\n// module id = 155\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/flatten.js\n// module id = 156\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/hasIn.js\n// module id = 157\n// module chunks = 0","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\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArrayLikeObject.js\n// module id = 158\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isPlainObject.js\n// module id = 159\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/memoize.js\n// module id = 160\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/pick.js\n// module id = 161\n// module chunks = 0","/**\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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/stubFalse.js\n// module id = 162\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/toPlainObject.js\n// module id = 163\n// module chunks = 0","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\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/toString.js\n// module id = 164\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_165__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"get-pixels\"\n// module id = 165\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_166__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"ndarray\"\n// module id = 166\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_167__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"ndarray-linear-interpolate\"\n// module id = 167\n// module chunks = 0"],"sourceRoot":""}