From 317abd34c1c207fcc902956705c70ec4b3e0636e Mon Sep 17 00:00:00 2001 From: Christoph Oberhofer Date: Thu, 31 Mar 2016 21:53:30 +0200 Subject: [PATCH] updated builds to 0.10.0 --- dist/quagga.js | 20109 +++++++++++++++++++++---------------------- dist/quagga.min.js | 6 +- lib/quagga.js | 15843 ++++++++++++++++++++++------------ 3 files changed, 19923 insertions(+), 16035 deletions(-) diff --git a/dist/quagga.js b/dist/quagga.js index fae3fde7..fb4e4553 100644 --- a/dist/quagga.js +++ b/dist/quagga.js @@ -1,10 +1,10 @@ (function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') - module.exports = factory(factory.toString()); + module.exports = factory(factory.toString()).default; else if(typeof exports === 'object') - exports["Quagga"] = factory(factory.toString()); + exports["Quagga"] = factory(factory.toString()).default; else - root["Quagga"] = factory(factory.toString()); + root["Quagga"] = factory(factory.toString()).default; })(this, function(__factorySource__) { return /******/ (function(modules) { // webpackBootstrap /******/ // The module cache @@ -15,23 +15,23 @@ return /******/ (function(modules) { // webpackBootstrap /******/ /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) -/******/ return installedModules[moduleId].exports; +/******/ return installedModules[moduleId].e; /******/ /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { -/******/ exports: {}, -/******/ id: moduleId, -/******/ loaded: false +/******/ e: {}, +/******/ i: moduleId, +/******/ l: false /******/ }; /******/ /******/ // Execute the module function -/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ modules[moduleId].call(module.e, module, module.e, __webpack_require__); /******/ /******/ // Flag the module as loaded -/******/ module.loaded = true; +/******/ module.l = true; /******/ /******/ // Return the exports of the module -/******/ return module.exports; +/******/ return module.e; /******/ } /******/ /******/ @@ -45,1126 +45,1173 @@ return /******/ (function(modules) { // webpackBootstrap /******/ __webpack_require__.p = "/"; /******/ /******/ // Load entry module and return exports -/******/ return __webpack_require__(0); +/******/ return __webpack_require__(__webpack_require__.s = 154); /******/ }) /************************************************************************/ /******/ ([ /* 0 */ /***/ function(module, exports, __webpack_require__) { - module.exports = __webpack_require__(1); - - -/***/ }, -/* 1 */ -/***/ function(module, exports, __webpack_require__) { - + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ 'use strict'; - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _commonTypedefs = __webpack_require__(2); + var logDisabled_ = false; - var _commonTypedefs2 = _interopRequireDefault(_commonTypedefs); - - // eslint-disable-line no-unused-vars - - var _commonImage_wrapper = __webpack_require__(3); + // Utility methods. + var utils = { + disableLog: function(bool) { + if (typeof bool !== 'boolean') { + return new Error('Argument type: ' + typeof bool + + '. Please use a boolean.'); + } + logDisabled_ = bool; + return (bool) ? 'adapter.js logging disabled' : + 'adapter.js logging enabled'; + }, - var _commonImage_wrapper2 = _interopRequireDefault(_commonImage_wrapper); + log: function() { + if (typeof window === 'object') { + if (logDisabled_) { + return; + } + console.log.apply(console, arguments); + } + }, + + /** + * Extract browser version out of the provided user agent string. + * @param {!string} uastring userAgent string. + * @param {!string} expr Regular expression used as match criteria. + * @param {!number} pos position in the version string to be returned. + * @return {!number} browser version. + */ + extractVersion: function(uastring, expr, pos) { + var match = uastring.match(expr); + return match && match.length >= pos && parseInt(match[pos], 10); + }, + + /** + * Browser detector. + * @return {object} result containing browser, version and minVersion + * properties. + */ + detectBrowser: function() { + // Returned result object. + var result = {}; + result.browser = null; + result.version = null; + result.minVersion = null; + + if (typeof window === 'undefined' || !window.navigator) { + result.browser = 'Not a browser.'; + return result; + } else if (navigator.mozGetUserMedia) { + // Firefox. + result.browser = 'firefox'; + result.version = this.extractVersion(navigator.userAgent, + /Firefox\/([0-9]+)\./, 1); + result.minVersion = 31; + } else if (navigator.webkitGetUserMedia && window.webkitRTCPeerConnection) { + // Chrome, Chromium, WebView, Opera and other WebKit browsers. + result.browser = 'chrome'; + result.version = this.extractVersion(navigator.userAgent, + /Chrom(e|ium)\/([0-9]+)\./, 2); + result.minVersion = 38; + } else if(navigator.mediaDevices && + navigator.userAgent.match(/Edge\/(\d+).(\d+)$/)) { + // Edge. + result.browser = 'edge'; + result.version = this.extractVersion(navigator.userAgent, + /Edge\/(\d+).(\d+)$/, 2); + result.minVersion = 10547; + } else { + result.browser = 'Not a supported browser.'; + return result; + } - var _locatorBarcode_locator = __webpack_require__(18); + // Warn if version is less than minVersion. + if (result.version < result.minVersion) { + utils.log('Browser: ' + result.browser + ' Version: ' + result.version + + ' < minimum supported version: ' + result.minVersion + + '\n some things might not work!'); + } - var _locatorBarcode_locator2 = _interopRequireDefault(_locatorBarcode_locator); + return result; + } + }; - var _decoderBarcode_decoder = __webpack_require__(23); + // Export. + module.e = { + log: utils.log, + disableLog: utils.disableLog, + browserDetails: utils.detectBrowser(), + extractVersion: utils.extractVersion + }; + + +/***/ }, +/* 1 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(module, global) {var checkGlobal = __webpack_require__(104); - var _decoderBarcode_decoder2 = _interopRequireDefault(_decoderBarcode_decoder); + /** Used to determine if values are of the language type `Object`. */ + var objectTypes = { + 'function': true, + 'object': true + }; - var _commonEvents = __webpack_require__(68); + /** Detect free variable `exports`. */ + var freeExports = (objectTypes[typeof exports] && exports && !exports.nodeType) + ? exports + : undefined; - var _commonEvents2 = _interopRequireDefault(_commonEvents); + /** Detect free variable `module`. */ + var freeModule = (objectTypes[typeof module] && module && !module.nodeType) + ? module + : undefined; - var _inputCamera_access = __webpack_require__(69); + /** Detect free variable `global` from Node.js. */ + var freeGlobal = checkGlobal(freeExports && freeModule && typeof global == 'object' && global); - var _inputCamera_access2 = _interopRequireDefault(_inputCamera_access); + /** Detect free variable `self`. */ + var freeSelf = checkGlobal(objectTypes[typeof self] && self); - var _commonImage_debug = __webpack_require__(19); + /** Detect free variable `window`. */ + var freeWindow = checkGlobal(objectTypes[typeof window] && window); - var _commonImage_debug2 = _interopRequireDefault(_commonImage_debug); + /** Detect `this` as the global object. */ + var thisGlobal = checkGlobal(objectTypes[typeof this] && this); - var _glMatrix = __webpack_require__(7); + /** + * Used as a reference to the global object. + * + * The `this` value is used if it's the global object to avoid Greasemonkey's + * restricted `window` object, otherwise the `window` object is used. + */ + var root = freeGlobal || + ((freeWindow !== (thisGlobal && thisGlobal.window)) && freeWindow) || + freeSelf || thisGlobal || Function('return this')(); - var _analyticsResult_collector = __webpack_require__(70); + module.e = root; - var _analyticsResult_collector2 = _interopRequireDefault(_analyticsResult_collector); + /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(48)(module), (function() { return this; }()))) + +/***/ }, +/* 2 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. + * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @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 && (type == 'object' || type == 'function'); + } - var _configConfig = __webpack_require__(71); + module.e = isObject; + + +/***/ }, +/* 3 */ +/***/ function(module, exports, __webpack_require__) { + + var getNative = __webpack_require__(12), + root = __webpack_require__(1); - var _configConfig2 = _interopRequireDefault(_configConfig); + /* Built-in method references that are verified to be native. */ + var Map = getNative(root, 'Map'); - var _input_stream = __webpack_require__(73); + module.e = Map; + + +/***/ }, +/* 4 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @type {Function} + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ + var isArray = Array.isArray; - var _input_stream2 = _interopRequireDefault(_input_stream); + module.e = isArray; + + +/***/ }, +/* 5 */ +/***/ function(module, exports, __webpack_require__) { + + function BarcodeReader(config) { + this._row = []; + this.config = config || {}; + return this; + } - var _frame_grabber = __webpack_require__(75); + BarcodeReader.prototype._nextUnset = function (line, start) { + var i; - var _frame_grabber2 = _interopRequireDefault(_frame_grabber); + if (start === undefined) { + start = 0; + } + for (i = start; i < line.length; i++) { + if (!line[i]) { + return i; + } + } + return line.length; + }; - var merge = __webpack_require__(35); + BarcodeReader.prototype._matchPattern = function (counter, code) { + var i, + error = 0, + singleError = 0, + modulo = this.MODULO, + maxSingleError = this.SINGLE_CODE_ERROR || 1; - var _inputStream, - _framegrabber, - _stopped, - _canvasContainer = { - ctx: { - image: null, - overlay: null - }, - dom: { - image: null, - overlay: null + for (i = 0; i < counter.length; i++) { + singleError = Math.abs(code[i] - counter[i]); + if (singleError > maxSingleError) { + return Number.MAX_VALUE; + } + error += singleError; } - }, - _inputImageWrapper, - _boxSize, - _decoder, - _workerPool = [], - _onUIThread = true, - _resultCollector, - _config = {}; + return error / modulo; + }; - function initializeData(imageWrapper) { - initBuffers(imageWrapper); - _decoder = _decoderBarcode_decoder2['default'].create(_config.decoder, _inputImageWrapper); - } + BarcodeReader.prototype._nextSet = function (line, offset) { + var i; - 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); - } + offset = offset || 0; + for (i = offset; i < line.length; i++) { + if (line[i]) { + return i; } - _inputStream = _input_stream2['default'].createLiveStream(video); - _inputCamera_access2['default'].request(video, _config.inputStream.constraints, function (err) { - if (!err) { - _inputStream.trigger("canrecord"); - } else { - return cb(err); - } - }); } + return line.length; + }; - _inputStream.setAttribute("preload", "auto"); - _inputStream.setAttribute("autoplay", true); - _inputStream.setInputStream(_config.inputStream); - _inputStream.addEventListener("canrecord", canRecord.bind(undefined, cb)); - } + BarcodeReader.prototype._normalize = function (counter, modulo) { + var i, + self = this, + sum = 0, + ratio, + numOnes = 0, + normalized = [], + norm = 0; - function getViewPort() { - var target = _config.inputStream.target; - // Check if target is already a DOM element - if (target && target.nodeName && target.nodeType === 1) { - return target; + if (!modulo) { + modulo = self.MODULO; + } + for (i = 0; i < counter.length; i++) { + if (counter[i] === 1) { + numOnes++; + } else { + sum += counter[i]; + } + } + ratio = sum / (modulo - numOnes); + if (ratio > 1.0) { + for (i = 0; i < counter.length; i++) { + norm = counter[i] === 1 ? counter[i] : counter[i] / ratio; + normalized.push(norm); + } } else { - // Use '#interactive.viewport' as a fallback selector (backwards compatibility) - var selector = typeof target === 'string' ? target : '#interactive.viewport'; - return document.querySelector(selector); + ratio = (sum + numOnes) / modulo; + for (i = 0; i < counter.length; i++) { + norm = counter[i] / ratio; + normalized.push(norm); + } } - } + return normalized; + }; - function canRecord(cb) { - _locatorBarcode_locator2['default'].checkImageConstraints(_inputStream, _config.locator); - initCanvas(_config); - _framegrabber = _frame_grabber2['default'].create(_inputStream, _canvasContainer.dom.image); + 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; - adjustWorkerPool(_config.numOfWorkers, function () { - if (_config.numOfWorkers === 0) { - initializeData(); + if (cmpCounter) { + for (i = 0; i < cmpCounter.length; i++) { + counter.push(0); } - ready(cb); - }); - } + 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); - 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); + 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; } } - _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); + } 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; } } - _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 _commonImage_wrapper2['default']({ - x: _inputStream.getWidth(), - y: _inputStream.getHeight() - }); - } + // if cmpCounter was not given + bestMatch.start = offset; + bestMatch.end = self._row.length - 1; + bestMatch.counter = counter; + return bestMatch; + }; - if (true) { - console.log(_inputImageWrapper.size); - } - _boxSize = [_glMatrix.vec2.clone([0, 0]), _glMatrix.vec2.clone([0, _inputImageWrapper.size.y]), _glMatrix.vec2.clone([_inputImageWrapper.size.x, _inputImageWrapper.size.y]), _glMatrix.vec2.clone([_inputImageWrapper.size.x, 0])]; - _locatorBarcode_locator2['default'].init(_inputImageWrapper, _config.locator); - } + BarcodeReader.prototype.decodePattern = function (pattern) { + var self = this, + result; - function getBoundingBoxes() { - if (_config.locate) { - return _locatorBarcode_locator2['default'].locate(); + 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 { - return [[_glMatrix.vec2.clone(_boxSize[0]), _glMatrix.vec2.clone(_boxSize[1]), _glMatrix.vec2.clone(_boxSize[2]), _glMatrix.vec2.clone(_boxSize[3])]]; + result.direction = BarcodeReader.DIRECTION.FORWARD; } - } - - function transformResult(result) { - var topRight = _inputStream.getTopRight(), - xOffset = topRight.x, - yOffset = topRight.y, - i; - - if (xOffset === 0 && yOffset === 0) { - return; + if (result) { + result.format = self.FORMAT; } + return result; + }; - if (result.barcodes) { - for (i = 0; i < result.barcodes.length; i++) { - transformResult(result.barcodes[i]); + 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; + }; - if (result.line && result.line.length === 2) { - moveLine(result.line); - } + BarcodeReader.prototype._fillCounters = function (offset, end, isWhite) { + var self = this, + counterPos = 0, + i, + counters = []; - if (result.box) { - moveBox(result.box); - } + isWhite = typeof isWhite !== 'undefined' ? isWhite : true; + offset = typeof offset !== 'undefined' ? offset : self._nextUnset(self._row); + end = end || self._row.length; - if (result.boxes && result.boxes.length > 0) { - for (i = 0; i < result.boxes.length; i++) { - moveBox(result.boxes[i]); + 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; + }; - function moveBox(box) { - var corner = box.length; + Object.defineProperty(BarcodeReader.prototype, "FORMAT", { + value: 'unknown', + writeable: false + }); - while (corner--) { - box[corner][0] += xOffset; - box[corner][1] += yOffset; - } - } + BarcodeReader.DIRECTION = { + FORWARD: 1, + REVERSE: -1 + }; - function moveLine(line) { - line[0].x += xOffset; - line[0].y += yOffset; - line[1].x += xOffset; - line[1].y += yOffset; - } - } + BarcodeReader.Exception = { + StartNotFoundException: "Start-Info was not found!", + CodeNotFoundException: "Code could not be found!", + PatternNotFoundException: "Pattern could not be found!" + }; - function addResult(result, imageData) { - if (!imageData || !_resultCollector) { - return; - } + BarcodeReader.CONFIG_KEYS = {}; - 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); - } - } + /* harmony default export */ exports["a"] = BarcodeReader; + +/***/ }, +/* 6 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = clone - function hasCodeResult(result) { - return result && (result.barcodes ? result.barcodes.some(function (barcode) { - return barcode.codeResult; - }) : result.codeResult); + /** + * 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 } - - function publishResult(result, imageData) { - var resultToPublish = result && (result.barcodes || result); - - if (result && _onUIThread) { - transformResult(result); - addResult(result, imageData); - } - - _commonEvents2['default'].publish("processed", resultToPublish); - if (hasCodeResult(result)) { - _commonEvents2['default'].publish("detected", resultToPublish); - } + +/***/ }, +/* 7 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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 _ + * @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 && typeof value == 'object'; } - function locateAndDecode() { - var result, boxes; + module.e = isObjectLike; + + +/***/ }, +/* 8 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony default export */ exports["a"] = { + init: function init(arr, val) { + var l = arr.length; + while (l--) { + arr[l] = val; + } + }, - boxes = getBoundingBoxes(); - if (boxes) { - result = _decoder.decodeFromBoundingBoxes(boxes); - result = result || {}; - result.boxes = boxes; - publishResult(result, _inputImageWrapper.data); - } else { - publishResult(); - } - } - - function update() { - var availableWorker; + /** + * 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; + }, - 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(); + 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(",") + "]"; } - } else { - locateAndDecode(); - } - } - - function startContinuousUpdate() { - var next = null, - delay = 1000 / (_config.frequency || 60); + return "[" + rows.join(",\r\n") + "]"; + }, - _stopped = false; - (function frame(timestamp) { - next = next || timestamp; - if (!_stopped) { - if (timestamp >= next) { - next += delay; - update(); + /** + * 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]); } - 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); + return queue; + }, - workerThread.worker.onmessage = function (e) { - if (e.data.event === 'initialized') { - URL.revokeObjectURL(blobURL); - workerThread.busy = false; - workerThread.imageData = new Uint8Array(e.data.imageData); - if (true) { - console.log("Worker initialized"); + maxIndex: function maxIndex(arr) { + var i, + max = 0; + for (i = 0; i < arr.length; i++) { + if (arr[i] > arr[max]) { + max = i; } - 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 (true) { - console.log("Worker error: " + e.data.message); + } + 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; + }, - workerThread.worker.postMessage({ - cmd: 'init', - size: { x: _inputStream.getWidth(), y: _inputStream.getHeight() }, - imageData: workerThread.imageData, - config: _config - }, [workerThread.imageData.buffer]); - } + sum: function sum(arr) { + var length = arr.length, + sum = 0; - function workerInterface(factory) { - /* eslint-disable no-undef*/ - if (factory) { - var Quagga = factory(); - if (!Quagga) { - self.postMessage({ 'event': 'error', message: 'Quagga could not be created' }); - return; + while (length--) { + sum += arr[length]; } + return sum; } - 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); + }; + +/***/ }, +/* 9 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony default export */ exports["a"] = { + 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; - function onProcessed(result) { - self.postMessage({ - 'event': 'processed', - imageData: imageWrapper.data, - result: result - }, [imageWrapper.data.buffer]); + 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__) { + + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__barcode_reader__ = __webpack_require__(5); - function ready() { - // eslint-disable-line - self.postMessage({ 'event': 'initialized', imageData: imageWrapper.data }, [imageWrapper.data.buffer]); - } - /* eslint-enable */ + function EANReader(opts) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].call(this, opts); } - function generateWorkerBlob() { - var blob, factorySource; - - /* jshint ignore:start */ - if (typeof __factorySource__ !== 'undefined') { - factorySource = __factorySource__; // eslint-disable-line no-undef - } - /* jshint ignore:end */ + var properties = { + CODE_L_START: { value: 0 }, + MODULO: { value: 7 }, + CODE_G_START: { value: 10 }, + START_PATTERN: { value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7] }, + STOP_PATTERN: { value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7] }, + MIDDLE_PATTERN: { value: [1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7] }, + 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.67 }, + AVG_CODE_ERROR: { value: 0.27 }, + FORMAT: { value: "ean_13", writeable: false } + }; - blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'], { type: 'text/javascript' }); + EANReader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].prototype, properties); + EANReader.prototype.constructor = EANReader; - return window.URL.createObjectURL(blob); - } + 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, + normalized; - 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 }); - }); + if (!coderange) { + coderange = self.CODE_PATTERN.length; } - } - 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 (true) { - 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 (i = offset; i < self._row.length; i++) { + if (self._row[i] ^ isWhite) { + counter[counterPos]++; + } else { + if (counterPos === counter.length - 1) { + normalized = self._normalize(counter); + if (normalized) { + for (code = 0; code < coderange; code++) { + error = self._matchPattern(normalized, 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++; } - }; - - for (var i = 0; i < increaseBy; i++) { - initWorker(workerInitialized); + counter[counterPos] = 1; + isWhite = !isWhite; } } - } + return null; + }; - exports['default'] = { - init: function init(config, cb, imageWrapper) { - _config = merge({}, _configConfig2['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") { - _inputCamera_access2['default'].release(); - _inputStream.clearEventHandlers(); - } - }, - pause: function pause() { - _stopped = true; - }, - onDetected: function onDetected(callback) { - _commonEvents2['default'].subscribe("detected", callback); - }, - offDetected: function offDetected(callback) { - _commonEvents2['default'].unsubscribe("detected", callback); - }, - onProcessed: function onProcessed(callback) { - _commonEvents2['default'].subscribe("processed", callback); - }, - offProcessed: function offProcessed(callback) { - _commonEvents2['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) { - config = merge({ - inputStream: { - type: "ImageStream", - sequence: false, - size: 800, - src: config.src - }, - numOfWorkers: (true) && config.debug ? 0 : 1, - locator: { - halfSample: false - } - }, config); - this.init(config, function () { - _commonEvents2['default'].once("processed", function (result) { - _stopped = true; - resultCallback.call(null, result); - }, true); - _start(); - }); + 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 }, - ImageWrapper: _commonImage_wrapper2['default'], - ImageDebug: _commonImage_debug2['default'], - ResultCollector: _analyticsResult_collector2['default'] - }; - module.exports = exports['default']; - -/***/ }, -/* 2 */ -/***/ function(module, exports) { - - /* - * typedefs.js - * Normalizes browser-specific prefixes - */ + error, + j, + sum, + normalized; - 'use strict'; + if (!offset) { + offset = self._nextSet(self._row); + } - 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); - }; - })(); + if (isWhite === undefined) { + isWhite = false; + } - navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia; - window.URL = window.URL || window.webkitURL || window.mozURL || window.msURL; - } - 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; - }; - -/***/ }, -/* 3 */ -/***/ function(module, exports, __webpack_require__) { - - 'use strict'; + if (tryHarder === undefined) { + tryHarder = true; + } - Object.defineProperty(exports, '__esModule', { - value: true - }); + if (epsilon === undefined) { + epsilon = self.AVG_CODE_ERROR; + } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + for (i = 0; i < pattern.length; i++) { + counter[i] = 0; + } - var _subImage = __webpack_require__(4); + 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]; + } + normalized = self._normalize(counter); + if (normalized) { + error = self._matchPattern(normalized, pattern); - var _subImage2 = _interopRequireDefault(_subImage); + 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; + }; - var _commonCv_utils = __webpack_require__(5); + EANReader.prototype._findStart = function () { + var self = this, + leadingWhitespaceStart, + offset = self._nextSet(self._row), + startInfo; - var _commonCv_utils2 = _interopRequireDefault(_commonCv_utils); + 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; + } + }; - var _commonArray_helper = __webpack_require__(17); + EANReader.prototype._verifyTrailingWhitespace = function (endInfo) { + var self = this, + trailingWhitespaceEnd; - var _commonArray_helper2 = _interopRequireDefault(_commonArray_helper); - - var _glMatrix = __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) { - _commonArray_helper2['default'].init(this.data, 0); - } - } else { - this.data = new Uint8Array(size.x * size.y); - if (Uint8Array === Array && initialize) { - _commonArray_helper2['default'].init(this.data, 0); - } + trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start); + if (trailingWhitespaceEnd < self._row.length) { + if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { + return endInfo; } - } 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; + return null; }; - /** - * 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; - }; + EANReader.prototype._findEnd = function (offset, isWhite) { + var self = this, + endInfo = self._findPattern(self.STOP_PATTERN, offset, isWhite, false); - /** - * 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; - } + return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null; }; - /** - * 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); - }; + EANReader.prototype._calculateFirstDigit = function (codeFrequency) { + var i, + self = 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]; + for (i = 0; i < self.CODE_FREQUENCY.length; i++) { + if (codeFrequency === self.CODE_FREQUENCY[i]) { + return i; } } + return null; }; - ImageWrapper.prototype.copyTo = function (imageWrapper) { - var length = this.data.length, - srcData = this.data, - dstData = imageWrapper.data; + EANReader.prototype._decodePayload = function (code, result, decodedCodes) { + var i, + self = this, + codeFrequency = 0x0, + firstDigit; - while (length--) { - dstData[length] = srcData[length]; + 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); } - }; - /** - * 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]; - }; + firstDigit = self._calculateFirstDigit(codeFrequency); + if (firstDigit === null) { + return null; + } + result.unshift(firstDigit); - /** - * 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; + code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); + if (code === null) { + return null; + } + decodedCodes.push(code); - 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; + 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 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; + return code; }; - /** - * 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; + EANReader.prototype._decode = function () { + var startInfo, + self = this, + code, + result = [], + decodedCodes = []; + + startInfo = self._findStart(); + if (!startInfo) { + return null; } - for (i = 1; i < height - 1; i++) { - data[i * width] = data[i * width + (width - 1)] = 0; + 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; } + + return { + code: result.join(""), + start: startInfo.start, + end: code.end, + codeset: "", + startInfo: startInfo, + decodedCodes: decodedCodes + }; }; - /** - * Inverts a binary image in place - */ - ImageWrapper.prototype.invert = function () { - var data = this.data, - length = data.length; + EANReader.prototype._checksum = function (result) { + var sum = 0, + i; - while (length--) { - data[length] = data[length] ? 0 : 1; + 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; }; - 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; - } - } - } + /* harmony default export */ exports["a"] = EANReader; + +/***/ }, +/* 11 */ +/***/ function(module, exports, __webpack_require__) { + + var eq = __webpack_require__(15); - 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 = _glMatrix.vec2.clone([Math.cos(tmp), Math.sin(tmp)]); - result.push(label); - } + /** + * Gets the index at which the first occurrence of `key` is found in `array` + * of key-value pairs. + * + * @private + * @param {Array} array The array to search. + * @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; + } - return result; - }; + module.e = assocIndexOf; + + +/***/ }, +/* 12 */ +/***/ function(module, exports, __webpack_require__) { + + var isNative = __webpack_require__(140); /** - * 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 + * 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`. */ - 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); - }; + function getNative(object, key) { + var value = object[key]; + return isNative(value) ? value : undefined; + } + module.e = getNative; + + +/***/ }, +/* 13 */ +/***/ function(module, exports, __webpack_require__) { + /** - * 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 + * 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`. */ - 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 : _commonCv_utils2['default'].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); - }; + function isKeyable(value) { + var type = typeof value; + return type == 'number' || type == 'boolean' || + (type == 'string' && value != '__proto__') || value == null; + } - exports['default'] = ImageWrapper; - module.exports = exports['default']; + module.e = isKeyable; + /***/ }, -/* 4 */ -/***/ function(module, exports) { +/* 14 */ +/***/ function(module, exports, __webpack_require__) { + + var getNative = __webpack_require__(12); + + /* Built-in method references that are verified to be native. */ + var nativeCreate = getNative(Object, 'create'); + + module.e = nativeCreate; + + +/***/ }, +/* 15 */ +/***/ function(module, exports, __webpack_require__) { /** - * 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 + * Performs a [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero) + * comparison between two values to determine if they are equivalent. + * + * @static + * @memberOf _ + * @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 = { 'user': 'fred' }; + * var other = { 'user': 'fred' }; + * + * _.eq(object, object); + * // => true + * + * _.eq(object, other); + * // => false + * + * _.eq('a', 'a'); + * // => true + * + * _.eq('a', Object('a')); + * // => false + * + * _.eq(NaN, NaN); + * // => true */ - 'use strict'; + function eq(value, other) { + return value === other || (value !== value && other !== other); + } - Object.defineProperty(exports, '__esModule', { - value: true - }); - function SubImage(from, size, I) { - if (!I) { - I = { - data: null, - size: size - }; - } - this.data = I.data; - this.originalSize = I.size; - this.I = I; + module.e = eq; + + +/***/ }, +/* 16 */ +/***/ function(module, exports, __webpack_require__) { + + var isObject = __webpack_require__(2); - this.from = from; - this.size = size; - } + /** `Object#toString` result references. */ + var funcTag = '[object Function]', + genTag = '[object GeneratorFunction]'; + + /** Used for built-in method references. */ + var objectProto = Object.prototype; /** - * 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 + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. */ - 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; - }; + var objectToString = objectProto.toString; /** - * Updates the position of the shared area - * @param from {x,y} The new location - * @returns {SubImage} returns {this} for possible chaining + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false */ - SubImage.prototype.updateFrom = function (from) { - this.from = from; - return this; - }; + function isFunction(value) { + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 8 which returns 'object' for typed array and weak map constructors, + // and PhantomJS 1.9 which returns 'function' for `NodeList` instances. + var tag = isObject(value) ? objectToString.call(value) : ''; + return tag == funcTag || tag == genTag; + } - exports['default'] = SubImage; - module.exports = exports['default']; + module.e = isFunction; + /***/ }, -/* 5 */ +/* 17 */ /***/ function(module, exports, __webpack_require__) { - 'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _cluster = __webpack_require__(6); - - var _cluster2 = _interopRequireDefault(_cluster); - - var _array_helper = __webpack_require__(17); - - var _array_helper2 = _interopRequireDefault(_array_helper); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__cluster__ = __webpack_require__(51); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__array_helper__ = __webpack_require__(8); + /* harmony export */ exports["f"] = imageRef;/* unused harmony export computeIntegralImage2 *//* unused harmony export computeIntegralImage *//* unused harmony export thresholdImage *//* unused harmony export computeHistogram *//* unused harmony export sharpenLine *//* unused harmony export determineOtsuThreshold *//* harmony export */ exports["c"] = otsuThreshold;/* unused harmony export computeBinaryImage *//* harmony export */ exports["d"] = cluster;/* unused harmony export dilate *//* unused harmony export erode *//* unused harmony export subtract *//* unused harmony export bitwiseOr *//* unused harmony export countNonZero *//* harmony export */ exports["e"] = topGeneric;/* unused harmony export grayArrayFromImage *//* unused harmony export grayArrayFromContext *//* harmony export */ exports["i"] = grayAndHalfSampleFromCanvasData;/* harmony export */ exports["j"] = computeGray;/* unused harmony export loadImageArray *//* harmony export */ exports["g"] = halfSample;/* harmony export */ exports["a"] = hsv2rgb;/* unused harmony export _computeDivisors *//* harmony export */ exports["b"] = calculatePatchSize;/* unused harmony export _parseCSSDimensionValues *//* harmony export */ exports["h"] = computeImageArea; - var _glMatrix = __webpack_require__(7); - - var CVUtils = {}; + var vec2 = { + clone: __webpack_require__(6) + }; + var vec3 = { + clone: __webpack_require__(78) + }; /** * @param x x-coordinate * @param y y-coordinate * @return ImageReference {x,y} Coordinate */ - CVUtils.imageRef = function (x, y) { + function imageRef(x, y) { var that = { x: x, y: y, toVec2: function toVec2() { - return _glMatrix.vec2.clone([this.x, this.y]); + return vec2.clone([this.x, this.y]); }, toVec3: function toVec3() { - return _glMatrix.vec3.clone([this.x, this.y, 1]); + 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); @@ -1179,7 +1226,7 @@ return /******/ (function(modules) { // webpackBootstrap * Computes an integral image of a given grayscale image. * @param imageDataContainer {ImageDataContainer} the image to be integrated */ - CVUtils.computeIntegralImage2 = function (imageWrapper, integralWrapper) { + function computeIntegralImage2(imageWrapper, integralWrapper) { var imageData = imageWrapper.data; var width = imageWrapper.size.x; var height = imageWrapper.size.y; @@ -1227,7 +1274,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.computeIntegralImage = function (imageWrapper, integralWrapper) { + function computeIntegralImage(imageWrapper, integralWrapper) { var imageData = imageWrapper.data; var width = imageWrapper.size.x; var height = imageWrapper.size.y; @@ -1249,7 +1296,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.thresholdImage = function (imageWrapper, threshold, targetWrapper) { + function thresholdImage(imageWrapper, threshold, targetWrapper) { if (!targetWrapper) { targetWrapper = imageWrapper; } @@ -1262,7 +1309,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.computeHistogram = function (imageWrapper, bitsPerPixel) { + function computeHistogram(imageWrapper, bitsPerPixel) { if (!bitsPerPixel) { bitsPerPixel = 8; } @@ -1278,7 +1325,7 @@ return /******/ (function(modules) { // webpackBootstrap return hist; }; - CVUtils.sharpenLine = function (line) { + function sharpenLine(line) { var i, length = line.length, left = line[0], @@ -1295,7 +1342,7 @@ return /******/ (function(modules) { // webpackBootstrap return line; }; - CVUtils.determineOtsuThreshold = function (imageWrapper, bitsPerPixel) { + function determineOtsuThreshold(imageWrapper, bitsPerPixel) { if (!bitsPerPixel) { bitsPerPixel = 8; } @@ -1334,7 +1381,7 @@ return /******/ (function(modules) { // webpackBootstrap m12, max = (1 << bitsPerPixel) - 1; - hist = CVUtils.computeHistogram(imageWrapper, bitsPerPixel); + hist = computeHistogram(imageWrapper, bitsPerPixel); for (k = 1; k < max; k++) { p1 = px(0, k); p2 = px(k + 1, max); @@ -1347,23 +1394,23 @@ return /******/ (function(modules) { // webpackBootstrap m12 = m1 - m2; vet[k] = m12 * m12 / p12; } - return _array_helper2['default'].maxIndex(vet); + return /* harmony import */__WEBPACK_IMPORTED_MODULE_1__array_helper__["a"].maxIndex(vet); } threshold = determineThreshold(); return threshold << bitShift; }; - CVUtils.otsuThreshold = function (imageWrapper, targetWrapper) { - var threshold = CVUtils.determineOtsuThreshold(imageWrapper); + function otsuThreshold(imageWrapper, targetWrapper) { + var threshold = determineOtsuThreshold(imageWrapper); - CVUtils.thresholdImage(imageWrapper, threshold, targetWrapper); + thresholdImage(imageWrapper, threshold, targetWrapper); return threshold; }; // local thresholding - CVUtils.computeBinaryImage = function (imageWrapper, integralWrapper, targetWrapper) { - CVUtils.computeIntegralImage(imageWrapper, integralWrapper); + function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) { + computeIntegralImage(imageWrapper, integralWrapper); if (!targetWrapper) { targetWrapper = imageWrapper; @@ -1413,7 +1460,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.cluster = function (points, threshold, property) { + function cluster(points, threshold, property) { var i, k, cluster, @@ -1438,15 +1485,15 @@ return /******/ (function(modules) { // webpackBootstrap // iterate over each cloud for (i = 0; i < points.length; i++) { - point = _cluster2['default'].createPoint(points[i], i, property); + point = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__cluster__["a"].createPoint(points[i], i, property); if (!addToCluster(point)) { - clusters.push(_cluster2['default'].create(point, threshold)); + clusters.push(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__cluster__["a"].create(point, threshold)); } } return clusters; }; - CVUtils.Tracer = { + var Tracer = { trace: function trace(points, vec) { var iteration, maxIterations = 10, @@ -1522,12 +1569,12 @@ return /******/ (function(modules) { // webpackBootstrap } return result; } - }; + };/* unused harmony export Tracer */ - CVUtils.DILATE = 1; - CVUtils.ERODE = 2; + var DILATE = 1;/* unused harmony export DILATE */ + var ERODE = 2;/* unused harmony export ERODE */ - CVUtils.dilate = function (inImageWrapper, outImageWrapper) { + function dilate(inImageWrapper, outImageWrapper) { var v, u, inImageData = inImageWrapper.data, @@ -1552,7 +1599,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.erode = function (inImageWrapper, outImageWrapper) { + function erode(inImageWrapper, outImageWrapper) { var v, u, inImageData = inImageWrapper.data, @@ -1577,7 +1624,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.subtract = function (aImageWrapper, bImageWrapper, resultImageWrapper) { + function subtract(aImageWrapper, bImageWrapper, resultImageWrapper) { if (!resultImageWrapper) { resultImageWrapper = aImageWrapper; } @@ -1591,7 +1638,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.bitwiseOr = function (aImageWrapper, bImageWrapper, resultImageWrapper) { + function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) { if (!resultImageWrapper) { resultImageWrapper = aImageWrapper; } @@ -1605,7 +1652,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.countNonZero = function (imageWrapper) { + function countNonZero(imageWrapper) { var length = imageWrapper.data.length, data = imageWrapper.data, sum = 0; @@ -1616,7 +1663,7 @@ return /******/ (function(modules) { // webpackBootstrap return sum; }; - CVUtils.topGeneric = function (list, top, scoreFunc) { + function topGeneric(list, top, scoreFunc) { var i, minIdx = 0, min = 0, @@ -1651,18 +1698,18 @@ return /******/ (function(modules) { // webpackBootstrap return queue; }; - CVUtils.grayArrayFromImage = function (htmlImage, offsetX, ctx, array) { + 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; - CVUtils.computeGray(ctxData, array); + computeGray(ctxData, array); }; - CVUtils.grayArrayFromContext = function (ctx, size, offset, array) { + function grayArrayFromContext(ctx, size, offset, array) { var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data; - CVUtils.computeGray(ctxData, array); + computeGray(ctxData, array); }; - CVUtils.grayAndHalfSampleFromCanvasData = function (canvasData, size, outArray) { + function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) { var topRowIdx = 0; var bottomRowIdx = size.x; var endIdx = Math.floor(canvasData.length / 4); @@ -1683,7 +1730,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.computeGray = function (imageData, outArray, config) { + function computeGray(imageData, outArray, config) { var l = imageData.length / 4 | 0, i, singleChannel = config && config.singleChannel === true; @@ -1699,7 +1746,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.loadImageArray = function (src, callback, canvas) { + function loadImageArray(src, callback, canvas) { if (!canvas) { canvas = document.createElement('canvas'); } @@ -1713,7 +1760,7 @@ return /******/ (function(modules) { // webpackBootstrap var array = new Uint8Array(this.width * this.height); ctx.drawImage(this, 0, 0); var data = ctx.getImageData(0, 0, this.width, this.height).data; - CVUtils.computeGray(data, array); + computeGray(data, array); this.callback(array, { x: this.width, y: this.height @@ -1726,7 +1773,7 @@ return /******/ (function(modules) { // webpackBootstrap * @param inImg {ImageWrapper} input image to be sampled * @param outImg {ImageWrapper} to be stored in */ - CVUtils.halfSample = function (inImgWrapper, outImgWrapper) { + function halfSample(inImgWrapper, outImgWrapper) { var inImg = inImgWrapper.data; var inWidth = inImgWrapper.size.x; var outImg = outImgWrapper.data; @@ -1747,7 +1794,7 @@ return /******/ (function(modules) { // webpackBootstrap } }; - CVUtils.hsv2rgb = function (hsv, rgb) { + function hsv2rgb(hsv, rgb) { var h = hsv[0], s = hsv[1], v = hsv[2], @@ -1785,7 +1832,7 @@ return /******/ (function(modules) { // webpackBootstrap return rgb; }; - CVUtils._computeDivisors = function (n) { + function _computeDivisors(n) { var largeDivisors = [], divisors = [], i; @@ -1801,7 +1848,7 @@ return /******/ (function(modules) { // webpackBootstrap return divisors.concat(largeDivisors); }; - CVUtils._computeIntersection = function (arr1, arr2) { + function _computeIntersection(arr1, arr2) { var i = 0, j = 0, result = []; @@ -1820,11 +1867,11 @@ return /******/ (function(modules) { // webpackBootstrap return result; }; - CVUtils.calculatePatchSize = function (patchSize, imgSize) { - var divisorsX = this._computeDivisors(imgSize.x), - divisorsY = this._computeDivisors(imgSize.y), + function calculatePatchSize(patchSize, imgSize) { + var divisorsX = _computeDivisors(imgSize.x), + divisorsY = _computeDivisors(imgSize.y), wideSide = Math.max(imgSize.x, imgSize.y), - common = this._computeIntersection(divisorsX, divisorsY), + common = _computeIntersection(divisorsX, divisorsY), nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80], nrOfPatchesMap = { "x-small": 5, @@ -1860,15 +1907,15 @@ return /******/ (function(modules) { // webpackBootstrap optimalPatchSize = findPatchSizeForDivisors(common); if (!optimalPatchSize) { - optimalPatchSize = findPatchSizeForDivisors(this._computeDivisors(wideSide)); + optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide)); if (!optimalPatchSize) { - optimalPatchSize = findPatchSizeForDivisors(this._computeDivisors(desiredPatchSize * nrOfPatches)); + optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(desiredPatchSize * nrOfPatches)); } } return optimalPatchSize; }; - CVUtils._parseCSSDimensionValues = function (value) { + function _parseCSSDimensionValues(value) { var dimension = { value: parseFloat(value), unit: value.indexOf("%") === value.length - 1 ? "%" : "%" @@ -1877,7 +1924,7 @@ return /******/ (function(modules) { // webpackBootstrap return dimension; }; - CVUtils._dimensionsConverters = { + var _dimensionsConverters = { top: function top(dimension, context) { if (dimension.unit === "%") { return Math.floor(context.height * (dimension.value / 100)); @@ -1898,15 +1945,15 @@ return /******/ (function(modules) { // webpackBootstrap return Math.floor(context.width * (dimension.value / 100)); } } - }; + };/* unused harmony export _dimensionsConverters */ - CVUtils.computeImageArea = function (inputWidth, inputHeight, area) { + 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 = CVUtils._parseCSSDimensionValues(value), - calculated = CVUtils._dimensionsConverters[key](parsed, context); + parsed = _parseCSSDimensionValues(value), + calculated = _dimensionsConverters[key](parsed, context); result[key] = calculated; return result; @@ -1919,7496 +1966,5056 @@ return /******/ (function(modules) { // webpackBootstrap sh: parsedArea.bottom - parsedArea.top }; }; - - exports['default'] = CVUtils; - module.exports = exports['default']; /***/ }, -/* 6 */ +/* 18 */ /***/ function(module, exports, __webpack_require__) { - 'use strict'; + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__subImage__ = __webpack_require__(53); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__common_cv_utils__ = __webpack_require__(17); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__common_array_helper__ = __webpack_require__(8); + - Object.defineProperty(exports, '__esModule', { - value: true - }); - var _glMatrix = __webpack_require__(7); + var vec2 = { + clone: __webpack_require__(6) + }; /** - * Creates a cluster for grouping similar orientations of datapoints + * 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} */ - exports['default'] = { - create: function create(point, threshold) { - var points = [], - center = { - rad: 0, - vec: _glMatrix.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; + function ImageWrapper(size, data, ArrayType, initialize) { + if (!data) { + if (ArrayType) { + this.data = new ArrayType(size.x * size.y); + if (ArrayType === Array && initialize) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_2__common_array_helper__["a"].init(this.data, 0); } - center.rad = sum / points.length; - center.vec = _glMatrix.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(_glMatrix.vec2.dot(otherPoint.point.vec, center.vec)); - if (similarity > threshold) { - return true; - } - return false; - }, - getPoints: function getPoints() { - return points; - }, - getCenter: function getCenter() { - return center; + } else { + this.data = new Uint8Array(size.x * size.y); + if (Uint8Array === Array && initialize) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_2__common_array_helper__["a"].init(this.data, 0); } - }; - }, - createPoint: function createPoint(newPoint, id, property) { - return { - rad: newPoint[property], - point: newPoint, - id: id - }; + } + } else { + this.data = data; } - }; - module.exports = exports['default']; - -/***/ }, -/* 7 */ -/***/ function(module, exports, __webpack_require__) { - - /** - * @fileoverview gl-matrix - High performance matrix and vector operations - * @author Brandon Jones - * @author Colin MacKenzie IV - * @version 2.3.0 - */ - - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. - - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ - // END HEADER - - exports.glMatrix = __webpack_require__(8); - exports.mat2 = __webpack_require__(9); - exports.mat2d = __webpack_require__(10); - exports.mat3 = __webpack_require__(11); - exports.mat4 = __webpack_require__(12); - exports.quat = __webpack_require__(13); - exports.vec2 = __webpack_require__(16); - exports.vec3 = __webpack_require__(14); - exports.vec4 = __webpack_require__(15); - -/***/ }, -/* 8 */ -/***/ function(module, exports) { - - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. - - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ - - /** - * @class Common utilities - * @name glMatrix - */ - var glMatrix = {}; - - // Constants - glMatrix.EPSILON = 0.000001; - glMatrix.ARRAY_TYPE = (typeof Float32Array !== 'undefined') ? Float32Array : Array; - glMatrix.RANDOM = Math.random; - - /** - * Sets the type of array used when creating new vectors and matrices - * - * @param {Type} type Array type, such as Float32Array or Array - */ - glMatrix.setMatrixArrayType = function(type) { - GLMAT_ARRAY_TYPE = type; - } - - var degree = Math.PI / 180; - - /** - * Convert Degree To Radian - * - * @param {Number} Angle in Degrees - */ - glMatrix.toRadian = function(a){ - return a * degree; + this.size = size; } - module.exports = glMatrix; - - -/***/ }, -/* 9 */ -/***/ function(module, exports, __webpack_require__) { - - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. - - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ - - var glMatrix = __webpack_require__(8); - /** - * @class 2x2 Matrix - * @name mat2 + * 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 */ - var mat2 = {}; + 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; + }; /** - * Creates a new identity mat2 - * - * @returns {mat2} a new 2x2 matrix + * 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 */ - mat2.create = function() { - var out = new glMatrix.ARRAY_TYPE(4); - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 1; - return out; + 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; }; /** - * Creates a new mat2 initialized with values from an existing matrix - * - * @param {mat2} a matrix to clone - * @returns {mat2} a new 2x2 matrix + * Initializes a given array. Sets each element to zero. + * @param array {Array} The array to initialize */ - mat2.clone = function(a) { - var out = new glMatrix.ARRAY_TYPE(4); - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - return out; + ImageWrapper.clearArray = function (array) { + var l = array.length; + while (l--) { + array[l] = 0; + } }; /** - * Copy the values from one mat2 to another - * - * @param {mat2} out the receiving matrix - * @param {mat2} a the source matrix - * @returns {mat2} out + * 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 */ - mat2.copy = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - return out; + ImageWrapper.prototype.subImage = function (from, size) { + return new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__subImage__["a"](from, size, this); }; /** - * Set a mat2 to the identity matrix - * - * @param {mat2} out the receiving matrix - * @returns {mat2} out - */ - mat2.identity = function(out) { - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 1; - return out; - }; - - /** - * Transpose the values of a mat2 - * - * @param {mat2} out the receiving matrix - * @param {mat2} a the source matrix - * @returns {mat2} out + * 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) */ - mat2.transpose = function(out, a) { - // If we are transposing ourselves we can skip a few steps but have to cache some values - if (out === a) { - var a1 = a[1]; - out[1] = a[2]; - out[2] = a1; - } else { - out[0] = a[0]; - out[1] = a[2]; - out[2] = a[1]; - out[3] = a[3]; + 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]; + } } - - return out; }; - /** - * Inverts a mat2 - * - * @param {mat2} out the receiving matrix - * @param {mat2} a the source matrix - * @returns {mat2} out - */ - mat2.invert = function(out, a) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], - - // Calculate the determinant - det = a0 * a3 - a2 * a1; + ImageWrapper.prototype.copyTo = function (imageWrapper) { + var length = this.data.length, + srcData = this.data, + dstData = imageWrapper.data; - if (!det) { - return null; + while (length--) { + dstData[length] = srcData[length]; } - det = 1.0 / det; - - out[0] = a3 * det; - out[1] = -a1 * det; - out[2] = -a2 * det; - out[3] = a0 * det; - - return out; }; /** - * Calculates the adjugate of a mat2 - * - * @param {mat2} out the receiving matrix - * @param {mat2} a the source matrix - * @returns {mat2} out + * 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 */ - mat2.adjoint = function(out, a) { - // Caching this value is nessecary if out == a - var a0 = a[0]; - out[0] = a[3]; - out[1] = -a[1]; - out[2] = -a[2]; - out[3] = a0; - - return out; + ImageWrapper.prototype.get = function (x, y) { + return this.data[y * this.size.x + x]; }; /** - * Calculates the determinant of a mat2 - * - * @param {mat2} a the source matrix - * @returns {Number} determinant of a + * 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 */ - mat2.determinant = function (a) { - return a[0] * a[3] - a[2] * a[1]; - }; + ImageWrapper.prototype.getSafe = function (x, y) { + var i; - /** - * Multiplies two mat2's - * - * @param {mat2} out the receiving matrix - * @param {mat2} a the first operand - * @param {mat2} b the second operand - * @returns {mat2} out - */ - mat2.multiply = function (out, a, b) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3]; - var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3]; - out[0] = a0 * b0 + a2 * b1; - out[1] = a1 * b0 + a3 * b1; - out[2] = a0 * b2 + a2 * b3; - out[3] = a1 * b2 + a3 * b3; - return out; + 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]]; }; /** - * Alias for {@link mat2.multiply} - * @function - */ - mat2.mul = mat2.multiply; - - /** - * Rotates a mat2 by the given angle - * - * @param {mat2} out the receiving matrix - * @param {mat2} a the matrix to rotate - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat2} out + * 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) */ - mat2.rotate = function (out, a, rad) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], - s = Math.sin(rad), - c = Math.cos(rad); - out[0] = a0 * c + a2 * s; - out[1] = a1 * c + a3 * s; - out[2] = a0 * -s + a2 * c; - out[3] = a1 * -s + a3 * c; - return out; - }; - - /** - * Scales the mat2 by the dimensions in the given vec2 - * - * @param {mat2} out the receiving matrix - * @param {mat2} a the matrix to rotate - * @param {vec2} v the vec2 to scale the matrix by - * @returns {mat2} out - **/ - mat2.scale = function(out, a, v) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], - v0 = v[0], v1 = v[1]; - out[0] = a0 * v0; - out[1] = a1 * v0; - out[2] = a2 * v1; - out[3] = a3 * v1; - return out; + ImageWrapper.prototype.set = function (x, y, value) { + this.data[y * this.size.x + x] = value; + return this; }; /** - * Creates a matrix from a given angle - * This is equivalent to (but much faster than): - * - * mat2.identity(dest); - * mat2.rotate(dest, dest, rad); - * - * @param {mat2} out mat2 receiving operation result - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat2} out + * Sets the border of the image (1 pixel) to zero */ - mat2.fromRotation = function(out, rad) { - var s = Math.sin(rad), - c = Math.cos(rad); - out[0] = c; - out[1] = s; - out[2] = -s; - out[3] = c; - return out; - } + 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; + } + }; /** - * Creates a matrix from a vector scaling - * This is equivalent to (but much faster than): - * - * mat2.identity(dest); - * mat2.scale(dest, dest, vec); - * - * @param {mat2} out mat2 receiving operation result - * @param {vec2} v Scaling vector - * @returns {mat2} out + * Inverts a binary image in place */ - mat2.fromScaling = function(out, v) { - out[0] = v[0]; - out[1] = 0; - out[2] = 0; - out[3] = v[1]; - return out; - } + ImageWrapper.prototype.invert = function () { + var data = this.data, + length = data.length; - /** - * Returns a string representation of a mat2 - * - * @param {mat2} mat matrix to represent as a string - * @returns {String} string representation of the matrix - */ - mat2.str = function (a) { - return 'mat2(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')'; + while (length--) { + data[length] = data[length] ? 0 : 1; + } }; - /** - * Returns Frobenius norm of a mat2 - * - * @param {mat2} a the matrix to calculate Frobenius norm of - * @returns {Number} Frobenius norm - */ - mat2.frob = function (a) { - return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2))) + 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; + } + } }; - /** - * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix - * @param {mat2} L the lower triangular matrix - * @param {mat2} D the diagonal matrix - * @param {mat2} U the upper triangular matrix - * @param {mat2} a the input matrix to factorize - */ - - mat2.LDU = function (L, D, U, a) { - L[2] = a[2]/a[0]; - U[0] = a[0]; - U[1] = a[1]; - U[3] = a[3] - L[2] * U[1]; - return [L, D, U]; - }; - - - module.exports = mat2; - - -/***/ }, -/* 10 */ -/***/ function(module, exports, __webpack_require__) { - - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. - - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ - - var glMatrix = __webpack_require__(8); + 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; - /** - * @class 2x3 Matrix - * @name mat2d - * - * @description - * A mat2d contains six elements defined as: - *
-	 * [a, c, tx,
-	 *  b, d, ty]
-	 * 
- * This is a short form for the 3x3 matrix: - *
-	 * [a, c, tx,
-	 *  b, d, ty,
-	 *  0, 0, 1]
-	 * 
- * The last row is ignored so the array is shorter and operations are faster. - */ - var mat2d = {}; + if (labelcount <= 0) { + return result; + } - /** - * Creates a new identity mat2d - * - * @returns {mat2d} a new 2x3 matrix - */ - mat2d.create = function() { - var out = new glMatrix.ARRAY_TYPE(6); - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 1; - out[4] = 0; - out[5] = 0; - return out; - }; + for (i = 0; i < labelcount; i++) { + labelsum[i] = { + m00: 0, + m01: 0, + m10: 0, + m11: 0, + m02: 0, + m20: 0, + theta: 0, + rad: 0 + }; + } - /** - * Creates a new mat2d initialized with values from an existing matrix - * - * @param {mat2d} a matrix to clone - * @returns {mat2d} a new 2x3 matrix - */ - mat2d.clone = function(a) { - var out = new glMatrix.ARRAY_TYPE(6); - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - out[4] = a[4]; - out[5] = a[5]; - return out; - }; + 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; + } + } + } - /** - * Copy the values from one mat2d to another - * - * @param {mat2d} out the receiving matrix - * @param {mat2d} a the source matrix - * @returns {mat2d} out - */ - mat2d.copy = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - out[4] = a[4]; - out[5] = a[5]; - return out; - }; + 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); + } + } - /** - * Set a mat2d to the identity matrix - * - * @param {mat2d} out the receiving matrix - * @returns {mat2d} out - */ - mat2d.identity = function(out) { - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 1; - out[4] = 0; - out[5] = 0; - return out; + return result; }; /** - * Inverts a mat2d - * - * @param {mat2d} out the receiving matrix - * @param {mat2d} a the source matrix - * @returns {mat2d} out + * 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 */ - mat2d.invert = function(out, a) { - var aa = a[0], ab = a[1], ac = a[2], ad = a[3], - atx = a[4], aty = a[5]; + ImageWrapper.prototype.show = function (canvas, scale) { + var ctx, frame, data, current, pixel, x, y; - var det = aa * ad - ab * ac; - if(!det){ - return null; + if (!scale) { + scale = 1.0; } - det = 1.0 / det; - - out[0] = ad * det; - out[1] = -ab * det; - out[2] = -ac * det; - out[3] = aa * det; - out[4] = (ac * aty - ad * atx) * det; - out[5] = (ab * atx - aa * aty) * det; - return out; - }; - - /** - * Calculates the determinant of a mat2d - * - * @param {mat2d} a the source matrix - * @returns {Number} determinant of a - */ - mat2d.determinant = function (a) { - return a[0] * a[3] - a[1] * a[2]; + 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); }; /** - * Multiplies two mat2d's - * - * @param {mat2d} out the receiving matrix - * @param {mat2d} a the first operand - * @param {mat2d} b the second operand - * @returns {mat2d} out + * 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 */ - mat2d.multiply = function (out, a, b) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5], - b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3], b4 = b[4], b5 = b[5]; - out[0] = a0 * b0 + a2 * b1; - out[1] = a1 * b0 + a3 * b1; - out[2] = a0 * b2 + a2 * b3; - out[3] = a1 * b2 + a3 * b3; - out[4] = a0 * b4 + a2 * b5 + a4; - out[5] = a1 * b4 + a3 * b5 + a5; - return out; + 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 : /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["a"].bind()(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); }; + /* harmony default export */ exports["a"] = ImageWrapper; + +/***/ }, +/* 19 */ +/***/ function(module, exports, __webpack_require__) { + /** - * Alias for {@link mat2d.multiply} - * @function - */ - mat2d.mul = mat2d.multiply; - - /** - * Rotates a mat2d by the given angle + * A specialized version of `_.reduce` for arrays without support for + * iteratee shorthands. * - * @param {mat2d} out the receiving matrix - * @param {mat2d} a the matrix to rotate - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat2d} out + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @param {boolean} [initAccum] Specify using the first element of `array` as the initial value. + * @returns {*} Returns the accumulated value. */ - mat2d.rotate = function (out, a, rad) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5], - s = Math.sin(rad), - c = Math.cos(rad); - out[0] = a0 * c + a2 * s; - out[1] = a1 * c + a3 * s; - out[2] = a0 * -s + a2 * c; - out[3] = a1 * -s + a3 * c; - out[4] = a4; - out[5] = a5; - return out; - }; + function arrayReduce(array, iteratee, accumulator, initAccum) { + var index = -1, + length = array.length; - /** - * Scales the mat2d by the dimensions in the given vec2 - * - * @param {mat2d} out the receiving matrix - * @param {mat2d} a the matrix to translate - * @param {vec2} v the vec2 to scale the matrix by - * @returns {mat2d} out - **/ - mat2d.scale = function(out, a, v) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5], - v0 = v[0], v1 = v[1]; - out[0] = a0 * v0; - out[1] = a1 * v0; - out[2] = a2 * v1; - out[3] = a3 * v1; - out[4] = a4; - out[5] = a5; - return out; - }; + if (initAccum && length) { + accumulator = array[++index]; + } + while (++index < length) { + accumulator = iteratee(accumulator, array[index], index, array); + } + return accumulator; + } - /** - * Translates the mat2d by the dimensions in the given vec2 - * - * @param {mat2d} out the receiving matrix - * @param {mat2d} a the matrix to translate - * @param {vec2} v the vec2 to translate the matrix by - * @returns {mat2d} out - **/ - mat2d.translate = function(out, a, v) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5], - v0 = v[0], v1 = v[1]; - out[0] = a0; - out[1] = a1; - out[2] = a2; - out[3] = a3; - out[4] = a0 * v0 + a2 * v1 + a4; - out[5] = a1 * v0 + a3 * v1 + a5; - return out; - }; + module.e = arrayReduce; + + +/***/ }, +/* 20 */ +/***/ function(module, exports, __webpack_require__) { + + var copyObjectWith = __webpack_require__(111); /** - * Creates a matrix from a given angle - * This is equivalent to (but much faster than): - * - * mat2d.identity(dest); - * mat2d.rotate(dest, dest, rad); + * Copies properties of `source` to `object`. * - * @param {mat2d} out mat2d receiving operation result - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat2d} out + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property names to copy. + * @param {Object} [object={}] The object to copy properties to. + * @returns {Object} Returns `object`. */ - mat2d.fromRotation = function(out, rad) { - var s = Math.sin(rad), c = Math.cos(rad); - out[0] = c; - out[1] = s; - out[2] = -s; - out[3] = c; - out[4] = 0; - out[5] = 0; - return out; + function copyObject(source, props, object) { + return copyObjectWith(source, props, object); } + module.e = copyObject; + + +/***/ }, +/* 21 */ +/***/ function(module, exports, __webpack_require__) { + /** - * Creates a matrix from a vector scaling - * This is equivalent to (but much faster than): - * - * mat2d.identity(dest); - * mat2d.scale(dest, dest, vec); + * Checks if `value` is a host object in IE < 9. * - * @param {mat2d} out mat2d receiving operation result - * @param {vec2} v Scaling vector - * @returns {mat2d} out - */ - mat2d.fromScaling = function(out, v) { - out[0] = v[0]; - out[1] = 0; - out[2] = 0; - out[3] = v[1]; - out[4] = 0; - out[5] = 0; - return out; + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a host object, else `false`. + */ + function isHostObject(value) { + // Many host objects are `Object` objects that can coerce to strings + // despite having improperly defined `toString` methods. + var result = false; + if (value != null && typeof value.toString != 'function') { + try { + result = !!(value + ''); + } catch (e) {} + } + return result; } + module.e = isHostObject; + + +/***/ }, +/* 22 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used as references for various `Number` constants. */ + var MAX_SAFE_INTEGER = 9007199254740991; + + /** Used to detect unsigned integer values. */ + var reIsUint = /^(?:0|[1-9]\d*)$/; + /** - * Creates a matrix from a vector translation - * This is equivalent to (but much faster than): - * - * mat2d.identity(dest); - * mat2d.translate(dest, dest, vec); + * Checks if `value` is a valid array-like index. * - * @param {mat2d} out mat2d receiving operation result - * @param {vec2} v Translation vector - * @returns {mat2d} out + * @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`. */ - mat2d.fromTranslation = function(out, v) { - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 1; - out[4] = v[0]; - out[5] = v[1]; - return out; + function isIndex(value, length) { + value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1; + length = length == null ? MAX_SAFE_INTEGER : length; + return value > -1 && value % 1 == 0 && value < length; } - /** - * Returns a string representation of a mat2d - * - * @param {mat2d} a matrix to represent as a string - * @returns {String} string representation of the matrix - */ - mat2d.str = function (a) { - return 'mat2d(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + - a[3] + ', ' + a[4] + ', ' + a[5] + ')'; - }; + module.e = isIndex; + + +/***/ }, +/* 23 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used for built-in method references. */ + var objectProto = Object.prototype; /** - * Returns Frobenius norm of a mat2d + * Checks if `value` is likely a prototype object. * - * @param {mat2d} a the matrix to calculate Frobenius norm of - * @returns {Number} Frobenius norm + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a prototype, else `false`. */ - mat2d.frob = function (a) { - return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + 1)) - }; + function isPrototype(value) { + var Ctor = value && value.constructor, + proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto; + + return value === proto; + } - module.exports = mat2d; + module.e = isPrototype; /***/ }, -/* 11 */ +/* 24 */ /***/ function(module, exports, __webpack_require__) { - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. + var isArrayLikeObject = __webpack_require__(26); - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. + /** `Object#toString` result references. */ + var argsTag = '[object Arguments]'; - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ + /** Used for built-in method references. */ + var objectProto = Object.prototype; - var glMatrix = __webpack_require__(8); + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; /** - * @class 3x3 Matrix - * @name mat3 + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. */ - var mat3 = {}; + var objectToString = objectProto.toString; - /** - * Creates a new identity mat3 - * - * @returns {mat3} a new 3x3 matrix - */ - mat3.create = function() { - var out = new glMatrix.ARRAY_TYPE(9); - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 1; - out[5] = 0; - out[6] = 0; - out[7] = 0; - out[8] = 1; - return out; - }; + /** Built-in value references. */ + var propertyIsEnumerable = objectProto.propertyIsEnumerable; /** - * Copies the upper-left 3x3 values into the given mat3. + * Checks if `value` is likely an `arguments` object. * - * @param {mat3} out the receiving 3x3 matrix - * @param {mat4} a the source 4x4 matrix - * @returns {mat3} out - */ - mat3.fromMat4 = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[4]; - out[4] = a[5]; - out[5] = a[6]; - out[6] = a[8]; - out[7] = a[9]; - out[8] = a[10]; - return out; - }; - - /** - * Creates a new mat3 initialized with values from an existing matrix + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example * - * @param {mat3} a matrix to clone - * @returns {mat3} a new 3x3 matrix - */ - mat3.clone = function(a) { - var out = new glMatrix.ARRAY_TYPE(9); - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - out[4] = a[4]; - out[5] = a[5]; - out[6] = a[6]; - out[7] = a[7]; - out[8] = a[8]; - return out; - }; - - /** - * Copy the values from one mat3 to another + * _.isArguments(function() { return arguments; }()); + * // => true * - * @param {mat3} out the receiving matrix - * @param {mat3} a the source matrix - * @returns {mat3} out + * _.isArguments([1, 2, 3]); + * // => false */ - mat3.copy = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - out[4] = a[4]; - out[5] = a[5]; - out[6] = a[6]; - out[7] = a[7]; - out[8] = a[8]; - return out; - }; + function isArguments(value) { + // Safari 8.1 incorrectly makes `arguments.callee` enumerable in strict mode. + return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') && + (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag); + } - /** - * Set a mat3 to the identity matrix - * - * @param {mat3} out the receiving matrix - * @returns {mat3} out - */ - mat3.identity = function(out) { - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 1; - out[5] = 0; - out[6] = 0; - out[7] = 0; - out[8] = 1; - return out; - }; + module.e = isArguments; + + +/***/ }, +/* 25 */ +/***/ function(module, exports, __webpack_require__) { + + var getLength = __webpack_require__(115), + isFunction = __webpack_require__(16), + isLength = __webpack_require__(27); /** - * Transpose the values of a mat3 + * 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`. * - * @param {mat3} out the receiving matrix - * @param {mat3} a the source matrix - * @returns {mat3} out - */ - mat3.transpose = function(out, a) { - // If we are transposing ourselves we can skip a few steps but have to cache some values - if (out === a) { - var a01 = a[1], a02 = a[2], a12 = a[5]; - out[1] = a[3]; - out[2] = a[6]; - out[3] = a01; - out[5] = a[7]; - out[6] = a02; - out[7] = a12; - } else { - out[0] = a[0]; - out[1] = a[3]; - out[2] = a[6]; - out[3] = a[1]; - out[4] = a[4]; - out[5] = a[7]; - out[6] = a[2]; - out[7] = a[5]; - out[8] = a[8]; - } - - return out; - }; - - /** - * Inverts a mat3 + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is array-like, else `false`. + * @example * - * @param {mat3} out the receiving matrix - * @param {mat3} a the source matrix - * @returns {mat3} out - */ - mat3.invert = function(out, a) { - var a00 = a[0], a01 = a[1], a02 = a[2], - a10 = a[3], a11 = a[4], a12 = a[5], - a20 = a[6], a21 = a[7], a22 = a[8], - - b01 = a22 * a11 - a12 * a21, - b11 = -a22 * a10 + a12 * a20, - b21 = a21 * a10 - a11 * a20, - - // Calculate the determinant - det = a00 * b01 + a01 * b11 + a02 * b21; - - if (!det) { - return null; - } - det = 1.0 / det; - - out[0] = b01 * det; - out[1] = (-a22 * a01 + a02 * a21) * det; - out[2] = (a12 * a01 - a02 * a11) * det; - out[3] = b11 * det; - out[4] = (a22 * a00 - a02 * a20) * det; - out[5] = (-a12 * a00 + a02 * a10) * det; - out[6] = b21 * det; - out[7] = (-a21 * a00 + a01 * a20) * det; - out[8] = (a11 * a00 - a01 * a10) * det; - return out; - }; - - /** - * Calculates the adjugate of a mat3 + * _.isArrayLike([1, 2, 3]); + * // => true * - * @param {mat3} out the receiving matrix - * @param {mat3} a the source matrix - * @returns {mat3} out - */ - mat3.adjoint = function(out, a) { - var a00 = a[0], a01 = a[1], a02 = a[2], - a10 = a[3], a11 = a[4], a12 = a[5], - a20 = a[6], a21 = a[7], a22 = a[8]; - - out[0] = (a11 * a22 - a12 * a21); - out[1] = (a02 * a21 - a01 * a22); - out[2] = (a01 * a12 - a02 * a11); - out[3] = (a12 * a20 - a10 * a22); - out[4] = (a00 * a22 - a02 * a20); - out[5] = (a02 * a10 - a00 * a12); - out[6] = (a10 * a21 - a11 * a20); - out[7] = (a01 * a20 - a00 * a21); - out[8] = (a00 * a11 - a01 * a10); - return out; - }; - - /** - * Calculates the determinant of a mat3 + * _.isArrayLike(document.body.children); + * // => true * - * @param {mat3} a the source matrix - * @returns {Number} determinant of a - */ - mat3.determinant = function (a) { - var a00 = a[0], a01 = a[1], a02 = a[2], - a10 = a[3], a11 = a[4], a12 = a[5], - a20 = a[6], a21 = a[7], a22 = a[8]; - - return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20); - }; - - /** - * Multiplies two mat3's + * _.isArrayLike('abc'); + * // => true * - * @param {mat3} out the receiving matrix - * @param {mat3} a the first operand - * @param {mat3} b the second operand - * @returns {mat3} out + * _.isArrayLike(_.noop); + * // => false */ - mat3.multiply = function (out, a, b) { - var a00 = a[0], a01 = a[1], a02 = a[2], - a10 = a[3], a11 = a[4], a12 = a[5], - a20 = a[6], a21 = a[7], a22 = a[8], - - b00 = b[0], b01 = b[1], b02 = b[2], - b10 = b[3], b11 = b[4], b12 = b[5], - b20 = b[6], b21 = b[7], b22 = b[8]; - - out[0] = b00 * a00 + b01 * a10 + b02 * a20; - out[1] = b00 * a01 + b01 * a11 + b02 * a21; - out[2] = b00 * a02 + b01 * a12 + b02 * a22; - - out[3] = b10 * a00 + b11 * a10 + b12 * a20; - out[4] = b10 * a01 + b11 * a11 + b12 * a21; - out[5] = b10 * a02 + b11 * a12 + b12 * a22; - - out[6] = b20 * a00 + b21 * a10 + b22 * a20; - out[7] = b20 * a01 + b21 * a11 + b22 * a21; - out[8] = b20 * a02 + b21 * a12 + b22 * a22; - return out; - }; + function isArrayLike(value) { + return value != null && isLength(getLength(value)) && !isFunction(value); + } - /** - * Alias for {@link mat3.multiply} - * @function - */ - mat3.mul = mat3.multiply; + module.e = isArrayLike; + + +/***/ }, +/* 26 */ +/***/ function(module, exports, __webpack_require__) { + + var isArrayLike = __webpack_require__(25), + isObjectLike = __webpack_require__(7); /** - * Translate a mat3 by the given vector + * This method is like `_.isArrayLike` except that it also checks if `value` + * is an object. + * + * @static + * @memberOf _ + * @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 * - * @param {mat3} out the receiving matrix - * @param {mat3} a the matrix to translate - * @param {vec2} v vector to translate by - * @returns {mat3} out + * _.isArrayLikeObject('abc'); + * // => false + * + * _.isArrayLikeObject(_.noop); + * // => false */ - mat3.translate = function(out, a, v) { - var a00 = a[0], a01 = a[1], a02 = a[2], - a10 = a[3], a11 = a[4], a12 = a[5], - a20 = a[6], a21 = a[7], a22 = a[8], - x = v[0], y = v[1]; - - out[0] = a00; - out[1] = a01; - out[2] = a02; - - out[3] = a10; - out[4] = a11; - out[5] = a12; + function isArrayLikeObject(value) { + return isObjectLike(value) && isArrayLike(value); + } - out[6] = x * a00 + y * a10 + a20; - out[7] = x * a01 + y * a11 + a21; - out[8] = x * a02 + y * a12 + a22; - return out; - }; + module.e = isArrayLikeObject; + + +/***/ }, +/* 27 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used as references for various `Number` constants. */ + var MAX_SAFE_INTEGER = 9007199254740991; /** - * Rotates a mat3 by the given angle + * Checks if `value` is a valid array-like length. * - * @param {mat3} out the receiving matrix - * @param {mat3} a the matrix to rotate - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat3} out - */ - mat3.rotate = function (out, a, rad) { - var a00 = a[0], a01 = a[1], a02 = a[2], - a10 = a[3], a11 = a[4], a12 = a[5], - a20 = a[6], a21 = a[7], a22 = a[8], - - s = Math.sin(rad), - c = Math.cos(rad); - - out[0] = c * a00 + s * a10; - out[1] = c * a01 + s * a11; - out[2] = c * a02 + s * a12; - - out[3] = c * a10 - s * a00; - out[4] = c * a11 - s * a01; - out[5] = c * a12 - s * a02; - - out[6] = a20; - out[7] = a21; - out[8] = a22; - return out; - }; - - /** - * Scales the mat3 by the dimensions in the given vec2 + * **Note:** This function is loosely based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). * - * @param {mat3} out the receiving matrix - * @param {mat3} a the matrix to rotate - * @param {vec2} v the vec2 to scale the matrix by - * @returns {mat3} out - **/ - mat3.scale = function(out, a, v) { - var x = v[0], y = v[1]; - - out[0] = x * a[0]; - out[1] = x * a[1]; - out[2] = x * a[2]; - - out[3] = y * a[3]; - out[4] = y * a[4]; - out[5] = y * a[5]; - - out[6] = a[6]; - out[7] = a[7]; - out[8] = a[8]; - return out; - }; - - /** - * Creates a matrix from a vector translation - * This is equivalent to (but much faster than): + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. + * @example * - * mat3.identity(dest); - * mat3.translate(dest, dest, vec); + * _.isLength(3); + * // => true * - * @param {mat3} out mat3 receiving operation result - * @param {vec2} v Translation vector - * @returns {mat3} out - */ - mat3.fromTranslation = function(out, v) { - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 1; - out[5] = 0; - out[6] = v[0]; - out[7] = v[1]; - out[8] = 1; - return out; - } - - /** - * Creates a matrix from a given angle - * This is equivalent to (but much faster than): + * _.isLength(Number.MIN_VALUE); + * // => false * - * mat3.identity(dest); - * mat3.rotate(dest, dest, rad); + * _.isLength(Infinity); + * // => false * - * @param {mat3} out mat3 receiving operation result - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat3} out + * _.isLength('3'); + * // => false */ - mat3.fromRotation = function(out, rad) { - var s = Math.sin(rad), c = Math.cos(rad); - - out[0] = c; - out[1] = s; - out[2] = 0; - - out[3] = -s; - out[4] = c; - out[5] = 0; - - out[6] = 0; - out[7] = 0; - out[8] = 1; - return out; + function isLength(value) { + return typeof value == 'number' && + value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; } + module.e = isLength; + + +/***/ }, +/* 28 */ +/***/ function(module, exports, __webpack_require__) { + + var baseMerge = __webpack_require__(99), + createAssigner = __webpack_require__(113); + /** - * Creates a matrix from a vector scaling - * This is equivalent to (but much faster than): + * This method is like `_.assign` except that it recursively merges own and + * inherited enumerable 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. * - * mat3.identity(dest); - * mat3.scale(dest, dest, vec); + * **Note:** This method mutates `object`. * - * @param {mat3} out mat3 receiving operation result - * @param {vec2} v Scaling vector - * @returns {mat3} out - */ - mat3.fromScaling = function(out, v) { - out[0] = v[0]; - out[1] = 0; - out[2] = 0; - - out[3] = 0; - out[4] = v[1]; - out[5] = 0; - - out[6] = 0; - out[7] = 0; - out[8] = 1; - return out; - } - - /** - * Copies the values from a mat2d into a mat3 - * - * @param {mat3} out the receiving matrix - * @param {mat2d} a the matrix to copy - * @returns {mat3} out - **/ - mat3.fromMat2d = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - out[2] = 0; - - out[3] = a[2]; - out[4] = a[3]; - out[5] = 0; - - out[6] = a[4]; - out[7] = a[5]; - out[8] = 1; - return out; - }; - - /** - * Calculates a 3x3 matrix from the given quaternion - * - * @param {mat3} out mat3 receiving operation result - * @param {quat} q Quaternion to create matrix from - * - * @returns {mat3} out - */ - mat3.fromQuat = function (out, q) { - var x = q[0], y = q[1], z = q[2], w = q[3], - x2 = x + x, - y2 = y + y, - z2 = z + z, - - xx = x * x2, - yx = y * x2, - yy = y * y2, - zx = z * x2, - zy = z * y2, - zz = z * z2, - wx = w * x2, - wy = w * y2, - wz = w * z2; - - out[0] = 1 - yy - zz; - out[3] = yx - wz; - out[6] = zx + wy; - - out[1] = yx + wz; - out[4] = 1 - xx - zz; - out[7] = zy - wx; - - out[2] = zx - wy; - out[5] = zy + wx; - out[8] = 1 - xx - yy; - - return out; - }; - - /** - * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix - * - * @param {mat3} out mat3 receiving operation result - * @param {mat4} a Mat4 to derive the normal matrix from - * - * @returns {mat3} out - */ - mat3.normalFromMat4 = function (out, a) { - var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3], - a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7], - a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11], - a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15], - - b00 = a00 * a11 - a01 * a10, - b01 = a00 * a12 - a02 * a10, - b02 = a00 * a13 - a03 * a10, - b03 = a01 * a12 - a02 * a11, - b04 = a01 * a13 - a03 * a11, - b05 = a02 * a13 - a03 * a12, - b06 = a20 * a31 - a21 * a30, - b07 = a20 * a32 - a22 * a30, - b08 = a20 * a33 - a23 * a30, - b09 = a21 * a32 - a22 * a31, - b10 = a21 * a33 - a23 * a31, - b11 = a22 * a33 - a23 * a32, - - // Calculate the determinant - det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06; - - if (!det) { - return null; - } - det = 1.0 / det; - - out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det; - out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det; - out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det; - - out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det; - out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det; - out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det; - - out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det; - out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det; - out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det; - - return out; - }; - - /** - * Returns a string representation of a mat3 + * @static + * @memberOf _ + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @example * - * @param {mat3} mat matrix to represent as a string - * @returns {String} string representation of the matrix - */ - mat3.str = function (a) { - return 'mat3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + - a[3] + ', ' + a[4] + ', ' + a[5] + ', ' + - a[6] + ', ' + a[7] + ', ' + a[8] + ')'; - }; - - /** - * Returns Frobenius norm of a mat3 + * var users = { + * 'data': [{ 'user': 'barney' }, { 'user': 'fred' }] + * }; * - * @param {mat3} a the matrix to calculate Frobenius norm of - * @returns {Number} Frobenius norm + * var ages = { + * 'data': [{ 'age': 36 }, { 'age': 40 }] + * }; + * + * _.merge(users, ages); + * // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] } */ - mat3.frob = function (a) { - return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2))) - }; - + var merge = createAssigner(function(object, source, srcIndex) { + baseMerge(object, source, srcIndex); + }); - module.exports = mat3; + module.e = merge; /***/ }, -/* 12 */ +/* 29 */ /***/ function(module, exports, __webpack_require__) { - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. - - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ - - var glMatrix = __webpack_require__(8); - - /** - * @class 4x4 Matrix - * @name mat4 - */ - var mat4 = {}; - - /** - * Creates a new identity mat4 - * - * @returns {mat4} a new 4x4 matrix - */ - mat4.create = function() { - var out = new glMatrix.ARRAY_TYPE(16); - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 0; - out[5] = 1; - out[6] = 0; - out[7] = 0; - out[8] = 0; - out[9] = 0; - out[10] = 1; - out[11] = 0; - out[12] = 0; - out[13] = 0; - out[14] = 0; - out[15] = 1; - return out; - }; - - /** - * Creates a new mat4 initialized with values from an existing matrix - * - * @param {mat4} a matrix to clone - * @returns {mat4} a new 4x4 matrix - */ - mat4.clone = function(a) { - var out = new glMatrix.ARRAY_TYPE(16); - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - out[4] = a[4]; - out[5] = a[5]; - out[6] = a[6]; - out[7] = a[7]; - out[8] = a[8]; - out[9] = a[9]; - out[10] = a[10]; - out[11] = a[11]; - out[12] = a[12]; - out[13] = a[13]; - out[14] = a[14]; - out[15] = a[15]; - return out; - }; - - /** - * Copy the values from one mat4 to another - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the source matrix - * @returns {mat4} out - */ - mat4.copy = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - out[4] = a[4]; - out[5] = a[5]; - out[6] = a[6]; - out[7] = a[7]; - out[8] = a[8]; - out[9] = a[9]; - out[10] = a[10]; - out[11] = a[11]; - out[12] = a[12]; - out[13] = a[13]; - out[14] = a[14]; - out[15] = a[15]; - return out; - }; - - /** - * Set a mat4 to the identity matrix - * - * @param {mat4} out the receiving matrix - * @returns {mat4} out - */ - mat4.identity = function(out) { - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 0; - out[5] = 1; - out[6] = 0; - out[7] = 0; - out[8] = 0; - out[9] = 0; - out[10] = 1; - out[11] = 0; - out[12] = 0; - out[13] = 0; - out[14] = 0; - out[15] = 1; - return out; - }; - - /** - * Transpose the values of a mat4 - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the source matrix - * @returns {mat4} out - */ - mat4.transpose = function(out, a) { - // If we are transposing ourselves we can skip a few steps but have to cache some values - if (out === a) { - var a01 = a[1], a02 = a[2], a03 = a[3], - a12 = a[6], a13 = a[7], - a23 = a[11]; - - out[1] = a[4]; - out[2] = a[8]; - out[3] = a[12]; - out[4] = a01; - out[6] = a[9]; - out[7] = a[13]; - out[8] = a02; - out[9] = a12; - out[11] = a[14]; - out[12] = a03; - out[13] = a13; - out[14] = a23; - } else { - out[0] = a[0]; - out[1] = a[4]; - out[2] = a[8]; - out[3] = a[12]; - out[4] = a[1]; - out[5] = a[5]; - out[6] = a[9]; - out[7] = a[13]; - out[8] = a[2]; - out[9] = a[6]; - out[10] = a[10]; - out[11] = a[14]; - out[12] = a[3]; - out[13] = a[7]; - out[14] = a[11]; - out[15] = a[15]; - } - - return out; - }; - - /** - * Inverts a mat4 - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the source matrix - * @returns {mat4} out - */ - mat4.invert = function(out, a) { - var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3], - a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7], - a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11], - a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15], - - b00 = a00 * a11 - a01 * a10, - b01 = a00 * a12 - a02 * a10, - b02 = a00 * a13 - a03 * a10, - b03 = a01 * a12 - a02 * a11, - b04 = a01 * a13 - a03 * a11, - b05 = a02 * a13 - a03 * a12, - b06 = a20 * a31 - a21 * a30, - b07 = a20 * a32 - a22 * a30, - b08 = a20 * a33 - a23 * a30, - b09 = a21 * a32 - a22 * a31, - b10 = a21 * a33 - a23 * a31, - b11 = a22 * a33 - a23 * a32, - - // Calculate the determinant - det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06; - - if (!det) { - return null; - } - det = 1.0 / det; - - out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det; - out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det; - out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det; - out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det; - out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det; - out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det; - out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det; - out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det; - out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det; - out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det; - out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det; - out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det; - out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det; - out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det; - out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det; - out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det; - - return out; - }; - - /** - * Calculates the adjugate of a mat4 - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the source matrix - * @returns {mat4} out - */ - mat4.adjoint = function(out, a) { - var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3], - a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7], - a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11], - a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15]; - - out[0] = (a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22)); - out[1] = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22)); - out[2] = (a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12)); - out[3] = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12)); - out[4] = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22)); - out[5] = (a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22)); - out[6] = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12)); - out[7] = (a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12)); - out[8] = (a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21)); - out[9] = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21)); - out[10] = (a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11)); - out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11)); - out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21)); - out[13] = (a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21)); - out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11)); - out[15] = (a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11)); - return out; - }; - - /** - * Calculates the determinant of a mat4 - * - * @param {mat4} a the source matrix - * @returns {Number} determinant of a - */ - mat4.determinant = function (a) { - var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3], - a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7], - a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11], - a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15], - - b00 = a00 * a11 - a01 * a10, - b01 = a00 * a12 - a02 * a10, - b02 = a00 * a13 - a03 * a10, - b03 = a01 * a12 - a02 * a11, - b04 = a01 * a13 - a03 * a11, - b05 = a02 * a13 - a03 * a12, - b06 = a20 * a31 - a21 * a30, - b07 = a20 * a32 - a22 * a30, - b08 = a20 * a33 - a23 * a30, - b09 = a21 * a32 - a22 * a31, - b10 = a21 * a33 - a23 * a31, - b11 = a22 * a33 - a23 * a32; - - // Calculate the determinant - return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06; - }; - - /** - * Multiplies two mat4's - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the first operand - * @param {mat4} b the second operand - * @returns {mat4} out - */ - mat4.multiply = function (out, a, b) { - var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3], - a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7], - a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11], - a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15]; - - // Cache only the current line of the second matrix - var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3]; - out[0] = b0*a00 + b1*a10 + b2*a20 + b3*a30; - out[1] = b0*a01 + b1*a11 + b2*a21 + b3*a31; - out[2] = b0*a02 + b1*a12 + b2*a22 + b3*a32; - out[3] = b0*a03 + b1*a13 + b2*a23 + b3*a33; - - b0 = b[4]; b1 = b[5]; b2 = b[6]; b3 = b[7]; - out[4] = b0*a00 + b1*a10 + b2*a20 + b3*a30; - out[5] = b0*a01 + b1*a11 + b2*a21 + b3*a31; - out[6] = b0*a02 + b1*a12 + b2*a22 + b3*a32; - out[7] = b0*a03 + b1*a13 + b2*a23 + b3*a33; - - b0 = b[8]; b1 = b[9]; b2 = b[10]; b3 = b[11]; - out[8] = b0*a00 + b1*a10 + b2*a20 + b3*a30; - out[9] = b0*a01 + b1*a11 + b2*a21 + b3*a31; - out[10] = b0*a02 + b1*a12 + b2*a22 + b3*a32; - out[11] = b0*a03 + b1*a13 + b2*a23 + b3*a33; - - b0 = b[12]; b1 = b[13]; b2 = b[14]; b3 = b[15]; - out[12] = b0*a00 + b1*a10 + b2*a20 + b3*a30; - out[13] = b0*a01 + b1*a11 + b2*a21 + b3*a31; - out[14] = b0*a02 + b1*a12 + b2*a22 + b3*a32; - out[15] = b0*a03 + b1*a13 + b2*a23 + b3*a33; - return out; - }; - - /** - * Alias for {@link mat4.multiply} - * @function - */ - mat4.mul = mat4.multiply; - - /** - * Translate a mat4 by the given vector - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the matrix to translate - * @param {vec3} v vector to translate by - * @returns {mat4} out - */ - mat4.translate = function (out, a, v) { - var x = v[0], y = v[1], z = v[2], - a00, a01, a02, a03, - a10, a11, a12, a13, - a20, a21, a22, a23; - - if (a === out) { - out[12] = a[0] * x + a[4] * y + a[8] * z + a[12]; - out[13] = a[1] * x + a[5] * y + a[9] * z + a[13]; - out[14] = a[2] * x + a[6] * y + a[10] * z + a[14]; - out[15] = a[3] * x + a[7] * y + a[11] * z + a[15]; - } else { - a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3]; - a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7]; - a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11]; - - out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a03; - out[4] = a10; out[5] = a11; out[6] = a12; out[7] = a13; - out[8] = a20; out[9] = a21; out[10] = a22; out[11] = a23; - - out[12] = a00 * x + a10 * y + a20 * z + a[12]; - out[13] = a01 * x + a11 * y + a21 * z + a[13]; - out[14] = a02 * x + a12 * y + a22 * z + a[14]; - out[15] = a03 * x + a13 * y + a23 * z + a[15]; - } - - return out; - }; - - /** - * Scales the mat4 by the dimensions in the given vec3 - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the matrix to scale - * @param {vec3} v the vec3 to scale the matrix by - * @returns {mat4} out - **/ - mat4.scale = function(out, a, v) { - var x = v[0], y = v[1], z = v[2]; - - out[0] = a[0] * x; - out[1] = a[1] * x; - out[2] = a[2] * x; - out[3] = a[3] * x; - out[4] = a[4] * y; - out[5] = a[5] * y; - out[6] = a[6] * y; - out[7] = a[7] * y; - out[8] = a[8] * z; - out[9] = a[9] * z; - out[10] = a[10] * z; - out[11] = a[11] * z; - out[12] = a[12]; - out[13] = a[13]; - out[14] = a[14]; - out[15] = a[15]; - return out; - }; - - /** - * Rotates a mat4 by the given angle around the given axis - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the matrix to rotate - * @param {Number} rad the angle to rotate the matrix by - * @param {vec3} axis the axis to rotate around - * @returns {mat4} out - */ - mat4.rotate = function (out, a, rad, axis) { - var x = axis[0], y = axis[1], z = axis[2], - len = Math.sqrt(x * x + y * y + z * z), - s, c, t, - a00, a01, a02, a03, - a10, a11, a12, a13, - a20, a21, a22, a23, - b00, b01, b02, - b10, b11, b12, - b20, b21, b22; - - if (Math.abs(len) < glMatrix.EPSILON) { return null; } - - len = 1 / len; - x *= len; - y *= len; - z *= len; - - s = Math.sin(rad); - c = Math.cos(rad); - t = 1 - c; - - a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3]; - a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7]; - a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11]; - - // Construct the elements of the rotation matrix - b00 = x * x * t + c; b01 = y * x * t + z * s; b02 = z * x * t - y * s; - b10 = x * y * t - z * s; b11 = y * y * t + c; b12 = z * y * t + x * s; - b20 = x * z * t + y * s; b21 = y * z * t - x * s; b22 = z * z * t + c; - - // Perform rotation-specific matrix multiplication - out[0] = a00 * b00 + a10 * b01 + a20 * b02; - out[1] = a01 * b00 + a11 * b01 + a21 * b02; - out[2] = a02 * b00 + a12 * b01 + a22 * b02; - out[3] = a03 * b00 + a13 * b01 + a23 * b02; - out[4] = a00 * b10 + a10 * b11 + a20 * b12; - out[5] = a01 * b10 + a11 * b11 + a21 * b12; - out[6] = a02 * b10 + a12 * b11 + a22 * b12; - out[7] = a03 * b10 + a13 * b11 + a23 * b12; - out[8] = a00 * b20 + a10 * b21 + a20 * b22; - out[9] = a01 * b20 + a11 * b21 + a21 * b22; - out[10] = a02 * b20 + a12 * b21 + a22 * b22; - out[11] = a03 * b20 + a13 * b21 + a23 * b22; - - if (a !== out) { // If the source and destination differ, copy the unchanged last row - out[12] = a[12]; - out[13] = a[13]; - out[14] = a[14]; - out[15] = a[15]; - } - return out; - }; - - /** - * Rotates a matrix by the given angle around the X axis - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the matrix to rotate - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat4} out - */ - mat4.rotateX = function (out, a, rad) { - var s = Math.sin(rad), - c = Math.cos(rad), - a10 = a[4], - a11 = a[5], - a12 = a[6], - a13 = a[7], - a20 = a[8], - a21 = a[9], - a22 = a[10], - a23 = a[11]; - - if (a !== out) { // If the source and destination differ, copy the unchanged rows - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - out[12] = a[12]; - out[13] = a[13]; - out[14] = a[14]; - out[15] = a[15]; - } - - // Perform axis-specific matrix multiplication - out[4] = a10 * c + a20 * s; - out[5] = a11 * c + a21 * s; - out[6] = a12 * c + a22 * s; - out[7] = a13 * c + a23 * s; - out[8] = a20 * c - a10 * s; - out[9] = a21 * c - a11 * s; - out[10] = a22 * c - a12 * s; - out[11] = a23 * c - a13 * s; - return out; - }; - - /** - * Rotates a matrix by the given angle around the Y axis - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the matrix to rotate - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat4} out - */ - mat4.rotateY = function (out, a, rad) { - var s = Math.sin(rad), - c = Math.cos(rad), - a00 = a[0], - a01 = a[1], - a02 = a[2], - a03 = a[3], - a20 = a[8], - a21 = a[9], - a22 = a[10], - a23 = a[11]; - - if (a !== out) { // If the source and destination differ, copy the unchanged rows - out[4] = a[4]; - out[5] = a[5]; - out[6] = a[6]; - out[7] = a[7]; - out[12] = a[12]; - out[13] = a[13]; - out[14] = a[14]; - out[15] = a[15]; - } - - // Perform axis-specific matrix multiplication - out[0] = a00 * c - a20 * s; - out[1] = a01 * c - a21 * s; - out[2] = a02 * c - a22 * s; - out[3] = a03 * c - a23 * s; - out[8] = a00 * s + a20 * c; - out[9] = a01 * s + a21 * c; - out[10] = a02 * s + a22 * c; - out[11] = a03 * s + a23 * c; - return out; - }; - - /** - * Rotates a matrix by the given angle around the Z axis - * - * @param {mat4} out the receiving matrix - * @param {mat4} a the matrix to rotate - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat4} out - */ - mat4.rotateZ = function (out, a, rad) { - var s = Math.sin(rad), - c = Math.cos(rad), - a00 = a[0], - a01 = a[1], - a02 = a[2], - a03 = a[3], - a10 = a[4], - a11 = a[5], - a12 = a[6], - a13 = a[7]; - - if (a !== out) { // If the source and destination differ, copy the unchanged last row - out[8] = a[8]; - out[9] = a[9]; - out[10] = a[10]; - out[11] = a[11]; - out[12] = a[12]; - out[13] = a[13]; - out[14] = a[14]; - out[15] = a[15]; - } - - // Perform axis-specific matrix multiplication - out[0] = a00 * c + a10 * s; - out[1] = a01 * c + a11 * s; - out[2] = a02 * c + a12 * s; - out[3] = a03 * c + a13 * s; - out[4] = a10 * c - a00 * s; - out[5] = a11 * c - a01 * s; - out[6] = a12 * c - a02 * s; - out[7] = a13 * c - a03 * s; - return out; - }; - - /** - * Creates a matrix from a vector translation - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.translate(dest, dest, vec); - * - * @param {mat4} out mat4 receiving operation result - * @param {vec3} v Translation vector - * @returns {mat4} out - */ - mat4.fromTranslation = function(out, v) { - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 0; - out[5] = 1; - out[6] = 0; - out[7] = 0; - out[8] = 0; - out[9] = 0; - out[10] = 1; - out[11] = 0; - out[12] = v[0]; - out[13] = v[1]; - out[14] = v[2]; - out[15] = 1; - return out; - } - - /** - * Creates a matrix from a vector scaling - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.scale(dest, dest, vec); - * - * @param {mat4} out mat4 receiving operation result - * @param {vec3} v Scaling vector - * @returns {mat4} out - */ - mat4.fromScaling = function(out, v) { - out[0] = v[0]; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 0; - out[5] = v[1]; - out[6] = 0; - out[7] = 0; - out[8] = 0; - out[9] = 0; - out[10] = v[2]; - out[11] = 0; - out[12] = 0; - out[13] = 0; - out[14] = 0; - out[15] = 1; - return out; - } - - /** - * Creates a matrix from a given angle around a given axis - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.rotate(dest, dest, rad, axis); - * - * @param {mat4} out mat4 receiving operation result - * @param {Number} rad the angle to rotate the matrix by - * @param {vec3} axis the axis to rotate around - * @returns {mat4} out - */ - mat4.fromRotation = function(out, rad, axis) { - var x = axis[0], y = axis[1], z = axis[2], - len = Math.sqrt(x * x + y * y + z * z), - s, c, t; - - if (Math.abs(len) < glMatrix.EPSILON) { return null; } - - len = 1 / len; - x *= len; - y *= len; - z *= len; - - s = Math.sin(rad); - c = Math.cos(rad); - t = 1 - c; - - // Perform rotation-specific matrix multiplication - out[0] = x * x * t + c; - out[1] = y * x * t + z * s; - out[2] = z * x * t - y * s; - out[3] = 0; - out[4] = x * y * t - z * s; - out[5] = y * y * t + c; - out[6] = z * y * t + x * s; - out[7] = 0; - out[8] = x * z * t + y * s; - out[9] = y * z * t - x * s; - out[10] = z * z * t + c; - out[11] = 0; - out[12] = 0; - out[13] = 0; - out[14] = 0; - out[15] = 1; - return out; - } - - /** - * Creates a matrix from the given angle around the X axis - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.rotateX(dest, dest, rad); - * - * @param {mat4} out mat4 receiving operation result - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat4} out - */ - mat4.fromXRotation = function(out, rad) { - var s = Math.sin(rad), - c = Math.cos(rad); - - // Perform axis-specific matrix multiplication - out[0] = 1; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 0; - out[5] = c; - out[6] = s; - out[7] = 0; - out[8] = 0; - out[9] = -s; - out[10] = c; - out[11] = 0; - out[12] = 0; - out[13] = 0; - out[14] = 0; - out[15] = 1; - return out; - } - - /** - * Creates a matrix from the given angle around the Y axis - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.rotateY(dest, dest, rad); - * - * @param {mat4} out mat4 receiving operation result - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat4} out - */ - mat4.fromYRotation = function(out, rad) { - var s = Math.sin(rad), - c = Math.cos(rad); - - // Perform axis-specific matrix multiplication - out[0] = c; - out[1] = 0; - out[2] = -s; - out[3] = 0; - out[4] = 0; - out[5] = 1; - out[6] = 0; - out[7] = 0; - out[8] = s; - out[9] = 0; - out[10] = c; - out[11] = 0; - out[12] = 0; - out[13] = 0; - out[14] = 0; - out[15] = 1; - return out; - } - - /** - * Creates a matrix from the given angle around the Z axis - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.rotateZ(dest, dest, rad); - * - * @param {mat4} out mat4 receiving operation result - * @param {Number} rad the angle to rotate the matrix by - * @returns {mat4} out - */ - mat4.fromZRotation = function(out, rad) { - var s = Math.sin(rad), - c = Math.cos(rad); - - // Perform axis-specific matrix multiplication - out[0] = c; - out[1] = s; - out[2] = 0; - out[3] = 0; - out[4] = -s; - out[5] = c; - out[6] = 0; - out[7] = 0; - out[8] = 0; - out[9] = 0; - out[10] = 1; - out[11] = 0; - out[12] = 0; - out[13] = 0; - out[14] = 0; - out[15] = 1; - return out; - } - - /** - * Creates a matrix from a quaternion rotation and vector translation - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.translate(dest, vec); - * var quatMat = mat4.create(); - * quat4.toMat4(quat, quatMat); - * mat4.multiply(dest, quatMat); - * - * @param {mat4} out mat4 receiving operation result - * @param {quat4} q Rotation quaternion - * @param {vec3} v Translation vector - * @returns {mat4} out - */ - mat4.fromRotationTranslation = function (out, q, v) { - // Quaternion math - var x = q[0], y = q[1], z = q[2], w = q[3], - x2 = x + x, - y2 = y + y, - z2 = z + z, - - xx = x * x2, - xy = x * y2, - xz = x * z2, - yy = y * y2, - yz = y * z2, - zz = z * z2, - wx = w * x2, - wy = w * y2, - wz = w * z2; - - out[0] = 1 - (yy + zz); - out[1] = xy + wz; - out[2] = xz - wy; - out[3] = 0; - out[4] = xy - wz; - out[5] = 1 - (xx + zz); - out[6] = yz + wx; - out[7] = 0; - out[8] = xz + wy; - out[9] = yz - wx; - out[10] = 1 - (xx + yy); - out[11] = 0; - out[12] = v[0]; - out[13] = v[1]; - out[14] = v[2]; - out[15] = 1; - - return out; - }; - - /** - * Creates a matrix from a quaternion rotation, vector translation and vector scale - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.translate(dest, vec); - * var quatMat = mat4.create(); - * quat4.toMat4(quat, quatMat); - * mat4.multiply(dest, quatMat); - * mat4.scale(dest, scale) - * - * @param {mat4} out mat4 receiving operation result - * @param {quat4} q Rotation quaternion - * @param {vec3} v Translation vector - * @param {vec3} s Scaling vector - * @returns {mat4} out - */ - mat4.fromRotationTranslationScale = function (out, q, v, s) { - // Quaternion math - var x = q[0], y = q[1], z = q[2], w = q[3], - x2 = x + x, - y2 = y + y, - z2 = z + z, - - xx = x * x2, - xy = x * y2, - xz = x * z2, - yy = y * y2, - yz = y * z2, - zz = z * z2, - wx = w * x2, - wy = w * y2, - wz = w * z2, - sx = s[0], - sy = s[1], - sz = s[2]; - - out[0] = (1 - (yy + zz)) * sx; - out[1] = (xy + wz) * sx; - out[2] = (xz - wy) * sx; - out[3] = 0; - out[4] = (xy - wz) * sy; - out[5] = (1 - (xx + zz)) * sy; - out[6] = (yz + wx) * sy; - out[7] = 0; - out[8] = (xz + wy) * sz; - out[9] = (yz - wx) * sz; - out[10] = (1 - (xx + yy)) * sz; - out[11] = 0; - out[12] = v[0]; - out[13] = v[1]; - out[14] = v[2]; - out[15] = 1; - - return out; - }; - - /** - * Creates a matrix from a quaternion rotation, vector translation and vector scale, rotating and scaling around the given origin - * This is equivalent to (but much faster than): - * - * mat4.identity(dest); - * mat4.translate(dest, vec); - * mat4.translate(dest, origin); - * var quatMat = mat4.create(); - * quat4.toMat4(quat, quatMat); - * mat4.multiply(dest, quatMat); - * mat4.scale(dest, scale) - * mat4.translate(dest, negativeOrigin); - * - * @param {mat4} out mat4 receiving operation result - * @param {quat4} q Rotation quaternion - * @param {vec3} v Translation vector - * @param {vec3} s Scaling vector - * @param {vec3} o The origin vector around which to scale and rotate - * @returns {mat4} out - */ - mat4.fromRotationTranslationScaleOrigin = function (out, q, v, s, o) { - // Quaternion math - var x = q[0], y = q[1], z = q[2], w = q[3], - x2 = x + x, - y2 = y + y, - z2 = z + z, - - xx = x * x2, - xy = x * y2, - xz = x * z2, - yy = y * y2, - yz = y * z2, - zz = z * z2, - wx = w * x2, - wy = w * y2, - wz = w * z2, - - sx = s[0], - sy = s[1], - sz = s[2], - - ox = o[0], - oy = o[1], - oz = o[2]; - - out[0] = (1 - (yy + zz)) * sx; - out[1] = (xy + wz) * sx; - out[2] = (xz - wy) * sx; - out[3] = 0; - out[4] = (xy - wz) * sy; - out[5] = (1 - (xx + zz)) * sy; - out[6] = (yz + wx) * sy; - out[7] = 0; - out[8] = (xz + wy) * sz; - out[9] = (yz - wx) * sz; - out[10] = (1 - (xx + yy)) * sz; - out[11] = 0; - out[12] = v[0] + ox - (out[0] * ox + out[4] * oy + out[8] * oz); - out[13] = v[1] + oy - (out[1] * ox + out[5] * oy + out[9] * oz); - out[14] = v[2] + oz - (out[2] * ox + out[6] * oy + out[10] * oz); - out[15] = 1; - - return out; - }; - - mat4.fromQuat = function (out, q) { - var x = q[0], y = q[1], z = q[2], w = q[3], - x2 = x + x, - y2 = y + y, - z2 = z + z, - - xx = x * x2, - yx = y * x2, - yy = y * y2, - zx = z * x2, - zy = z * y2, - zz = z * z2, - wx = w * x2, - wy = w * y2, - wz = w * z2; - - out[0] = 1 - yy - zz; - out[1] = yx + wz; - out[2] = zx - wy; - out[3] = 0; - - out[4] = yx - wz; - out[5] = 1 - xx - zz; - out[6] = zy + wx; - out[7] = 0; - - out[8] = zx + wy; - out[9] = zy - wx; - out[10] = 1 - xx - yy; - out[11] = 0; - - out[12] = 0; - out[13] = 0; - out[14] = 0; - out[15] = 1; - - return out; - }; - - /** - * Generates a frustum matrix with the given bounds - * - * @param {mat4} out mat4 frustum matrix will be written into - * @param {Number} left Left bound of the frustum - * @param {Number} right Right bound of the frustum - * @param {Number} bottom Bottom bound of the frustum - * @param {Number} top Top bound of the frustum - * @param {Number} near Near bound of the frustum - * @param {Number} far Far bound of the frustum - * @returns {mat4} out - */ - mat4.frustum = function (out, left, right, bottom, top, near, far) { - var rl = 1 / (right - left), - tb = 1 / (top - bottom), - nf = 1 / (near - far); - out[0] = (near * 2) * rl; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 0; - out[5] = (near * 2) * tb; - out[6] = 0; - out[7] = 0; - out[8] = (right + left) * rl; - out[9] = (top + bottom) * tb; - out[10] = (far + near) * nf; - out[11] = -1; - out[12] = 0; - out[13] = 0; - out[14] = (far * near * 2) * nf; - out[15] = 0; - return out; - }; - - /** - * Generates a perspective projection matrix with the given bounds - * - * @param {mat4} out mat4 frustum matrix will be written into - * @param {number} fovy Vertical field of view in radians - * @param {number} aspect Aspect ratio. typically viewport width/height - * @param {number} near Near bound of the frustum - * @param {number} far Far bound of the frustum - * @returns {mat4} out - */ - mat4.perspective = function (out, fovy, aspect, near, far) { - var f = 1.0 / Math.tan(fovy / 2), - nf = 1 / (near - far); - out[0] = f / aspect; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 0; - out[5] = f; - out[6] = 0; - out[7] = 0; - out[8] = 0; - out[9] = 0; - out[10] = (far + near) * nf; - out[11] = -1; - out[12] = 0; - out[13] = 0; - out[14] = (2 * far * near) * nf; - out[15] = 0; - return out; - }; - - /** - * Generates a perspective projection matrix with the given field of view. - * This is primarily useful for generating projection matrices to be used - * with the still experiemental WebVR API. - * - * @param {mat4} out mat4 frustum matrix will be written into - * @param {number} fov Object containing the following values: upDegrees, downDegrees, leftDegrees, rightDegrees - * @param {number} near Near bound of the frustum - * @param {number} far Far bound of the frustum - * @returns {mat4} out - */ - mat4.perspectiveFromFieldOfView = function (out, fov, near, far) { - var upTan = Math.tan(fov.upDegrees * Math.PI/180.0), - downTan = Math.tan(fov.downDegrees * Math.PI/180.0), - leftTan = Math.tan(fov.leftDegrees * Math.PI/180.0), - rightTan = Math.tan(fov.rightDegrees * Math.PI/180.0), - xScale = 2.0 / (leftTan + rightTan), - yScale = 2.0 / (upTan + downTan); - - out[0] = xScale; - out[1] = 0.0; - out[2] = 0.0; - out[3] = 0.0; - out[4] = 0.0; - out[5] = yScale; - out[6] = 0.0; - out[7] = 0.0; - out[8] = -((leftTan - rightTan) * xScale * 0.5); - out[9] = ((upTan - downTan) * yScale * 0.5); - out[10] = far / (near - far); - out[11] = -1.0; - out[12] = 0.0; - out[13] = 0.0; - out[14] = (far * near) / (near - far); - out[15] = 0.0; - return out; - } - - /** - * Generates a orthogonal projection matrix with the given bounds - * - * @param {mat4} out mat4 frustum matrix will be written into - * @param {number} left Left bound of the frustum - * @param {number} right Right bound of the frustum - * @param {number} bottom Bottom bound of the frustum - * @param {number} top Top bound of the frustum - * @param {number} near Near bound of the frustum - * @param {number} far Far bound of the frustum - * @returns {mat4} out - */ - mat4.ortho = function (out, left, right, bottom, top, near, far) { - var lr = 1 / (left - right), - bt = 1 / (bottom - top), - nf = 1 / (near - far); - out[0] = -2 * lr; - out[1] = 0; - out[2] = 0; - out[3] = 0; - out[4] = 0; - out[5] = -2 * bt; - out[6] = 0; - out[7] = 0; - out[8] = 0; - out[9] = 0; - out[10] = 2 * nf; - out[11] = 0; - out[12] = (left + right) * lr; - out[13] = (top + bottom) * bt; - out[14] = (far + near) * nf; - out[15] = 1; - return out; - }; - - /** - * Generates a look-at matrix with the given eye position, focal point, and up axis - * - * @param {mat4} out mat4 frustum matrix will be written into - * @param {vec3} eye Position of the viewer - * @param {vec3} center Point the viewer is looking at - * @param {vec3} up vec3 pointing up - * @returns {mat4} out - */ - mat4.lookAt = function (out, eye, center, up) { - var x0, x1, x2, y0, y1, y2, z0, z1, z2, len, - eyex = eye[0], - eyey = eye[1], - eyez = eye[2], - upx = up[0], - upy = up[1], - upz = up[2], - centerx = center[0], - centery = center[1], - centerz = center[2]; - - if (Math.abs(eyex - centerx) < glMatrix.EPSILON && - Math.abs(eyey - centery) < glMatrix.EPSILON && - Math.abs(eyez - centerz) < glMatrix.EPSILON) { - return mat4.identity(out); - } - - z0 = eyex - centerx; - z1 = eyey - centery; - z2 = eyez - centerz; - - len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2); - z0 *= len; - z1 *= len; - z2 *= len; - - x0 = upy * z2 - upz * z1; - x1 = upz * z0 - upx * z2; - x2 = upx * z1 - upy * z0; - len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2); - if (!len) { - x0 = 0; - x1 = 0; - x2 = 0; - } else { - len = 1 / len; - x0 *= len; - x1 *= len; - x2 *= len; - } + /** + * 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; - y0 = z1 * x2 - z2 * x1; - y1 = z2 * x0 - z0 * x2; - y2 = z0 * x1 - z1 * x0; + function _trace(current, color, label, edgelabel) { + var i, y, x; - len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2); - if (!len) { - y0 = 0; - y1 = 0; - y2 = 0; - } else { - len = 1 / len; - y0 *= len; - y1 *= len; - y2 *= len; - } + 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; + } - out[0] = x0; - out[1] = y0; - out[2] = z0; - out[3] = 0; - out[4] = x1; - out[5] = y1; - out[6] = z1; - out[7] = 0; - out[8] = x2; - out[9] = y2; - out[10] = z2; - out[11] = 0; - out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez); - out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez); - out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez); - out[15] = 1; + function vertex2D(x, y, dir) { + return { + dir: dir, + x: x, + y: y, + next: null, + prev: null + }; + } - return out; - }; + function _contourTracing(sy, sx, label, color, edgelabel) { + var Fv = null, + Cv, + P, + ldir, + current = { + cx: sx, + cy: sy, + dir: 0 + }; - /** - * Returns a string representation of a mat4 - * - * @param {mat4} mat matrix to represent as a string - * @returns {String} string representation of the matrix - */ - mat4.str = function (a) { - return 'mat4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ', ' + - a[4] + ', ' + a[5] + ', ' + a[6] + ', ' + a[7] + ', ' + - a[8] + ', ' + a[9] + ', ' + a[10] + ', ' + a[11] + ', ' + - a[12] + ', ' + a[13] + ', ' + a[14] + ', ' + a[15] + ')'; - }; + 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; + } - /** - * Returns Frobenius norm of a mat4 - * - * @param {mat4} a the matrix to calculate Frobenius norm of - * @returns {Number} Frobenius norm - */ - mat4.frob = function (a) { - return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2) + Math.pow(a[9], 2) + Math.pow(a[10], 2) + Math.pow(a[11], 2) + Math.pow(a[12], 2) + Math.pow(a[13], 2) + Math.pow(a[14], 2) + Math.pow(a[15], 2) )) + 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); + } + }; + } }; - - module.exports = mat4; - + /* harmony default export */ exports["a"] = Tracer; /***/ }, -/* 13 */ +/* 30 */ /***/ function(module, exports, __webpack_require__) { - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__barcode_reader__ = __webpack_require__(5); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__common_array_helper__ = __webpack_require__(8); - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ + function Code39Reader() { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].call(this); + } - var glMatrix = __webpack_require__(8); - var mat3 = __webpack_require__(11); - var vec3 = __webpack_require__(14); - var vec4 = __webpack_require__(15); + 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 } + }; - /** - * @class Quaternion - * @name quat - */ - var quat = {}; + Code39Reader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].prototype, properties); + Code39Reader.prototype.constructor = Code39Reader; - /** - * Creates a new identity quat - * - * @returns {quat} a new quaternion - */ - quat.create = function() { - var out = new glMatrix.ARRAY_TYPE(4); - out[0] = 0; - out[1] = 0; - out[2] = 0; - out[3] = 1; - return out; - }; + Code39Reader.prototype._toCounters = function (start, counter) { + var self = this, + numCounters = counter.length, + end = self._row.length, + isWhite = !self._row[start], + i, + counterPos = 0; - /** - * Sets a quaternion to represent the shortest rotation from one - * vector to another. - * - * Both vectors are assumed to be unit length. - * - * @param {quat} out the receiving quaternion. - * @param {vec3} a the initial vector - * @param {vec3} b the destination vector - * @returns {quat} out - */ - quat.rotationTo = (function() { - var tmpvec3 = vec3.create(); - var xUnitVec3 = vec3.fromValues(1,0,0); - var yUnitVec3 = vec3.fromValues(0,1,0); + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_array_helper__["a"].init(counter, 0); - return function(out, a, b) { - var dot = vec3.dot(a, b); - if (dot < -0.999999) { - vec3.cross(tmpvec3, xUnitVec3, a); - if (vec3.length(tmpvec3) < 0.000001) - vec3.cross(tmpvec3, yUnitVec3, a); - vec3.normalize(tmpvec3, tmpvec3); - quat.setAxisAngle(out, tmpvec3, Math.PI); - return out; - } else if (dot > 0.999999) { - out[0] = 0; - out[1] = 0; - out[2] = 0; - out[3] = 1; - return out; + for (i = start; i < end; i++) { + if (self._row[i] ^ isWhite) { + counter[counterPos]++; } else { - vec3.cross(tmpvec3, a, b); - out[0] = tmpvec3[0]; - out[1] = tmpvec3[1]; - out[2] = tmpvec3[2]; - out[3] = 1 + dot; - return quat.normalize(out, out); + counterPos++; + if (counterPos === numCounters) { + break; + } else { + counter[counterPos] = 1; + isWhite = !isWhite; + } } - }; - })(); - - /** - * Sets the specified quaternion with values corresponding to the given - * axes. Each axis is a vec3 and is expected to be unit length and - * perpendicular to all other specified axes. - * - * @param {vec3} view the vector representing the viewing direction - * @param {vec3} right the vector representing the local "right" direction - * @param {vec3} up the vector representing the local "up" direction - * @returns {quat} out - */ - quat.setAxes = (function() { - var matr = mat3.create(); - - return function(out, view, right, up) { - matr[0] = right[0]; - matr[3] = right[1]; - matr[6] = right[2]; + } - matr[1] = up[0]; - matr[4] = up[1]; - matr[7] = up[2]; + return counter; + }; - matr[2] = -view[0]; - matr[5] = -view[1]; - matr[8] = -view[2]; + 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; - return quat.normalize(out, quat.fromMat3(out, matr)); - }; - })(); - - /** - * Creates a new quat initialized with values from an existing quaternion - * - * @param {quat} a quaternion to clone - * @returns {quat} a new quaternion - * @function - */ - quat.clone = vec4.clone; - - /** - * Creates a new quat initialized with the given values - * - * @param {Number} x X component - * @param {Number} y Y component - * @param {Number} z Z component - * @param {Number} w W component - * @returns {quat} a new quaternion - * @function - */ - quat.fromValues = vec4.fromValues; + if (!start) { + return null; + } + nextStart = self._nextSet(self._row, start.end); - /** - * Copy the values from one quat to another - * - * @param {quat} out the receiving quaternion - * @param {quat} a the source quaternion - * @returns {quat} out - * @function - */ - quat.copy = vec4.copy; + 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 += /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_array_helper__["a"].sum(counters); + nextStart = self._nextSet(self._row, nextStart); + } while (decodedChar !== '*'); + result.pop(); - /** - * Set the components of a quat to the given values - * - * @param {quat} out the receiving quaternion - * @param {Number} x X component - * @param {Number} y Y component - * @param {Number} z Z component - * @param {Number} w W component - * @returns {quat} out - * @function - */ - quat.set = vec4.set; + if (!result.length) { + return null; + } - /** - * Set a quat to the identity quaternion - * - * @param {quat} out the receiving quaternion - * @returns {quat} out - */ - quat.identity = function(out) { - out[0] = 0; - out[1] = 0; - out[2] = 0; - out[3] = 1; - return out; - }; + if (!self._verifyTrailingWhitespace(lastStart, nextStart, counters)) { + return null; + } - /** - * Sets a quat from the given angle and rotation axis, - * then returns it. - * - * @param {quat} out the receiving quaternion - * @param {vec3} axis the axis around which to rotate - * @param {Number} rad the angle in radians - * @returns {quat} out - **/ - quat.setAxisAngle = function(out, axis, rad) { - rad = rad * 0.5; - var s = Math.sin(rad); - out[0] = s * axis[0]; - out[1] = s * axis[1]; - out[2] = s * axis[2]; - out[3] = Math.cos(rad); - return out; + return { + code: result.join(""), + start: start.start, + end: nextStart, + startInfo: start, + decodedCodes: result + }; }; - /** - * Adds two quat's - * - * @param {quat} out the receiving quaternion - * @param {quat} a the first operand - * @param {quat} b the second operand - * @returns {quat} out - * @function - */ - quat.add = vec4.add; - - /** - * Multiplies two quat's - * - * @param {quat} out the receiving quaternion - * @param {quat} a the first operand - * @param {quat} b the second operand - * @returns {quat} out - */ - quat.multiply = function(out, a, b) { - var ax = a[0], ay = a[1], az = a[2], aw = a[3], - bx = b[0], by = b[1], bz = b[2], bw = b[3]; + Code39Reader.prototype._verifyTrailingWhitespace = function (lastStart, nextStart, counters) { + var trailingWhitespaceEnd, + patternSize = /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_array_helper__["a"].sum(counters); - out[0] = ax * bw + aw * bx + ay * bz - az * by; - out[1] = ay * bw + aw * by + az * bx - ax * bz; - out[2] = az * bw + aw * bz + ax * by - ay * bx; - out[3] = aw * bw - ax * bx - ay * by - az * bz; - return out; + trailingWhitespaceEnd = nextStart - lastStart - patternSize; + if (trailingWhitespaceEnd * 3 >= patternSize) { + return true; + } + return false; }; - /** - * Alias for {@link quat.multiply} - * @function - */ - quat.mul = quat.multiply; - - /** - * Scales a quat by a scalar number - * - * @param {quat} out the receiving vector - * @param {quat} a the vector to scale - * @param {Number} b amount to scale the vector by - * @returns {quat} out - * @function - */ - quat.scale = vec4.scale; - - /** - * Rotates a quaternion by the given angle about the X axis - * - * @param {quat} out quat receiving operation result - * @param {quat} a quat to rotate - * @param {number} rad angle (in radians) to rotate - * @returns {quat} out - */ - quat.rotateX = function (out, a, rad) { - rad *= 0.5; - - var ax = a[0], ay = a[1], az = a[2], aw = a[3], - bx = Math.sin(rad), bw = Math.cos(rad); + Code39Reader.prototype._patternToChar = function (pattern) { + var i, + self = this; - out[0] = ax * bw + aw * bx; - out[1] = ay * bw + az * bx; - out[2] = az * bw - ay * bx; - out[3] = aw * bw - ax * bx; - return out; + for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) { + if (self.CHARACTER_ENCODINGS[i] === pattern) { + return String.fromCharCode(self.ALPHABET[i]); + } + } + return -1; }; - /** - * Rotates a quaternion by the given angle about the Y axis - * - * @param {quat} out quat receiving operation result - * @param {quat} a quat to rotate - * @param {number} rad angle (in radians) to rotate - * @returns {quat} out - */ - quat.rotateY = function (out, a, rad) { - rad *= 0.5; + Code39Reader.prototype._findNextWidth = function (counters, current) { + var i, + minWidth = Number.MAX_VALUE; - var ax = a[0], ay = a[1], az = a[2], aw = a[3], - by = Math.sin(rad), bw = Math.cos(rad); + for (i = 0; i < counters.length; i++) { + if (counters[i] < minWidth && counters[i] > current) { + minWidth = counters[i]; + } + } - out[0] = ax * bw - az * by; - out[1] = ay * bw + aw * by; - out[2] = az * bw + ax * by; - out[3] = aw * bw - ay * by; - return out; + return minWidth; }; - /** - * Rotates a quaternion by the given angle about the Z axis - * - * @param {quat} out quat receiving operation result - * @param {quat} a quat to rotate - * @param {number} rad angle (in radians) to rotate - * @returns {quat} out - */ - quat.rotateZ = function (out, a, rad) { - rad *= 0.5; - - var ax = a[0], ay = a[1], az = a[2], aw = a[3], - bz = Math.sin(rad), bw = Math.cos(rad); - - out[0] = ax * bw + ay * bz; - out[1] = ay * bw - ax * bz; - out[2] = az * bw + aw * bz; - out[3] = aw * bw - az * bz; - return out; - }; + Code39Reader.prototype._toPattern = function (counters) { + var numCounters = counters.length, + maxNarrowWidth = 0, + numWideBars = numCounters, + wideBarWidth = 0, + self = this, + pattern, + i; - /** - * Calculates the W component of a quat from the X, Y, and Z components. - * Assumes that quaternion is 1 unit in length. - * Any existing W component will be ignored. - * - * @param {quat} out the receiving quaternion - * @param {quat} a quat to calculate W component of - * @returns {quat} out - */ - quat.calculateW = function (out, a) { - var x = a[0], y = a[1], z = a[2]; + 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]; + } + } - out[0] = x; - out[1] = y; - out[2] = z; - out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z)); - return out; + 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; }; - /** - * Calculates the dot product of two quat's - * - * @param {quat} a the first operand - * @param {quat} b the second operand - * @returns {Number} dot product of a and b - * @function - */ - quat.dot = vec4.dot; - - /** - * Performs a linear interpolation between two quat's - * - * @param {quat} out the receiving quaternion - * @param {quat} a the first operand - * @param {quat} b the second operand - * @param {Number} t interpolation amount between the two inputs - * @returns {quat} out - * @function - */ - quat.lerp = vec4.lerp; - - /** - * Performs a spherical linear interpolation between two quat - * - * @param {quat} out the receiving quaternion - * @param {quat} a the first operand - * @param {quat} b the second operand - * @param {Number} t interpolation amount between the two inputs - * @returns {quat} out - */ - quat.slerp = function (out, a, b, t) { - // benchmarks: - // http://jsperf.com/quaternion-slerp-implementations - - var ax = a[0], ay = a[1], az = a[2], aw = a[3], - bx = b[0], by = b[1], bz = b[2], bw = b[3]; - - var omega, cosom, sinom, scale0, scale1; - - // calc cosine - cosom = ax * bx + ay * by + az * bz + aw * bw; - // adjust signs (if necessary) - if ( cosom < 0.0 ) { - cosom = -cosom; - bx = - bx; - by = - by; - bz = - bz; - bw = - bw; - } - // calculate coefficients - if ( (1.0 - cosom) > 0.000001 ) { - // standard case (slerp) - omega = Math.acos(cosom); - sinom = Math.sin(omega); - scale0 = Math.sin((1.0 - t) * omega) / sinom; - scale1 = Math.sin(t * omega) / sinom; - } else { - // "from" and "to" quaternions are very close - // ... so we can do a linear interpolation - scale0 = 1.0 - t; - scale1 = t; - } - // calculate final values - out[0] = scale0 * ax + scale1 * bx; - out[1] = scale0 * ay + scale1 * by; - out[2] = scale0 * az + scale1 * bz; - out[3] = scale0 * aw + scale1 * bw; - - return out; - }; - - /** - * Performs a spherical linear interpolation with two control points - * - * @param {quat} out the receiving quaternion - * @param {quat} a the first operand - * @param {quat} b the second operand - * @param {quat} c the third operand - * @param {quat} d the fourth operand - * @param {Number} t interpolation amount - * @returns {quat} out - */ - quat.sqlerp = (function () { - var temp1 = quat.create(); - var temp2 = quat.create(); - - return function (out, a, b, c, d, t) { - quat.slerp(temp1, a, d, t); - quat.slerp(temp2, b, c, t); - quat.slerp(out, temp1, temp2, 2 * t * (1 - t)); - - return out; - }; - }()); + 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; - /** - * Calculates the inverse of a quat - * - * @param {quat} out the receiving quaternion - * @param {quat} a quat to calculate inverse of - * @returns {quat} out - */ - quat.invert = function(out, a) { - var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], - dot = a0*a0 + a1*a1 + a2*a2 + a3*a3, - invDot = dot ? 1.0/dot : 0; - - // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0 + 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 + }; + } + } - out[0] = -a0*invDot; - out[1] = -a1*invDot; - out[2] = -a2*invDot; - out[3] = a3*invDot; - return out; + 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; }; - /** - * Calculates the conjugate of a quat - * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result. - * - * @param {quat} out the receiving quaternion - * @param {quat} a quat to calculate conjugate of - * @returns {quat} out - */ - quat.conjugate = function (out, a) { - out[0] = -a[0]; - out[1] = -a[1]; - out[2] = -a[2]; - out[3] = a[3]; - return out; - }; + /* harmony default export */ exports["a"] = Code39Reader; + +/***/ }, +/* 31 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = dot /** - * Calculates the length of a quat + * Calculates the dot product of two vec2's * - * @param {quat} a vector to calculate length of - * @returns {Number} length of a - * @function - */ - quat.length = vec4.length; - - /** - * Alias for {@link quat.length} - * @function + * @param {vec2} a the first operand + * @param {vec2} b the second operand + * @returns {Number} dot product of a and b */ - quat.len = quat.length; + function dot(a, b) { + return a[0] * b[0] + a[1] * b[1] + } + +/***/ }, +/* 32 */ +/***/ function(module, exports, __webpack_require__) { + + var stackClear = __webpack_require__(133), + stackDelete = __webpack_require__(134), + stackGet = __webpack_require__(135), + stackHas = __webpack_require__(136), + stackSet = __webpack_require__(137); /** - * Calculates the squared length of a quat + * Creates a stack cache object to store key-value pairs. * - * @param {quat} a vector to calculate squared length of - * @returns {Number} squared length of a - * @function + * @private + * @constructor + * @param {Array} [values] The values to cache. */ - quat.squaredLength = vec4.squaredLength; + function Stack(values) { + var index = -1, + length = values ? values.length : 0; - /** - * Alias for {@link quat.squaredLength} - * @function - */ - quat.sqrLen = quat.squaredLength; + this.clear(); + while (++index < length) { + var entry = values[index]; + this.set(entry[0], entry[1]); + } + } - /** - * Normalize a quat - * - * @param {quat} out the receiving quaternion - * @param {quat} a quaternion to normalize - * @returns {quat} out - * @function - */ - quat.normalize = vec4.normalize; + // Add functions to the `Stack` cache. + Stack.prototype.clear = stackClear; + Stack.prototype['delete'] = stackDelete; + Stack.prototype.get = stackGet; + Stack.prototype.has = stackHas; + Stack.prototype.set = stackSet; + module.e = Stack; + + +/***/ }, +/* 33 */ +/***/ function(module, exports, __webpack_require__) { + /** - * Creates a quaternion from the given 3x3 rotation matrix. + * A specialized version of `_.forEach` for arrays without support for + * iteratee shorthands. * - * NOTE: The resultant quaternion is not normalized, so you should be sure - * to renormalize the quaternion yourself where necessary. - * - * @param {quat} out the receiving quaternion - * @param {mat3} m rotation matrix - * @returns {quat} out - * @function + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns `array`. */ - quat.fromMat3 = function(out, m) { - // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes - // article "Quaternion Calculus and Fast Animation". - var fTrace = m[0] + m[4] + m[8]; - var fRoot; + function arrayEach(array, iteratee) { + var index = -1, + length = array.length; - if ( fTrace > 0.0 ) { - // |w| > 1/2, may as well choose w > 1/2 - fRoot = Math.sqrt(fTrace + 1.0); // 2w - out[3] = 0.5 * fRoot; - fRoot = 0.5/fRoot; // 1/(4w) - out[0] = (m[5]-m[7])*fRoot; - out[1] = (m[6]-m[2])*fRoot; - out[2] = (m[1]-m[3])*fRoot; - } else { - // |w| <= 1/2 - var i = 0; - if ( m[4] > m[0] ) - i = 1; - if ( m[8] > m[i*3+i] ) - i = 2; - var j = (i+1)%3; - var k = (i+2)%3; - - fRoot = Math.sqrt(m[i*3+i]-m[j*3+j]-m[k*3+k] + 1.0); - out[i] = 0.5 * fRoot; - fRoot = 0.5 / fRoot; - out[3] = (m[j*3+k] - m[k*3+j]) * fRoot; - out[j] = (m[j*3+i] + m[i*3+j]) * fRoot; - out[k] = (m[k*3+i] + m[i*3+k]) * fRoot; + while (++index < length) { + if (iteratee(array[index], index, array) === false) { + break; } - - return out; - }; + } + return array; + } + + module.e = arrayEach; + + +/***/ }, +/* 34 */ +/***/ function(module, exports, __webpack_require__) { + + var eq = __webpack_require__(15); /** - * Returns a string representation of a quatenion + * This function is like `assignValue` except that it doesn't assign + * `undefined` values. * - * @param {quat} vec vector to represent as a string - * @returns {String} string representation of the vector - */ - quat.str = function (a) { - return 'quat(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')'; - }; + * @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)) || + (typeof key == 'number' && value === undefined && !(key in object))) { + object[key] = value; + } + } - module.exports = quat; + module.e = assignMergeValue; /***/ }, -/* 14 */ +/* 35 */ /***/ function(module, exports, __webpack_require__) { - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. + var eq = __webpack_require__(15); - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ - - var glMatrix = __webpack_require__(8); + /** Used for built-in method references. */ + var objectProto = Object.prototype; - /** - * @class 3 Dimensional Vector - * @name vec3 - */ - var vec3 = {}; + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; /** - * Creates a new, empty vec3 + * Assigns `value` to `key` of `object` if the existing value is not equivalent + * using [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero) + * for equality comparisons. * - * @returns {vec3} a new 3D vector - */ - vec3.create = function() { - var out = new glMatrix.ARRAY_TYPE(3); - out[0] = 0; - out[1] = 0; - out[2] = 0; - return out; - }; + * @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))) { + object[key] = value; + } + } - /** - * Creates a new vec3 initialized with values from an existing vector - * - * @param {vec3} a vector to clone - * @returns {vec3} a new 3D vector - */ - vec3.clone = function(a) { - var out = new glMatrix.ARRAY_TYPE(3); - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - return out; - }; + module.e = assignValue; + + +/***/ }, +/* 36 */ +/***/ function(module, exports, __webpack_require__) { + + var assocIndexOf = __webpack_require__(11); - /** - * Creates a new vec3 initialized with the given values - * - * @param {Number} x X component - * @param {Number} y Y component - * @param {Number} z Z component - * @returns {vec3} a new 3D vector - */ - vec3.fromValues = function(x, y, z) { - var out = new glMatrix.ARRAY_TYPE(3); - out[0] = x; - out[1] = y; - out[2] = z; - return out; - }; + /** Used for built-in method references. */ + var arrayProto = Array.prototype; - /** - * Copy the values from one vec3 to another - * - * @param {vec3} out the receiving vector - * @param {vec3} a the source vector - * @returns {vec3} out - */ - vec3.copy = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - return out; - }; + /** Built-in value references. */ + var splice = arrayProto.splice; /** - * Set the components of a vec3 to the given values + * Removes `key` and its value from the associative array. * - * @param {vec3} out the receiving vector - * @param {Number} x X component - * @param {Number} y Y component - * @param {Number} z Z component - * @returns {vec3} out + * @private + * @param {Array} array The array to query. + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. */ - vec3.set = function(out, x, y, z) { - out[0] = x; - out[1] = y; - out[2] = z; - return out; - }; + function assocDelete(array, key) { + var index = assocIndexOf(array, key); + if (index < 0) { + return false; + } + var lastIndex = array.length - 1; + if (index == lastIndex) { + array.pop(); + } else { + splice.call(array, index, 1); + } + return true; + } - /** - * Adds two vec3's - * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {vec3} out - */ - vec3.add = function(out, a, b) { - out[0] = a[0] + b[0]; - out[1] = a[1] + b[1]; - out[2] = a[2] + b[2]; - return out; - }; + module.e = assocDelete; + + +/***/ }, +/* 37 */ +/***/ function(module, exports, __webpack_require__) { + + var assocIndexOf = __webpack_require__(11); /** - * Subtracts vector b from vector a + * Gets the associative array value for `key`. * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {vec3} out + * @private + * @param {Array} array The array to query. + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. */ - vec3.subtract = function(out, a, b) { - out[0] = a[0] - b[0]; - out[1] = a[1] - b[1]; - out[2] = a[2] - b[2]; - return out; - }; + function assocGet(array, key) { + var index = assocIndexOf(array, key); + return index < 0 ? undefined : array[index][1]; + } - /** - * Alias for {@link vec3.subtract} - * @function - */ - vec3.sub = vec3.subtract; + module.e = assocGet; + + +/***/ }, +/* 38 */ +/***/ function(module, exports, __webpack_require__) { + + var assocIndexOf = __webpack_require__(11); /** - * Multiplies two vec3's + * Checks if an associative array value for `key` exists. * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {vec3} out + * @private + * @param {Array} array The array to query. + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. */ - vec3.multiply = function(out, a, b) { - out[0] = a[0] * b[0]; - out[1] = a[1] * b[1]; - out[2] = a[2] * b[2]; - return out; - }; + function assocHas(array, key) { + return assocIndexOf(array, key) > -1; + } - /** - * Alias for {@link vec3.multiply} - * @function - */ - vec3.mul = vec3.multiply; + module.e = assocHas; + + +/***/ }, +/* 39 */ +/***/ function(module, exports, __webpack_require__) { + + var assocIndexOf = __webpack_require__(11); /** - * Divides two vec3's + * Sets the associative array `key` to `value`. * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {vec3} out - */ - vec3.divide = function(out, a, b) { - out[0] = a[0] / b[0]; - out[1] = a[1] / b[1]; - out[2] = a[2] / b[2]; - return out; - }; + * @private + * @param {Array} array The array to modify. + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + */ + function assocSet(array, key, value) { + var index = assocIndexOf(array, key); + if (index < 0) { + array.push([key, value]); + } else { + array[index][1] = value; + } + } - /** - * Alias for {@link vec3.divide} - * @function - */ - vec3.div = vec3.divide; + module.e = assocSet; + + +/***/ }, +/* 40 */ +/***/ function(module, exports, __webpack_require__) { + + var Uint8Array = __webpack_require__(84); /** - * Returns the minimum of two vec3's + * Creates a clone of `arrayBuffer`. * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {vec3} out + * @private + * @param {ArrayBuffer} arrayBuffer The array buffer to clone. + * @returns {ArrayBuffer} Returns the cloned array buffer. */ - vec3.min = function(out, a, b) { - out[0] = Math.min(a[0], b[0]); - out[1] = Math.min(a[1], b[1]); - out[2] = Math.min(a[2], b[2]); - return out; - }; + function cloneArrayBuffer(arrayBuffer) { + var result = new arrayBuffer.constructor(arrayBuffer.byteLength); + new Uint8Array(result).set(new Uint8Array(arrayBuffer)); + return result; + } + module.e = cloneArrayBuffer; + + +/***/ }, +/* 41 */ +/***/ function(module, exports, __webpack_require__) { + /** - * Returns the maximum of two vec3's + * Copies the values of `source` to `array`. * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {vec3} out + * @private + * @param {Array} source The array to copy values from. + * @param {Array} [array=[]] The array to copy values to. + * @returns {Array} Returns `array`. */ - vec3.max = function(out, a, b) { - out[0] = Math.max(a[0], b[0]); - out[1] = Math.max(a[1], b[1]); - out[2] = Math.max(a[2], b[2]); - return out; - }; + function copyArray(source, array) { + var index = -1, + length = source.length; - /** - * Scales a vec3 by a scalar number - * - * @param {vec3} out the receiving vector - * @param {vec3} a the vector to scale - * @param {Number} b amount to scale the vector by - * @returns {vec3} out - */ - vec3.scale = function(out, a, b) { - out[0] = a[0] * b; - out[1] = a[1] * b; - out[2] = a[2] * b; - return out; - }; + array || (array = Array(length)); + while (++index < length) { + array[index] = source[index]; + } + return array; + } - /** - * Adds two vec3's after scaling the second operand by a scalar value - * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @param {Number} scale the amount to scale b by before adding - * @returns {vec3} out - */ - vec3.scaleAndAdd = function(out, a, b, scale) { - out[0] = a[0] + (b[0] * scale); - out[1] = a[1] + (b[1] * scale); - out[2] = a[2] + (b[2] * scale); - return out; - }; + module.e = copyArray; + + +/***/ }, +/* 42 */ +/***/ function(module, exports, __webpack_require__) { + + var nativeCreate = __webpack_require__(14); - /** - * Calculates the euclidian distance between two vec3's - * - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {Number} distance between a and b - */ - vec3.distance = function(a, b) { - var x = b[0] - a[0], - y = b[1] - a[1], - z = b[2] - a[2]; - return Math.sqrt(x*x + y*y + z*z); - }; + /** Used for built-in method references. */ + var objectProto = Object.prototype; - /** - * Alias for {@link vec3.distance} - * @function - */ - vec3.dist = vec3.distance; + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; /** - * Calculates the squared euclidian distance between two vec3's + * Checks if a hash value for `key` exists. * - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {Number} squared distance between a and b + * @private + * @param {Object} hash The hash to query. + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. */ - vec3.squaredDistance = function(a, b) { - var x = b[0] - a[0], - y = b[1] - a[1], - z = b[2] - a[2]; - return x*x + y*y + z*z; - }; + function hashHas(hash, key) { + return nativeCreate ? hash[key] !== undefined : hasOwnProperty.call(hash, key); + } - /** - * Alias for {@link vec3.squaredDistance} - * @function - */ - vec3.sqrDist = vec3.squaredDistance; + module.e = hashHas; + + +/***/ }, +/* 43 */ +/***/ function(module, exports, __webpack_require__) { + + var baseTimes = __webpack_require__(103), + isArguments = __webpack_require__(24), + isArray = __webpack_require__(4), + isLength = __webpack_require__(27), + isString = __webpack_require__(142); /** - * Calculates the length of a vec3 + * Creates an array of index keys for `object` values of arrays, + * `arguments` objects, and strings, otherwise `null` is returned. * - * @param {vec3} a vector to calculate length of - * @returns {Number} length of a + * @private + * @param {Object} object The object to query. + * @returns {Array|null} Returns index keys, else `null`. */ - vec3.length = function (a) { - var x = a[0], - y = a[1], - z = a[2]; - return Math.sqrt(x*x + y*y + z*z); - }; + function indexKeys(object) { + var length = object ? object.length : undefined; + if (isLength(length) && + (isArray(object) || isString(object) || isArguments(object))) { + return baseTimes(length, String); + } + return null; + } - /** - * Alias for {@link vec3.length} - * @function - */ - vec3.len = vec3.length; + module.e = indexKeys; + + +/***/ }, +/* 44 */ +/***/ function(module, exports, __webpack_require__) { + + var isLength = __webpack_require__(27), + isObjectLike = __webpack_require__(7); - /** - * Calculates the squared length of a vec3 - * - * @param {vec3} a vector to calculate squared length of - * @returns {Number} squared length of a - */ - vec3.squaredLength = function (a) { - var x = a[0], - y = a[1], - z = a[2]; - return x*x + y*y + z*z; - }; + /** `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]'; - /** - * Alias for {@link vec3.squaredLength} - * @function - */ - vec3.sqrLen = vec3.squaredLength; + var arrayBufferTag = '[object ArrayBuffer]', + 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]'; - /** - * Negates the components of a vec3 - * - * @param {vec3} out the receiving vector - * @param {vec3} a vector to negate - * @returns {vec3} out - */ - vec3.negate = function(out, a) { - out[0] = -a[0]; - out[1] = -a[1]; - out[2] = -a[2]; - return out; - }; + /** 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[dateTag] = typedArrayTags[errorTag] = + typedArrayTags[funcTag] = typedArrayTags[mapTag] = + typedArrayTags[numberTag] = typedArrayTags[objectTag] = + typedArrayTags[regexpTag] = typedArrayTags[setTag] = + typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false; - /** - * Returns the inverse of the components of a vec3 - * - * @param {vec3} out the receiving vector - * @param {vec3} a vector to invert - * @returns {vec3} out - */ - vec3.inverse = function(out, a) { - out[0] = 1.0 / a[0]; - out[1] = 1.0 / a[1]; - out[2] = 1.0 / a[2]; - return out; - }; + /** Used for built-in method references. */ + var objectProto = Object.prototype; /** - * Normalize a vec3 - * - * @param {vec3} out the receiving vector - * @param {vec3} a vector to normalize - * @returns {vec3} out + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. */ - vec3.normalize = function(out, a) { - var x = a[0], - y = a[1], - z = a[2]; - var len = x*x + y*y + z*z; - if (len > 0) { - //TODO: evaluate use of glm_invsqrt here? - len = 1 / Math.sqrt(len); - out[0] = a[0] * len; - out[1] = a[1] * len; - out[2] = a[2] * len; - } - return out; - }; + var objectToString = objectProto.toString; /** - * Calculates the dot product of two vec3's + * Checks if `value` is classified as a typed array. * - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {Number} dot product of a and b - */ - vec3.dot = function (a, b) { - return a[0] * b[0] + a[1] * b[1] + a[2] * b[2]; - }; - - /** - * Computes the cross product of two vec3's + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @returns {vec3} out - */ - vec3.cross = function(out, a, b) { - var ax = a[0], ay = a[1], az = a[2], - bx = b[0], by = b[1], bz = b[2]; - - out[0] = ay * bz - az * by; - out[1] = az * bx - ax * bz; - out[2] = ax * by - ay * bx; - return out; - }; - - /** - * Performs a linear interpolation between two vec3's + * _.isTypedArray(new Uint8Array); + * // => true * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @param {Number} t interpolation amount between the two inputs - * @returns {vec3} out + * _.isTypedArray([]); + * // => false */ - vec3.lerp = function (out, a, b, t) { - var ax = a[0], - ay = a[1], - az = a[2]; - out[0] = ax + t * (b[0] - ax); - out[1] = ay + t * (b[1] - ay); - out[2] = az + t * (b[2] - az); - return out; - }; + function isTypedArray(value) { + return isObjectLike(value) && + isLength(value.length) && !!typedArrayTags[objectToString.call(value)]; + } - /** - * Performs a hermite interpolation with two control points - * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @param {vec3} c the third operand - * @param {vec3} d the fourth operand - * @param {Number} t interpolation amount between the two inputs - * @returns {vec3} out - */ - vec3.hermite = function (out, a, b, c, d, t) { - var factorTimes2 = t * t, - factor1 = factorTimes2 * (2 * t - 3) + 1, - factor2 = factorTimes2 * (t - 2) + t, - factor3 = factorTimes2 * (t - 1), - factor4 = factorTimes2 * (3 - 2 * t); - - out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4; - out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4; - out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4; - - return out; - }; + module.e = isTypedArray; + + +/***/ }, +/* 45 */ +/***/ function(module, exports, __webpack_require__) { + + var baseHas = __webpack_require__(96), + baseKeys = __webpack_require__(97), + indexKeys = __webpack_require__(43), + isArrayLike = __webpack_require__(25), + isIndex = __webpack_require__(22), + isPrototype = __webpack_require__(23); /** - * Performs a bezier interpolation with two control points + * Creates an array of the own enumerable property names of `object`. * - * @param {vec3} out the receiving vector - * @param {vec3} a the first operand - * @param {vec3} b the second operand - * @param {vec3} c the third operand - * @param {vec3} d the fourth operand - * @param {Number} t interpolation amount between the two inputs - * @returns {vec3} out - */ - vec3.bezier = function (out, a, b, c, d, t) { - var inverseFactor = 1 - t, - inverseFactorTimesTwo = inverseFactor * inverseFactor, - factorTimes2 = t * t, - factor1 = inverseFactorTimesTwo * inverseFactor, - factor2 = 3 * t * inverseFactorTimesTwo, - factor3 = 3 * factorTimes2 * inverseFactor, - factor4 = factorTimes2 * t; - - out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4; - out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4; - out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4; - - return out; - }; - - /** - * Generates a random vector with the given scale + * **Note:** Non-object values are coerced to objects. See the + * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys) + * for more details. * - * @param {vec3} out the receiving vector - * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned - * @returns {vec3} out - */ - vec3.random = function (out, scale) { - scale = scale || 1.0; - - var r = glMatrix.RANDOM() * 2.0 * Math.PI; - var z = (glMatrix.RANDOM() * 2.0) - 1.0; - var zScale = Math.sqrt(1.0-z*z) * scale; - - out[0] = Math.cos(r) * zScale; - out[1] = Math.sin(r) * zScale; - out[2] = z * scale; - return out; - }; - - /** - * Transforms the vec3 with a mat4. - * 4th vector component is implicitly '1' + * @static + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example * - * @param {vec3} out the receiving vector - * @param {vec3} a the vector to transform - * @param {mat4} m matrix to transform with - * @returns {vec3} out - */ - vec3.transformMat4 = function(out, a, m) { - var x = a[0], y = a[1], z = a[2], - w = m[3] * x + m[7] * y + m[11] * z + m[15]; - w = w || 1.0; - out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w; - out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w; - out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w; - return out; - }; - - /** - * Transforms the vec3 with a mat3. - * - * @param {vec3} out the receiving vector - * @param {vec3} a the vector to transform - * @param {mat4} m the 3x3 matrix to transform with - * @returns {vec3} out - */ - vec3.transformMat3 = function(out, a, m) { - var x = a[0], y = a[1], z = a[2]; - out[0] = x * m[0] + y * m[3] + z * m[6]; - out[1] = x * m[1] + y * m[4] + z * m[7]; - out[2] = x * m[2] + y * m[5] + z * m[8]; - return out; - }; - - /** - * Transforms the vec3 with a quat - * - * @param {vec3} out the receiving vector - * @param {vec3} a the vector to transform - * @param {quat} q quaternion to transform with - * @returns {vec3} out - */ - vec3.transformQuat = function(out, a, q) { - // benchmarks: http://jsperf.com/quaternion-transform-vec3-implementations - - var x = a[0], y = a[1], z = a[2], - qx = q[0], qy = q[1], qz = q[2], qw = q[3], - - // calculate quat * vec - ix = qw * x + qy * z - qz * y, - iy = qw * y + qz * x - qx * z, - iz = qw * z + qx * y - qy * x, - iw = -qx * x - qy * y - qz * z; - - // calculate result * inverse quat - out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy; - out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz; - out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx; - return out; - }; - - /** - * Rotate a 3D vector around the x-axis - * @param {vec3} out The receiving vec3 - * @param {vec3} a The vec3 point to rotate - * @param {vec3} b The origin of the rotation - * @param {Number} c The angle of rotation - * @returns {vec3} out - */ - vec3.rotateX = function(out, a, b, c){ - var p = [], r=[]; - //Translate point to the origin - p[0] = a[0] - b[0]; - p[1] = a[1] - b[1]; - p[2] = a[2] - b[2]; - - //perform rotation - r[0] = p[0]; - r[1] = p[1]*Math.cos(c) - p[2]*Math.sin(c); - r[2] = p[1]*Math.sin(c) + p[2]*Math.cos(c); - - //translate to correct position - out[0] = r[0] + b[0]; - out[1] = r[1] + b[1]; - out[2] = r[2] + b[2]; - - return out; - }; - - /** - * Rotate a 3D vector around the y-axis - * @param {vec3} out The receiving vec3 - * @param {vec3} a The vec3 point to rotate - * @param {vec3} b The origin of the rotation - * @param {Number} c The angle of rotation - * @returns {vec3} out - */ - vec3.rotateY = function(out, a, b, c){ - var p = [], r=[]; - //Translate point to the origin - p[0] = a[0] - b[0]; - p[1] = a[1] - b[1]; - p[2] = a[2] - b[2]; - - //perform rotation - r[0] = p[2]*Math.sin(c) + p[0]*Math.cos(c); - r[1] = p[1]; - r[2] = p[2]*Math.cos(c) - p[0]*Math.sin(c); - - //translate to correct position - out[0] = r[0] + b[0]; - out[1] = r[1] + b[1]; - out[2] = r[2] + b[2]; - - return out; - }; - - /** - * Rotate a 3D vector around the z-axis - * @param {vec3} out The receiving vec3 - * @param {vec3} a The vec3 point to rotate - * @param {vec3} b The origin of the rotation - * @param {Number} c The angle of rotation - * @returns {vec3} out - */ - vec3.rotateZ = function(out, a, b, c){ - var p = [], r=[]; - //Translate point to the origin - p[0] = a[0] - b[0]; - p[1] = a[1] - b[1]; - p[2] = a[2] - b[2]; - - //perform rotation - r[0] = p[0]*Math.cos(c) - p[1]*Math.sin(c); - r[1] = p[0]*Math.sin(c) + p[1]*Math.cos(c); - r[2] = p[2]; - - //translate to correct position - out[0] = r[0] + b[0]; - out[1] = r[1] + b[1]; - out[2] = r[2] + b[2]; - - return out; - }; - - /** - * Perform some operation over an array of vec3s. - * - * @param {Array} a the array of vectors to iterate over - * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed - * @param {Number} offset Number of elements to skip at the beginning of the array - * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array - * @param {Function} fn Function to call for each vector in the array - * @param {Object} [arg] additional argument to pass to fn - * @returns {Array} a - * @function - */ - vec3.forEach = (function() { - var vec = vec3.create(); - - return function(a, stride, offset, count, fn, arg) { - var i, l; - if(!stride) { - stride = 3; - } - - if(!offset) { - offset = 0; - } - - if(count) { - l = Math.min((count * stride) + offset, a.length); - } else { - l = a.length; - } - - for(i = offset; i < l; i += stride) { - vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2]; - fn(vec, vec, arg); - a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2]; - } - - return a; - }; - })(); - - /** - * Get the angle between two 3D vectors - * @param {vec3} a The first operand - * @param {vec3} b The second operand - * @returns {Number} The angle in radians - */ - vec3.angle = function(a, b) { - - var tempA = vec3.fromValues(a[0], a[1], a[2]); - var tempB = vec3.fromValues(b[0], b[1], b[2]); - - vec3.normalize(tempA, tempA); - vec3.normalize(tempB, tempB); - - var cosine = vec3.dot(tempA, tempB); - - if(cosine > 1.0){ - return 0; - } else { - return Math.acos(cosine); - } - }; - - /** - * Returns a string representation of a vector + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keys(new Foo); + * // => ['a', 'b'] (iteration order is not guaranteed) * - * @param {vec3} vec vector to represent as a string - * @returns {String} string representation of the vector + * _.keys('hi'); + * // => ['0', '1'] */ - vec3.str = function (a) { - return 'vec3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ')'; - }; + function keys(object) { + var isProto = isPrototype(object); + if (!(isProto || isArrayLike(object))) { + return baseKeys(object); + } + var indexes = indexKeys(object), + skipIndexes = !!indexes, + result = indexes || [], + length = result.length; + + for (var key in object) { + if (baseHas(object, key) && + !(skipIndexes && (key == 'length' || isIndex(key, length))) && + !(isProto && key == 'constructor')) { + result.push(key); + } + } + return result; + } - module.exports = vec3; + module.e = keys; /***/ }, -/* 15 */ +/* 46 */ /***/ function(module, exports, __webpack_require__) { - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. - - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ - - var glMatrix = __webpack_require__(8); - - /** - * @class 4 Dimensional Vector - * @name vec4 - */ - var vec4 = {}; - - /** - * Creates a new, empty vec4 - * - * @returns {vec4} a new 4D vector - */ - vec4.create = function() { - var out = new glMatrix.ARRAY_TYPE(4); - out[0] = 0; - out[1] = 0; - out[2] = 0; - out[3] = 0; - return out; - }; + var baseKeysIn = __webpack_require__(98), + indexKeys = __webpack_require__(43), + isIndex = __webpack_require__(22), + isPrototype = __webpack_require__(23); - /** - * Creates a new vec4 initialized with values from an existing vector - * - * @param {vec4} a vector to clone - * @returns {vec4} a new 4D vector - */ - vec4.clone = function(a) { - var out = new glMatrix.ARRAY_TYPE(4); - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - return out; - }; + /** Used for built-in method references. */ + var objectProto = Object.prototype; - /** - * Creates a new vec4 initialized with the given values - * - * @param {Number} x X component - * @param {Number} y Y component - * @param {Number} z Z component - * @param {Number} w W component - * @returns {vec4} a new 4D vector - */ - vec4.fromValues = function(x, y, z, w) { - var out = new glMatrix.ARRAY_TYPE(4); - out[0] = x; - out[1] = y; - out[2] = z; - out[3] = w; - return out; - }; + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; /** - * Copy the values from one vec4 to another + * Creates an array of the own and inherited enumerable property names of `object`. * - * @param {vec4} out the receiving vector - * @param {vec4} a the source vector - * @returns {vec4} out - */ - vec4.copy = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - out[2] = a[2]; - out[3] = a[3]; - return out; - }; - - /** - * Set the components of a vec4 to the given values + * **Note:** Non-object values are coerced to objects. * - * @param {vec4} out the receiving vector - * @param {Number} x X component - * @param {Number} y Y component - * @param {Number} z Z component - * @param {Number} w W component - * @returns {vec4} out - */ - vec4.set = function(out, x, y, z, w) { - out[0] = x; - out[1] = y; - out[2] = z; - out[3] = w; - return out; - }; - - /** - * Adds two vec4's + * @static + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example * - * @param {vec4} out the receiving vector - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {vec4} out - */ - vec4.add = function(out, a, b) { - out[0] = a[0] + b[0]; - out[1] = a[1] + b[1]; - out[2] = a[2] + b[2]; - out[3] = a[3] + b[3]; - return out; - }; - - /** - * Subtracts vector b from vector a + * function Foo() { + * this.a = 1; + * this.b = 2; + * } * - * @param {vec4} out the receiving vector - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {vec4} out - */ - vec4.subtract = function(out, a, b) { - out[0] = a[0] - b[0]; - out[1] = a[1] - b[1]; - out[2] = a[2] - b[2]; - out[3] = a[3] - b[3]; - return out; - }; - - /** - * Alias for {@link vec4.subtract} - * @function - */ - vec4.sub = vec4.subtract; - - /** - * Multiplies two vec4's + * Foo.prototype.c = 3; * - * @param {vec4} out the receiving vector - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {vec4} out + * _.keysIn(new Foo); + * // => ['a', 'b', 'c'] (iteration order is not guaranteed) */ - vec4.multiply = function(out, a, b) { - out[0] = a[0] * b[0]; - out[1] = a[1] * b[1]; - out[2] = a[2] * b[2]; - out[3] = a[3] * b[3]; - return out; - }; + function keysIn(object) { + var index = -1, + isProto = isPrototype(object), + props = baseKeysIn(object), + propsLength = props.length, + indexes = indexKeys(object), + skipIndexes = !!indexes, + result = indexes || [], + length = result.length; - /** - * Alias for {@link vec4.multiply} - * @function - */ - vec4.mul = vec4.multiply; + while (++index < propsLength) { + var key = props[index]; + if (!(skipIndexes && (key == 'length' || isIndex(key, length))) && + !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { + result.push(key); + } + } + return result; + } - /** - * Divides two vec4's - * - * @param {vec4} out the receiving vector - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {vec4} out - */ - vec4.divide = function(out, a, b) { - out[0] = a[0] / b[0]; - out[1] = a[1] / b[1]; - out[2] = a[2] / b[2]; - out[3] = a[3] / b[3]; - return out; - }; + module.e = keysIn; + + +/***/ }, +/* 47 */ +/***/ function(module, exports, __webpack_require__) { + + var apply = __webpack_require__(88), + toInteger = __webpack_require__(144); - /** - * Alias for {@link vec4.divide} - * @function - */ - vec4.div = vec4.divide; + /** Used as the `TypeError` message for "Functions" methods. */ + var FUNC_ERROR_TEXT = 'Expected a function'; - /** - * Returns the minimum of two vec4's - * - * @param {vec4} out the receiving vector - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {vec4} out - */ - vec4.min = function(out, a, b) { - out[0] = Math.min(a[0], b[0]); - out[1] = Math.min(a[1], b[1]); - out[2] = Math.min(a[2], b[2]); - out[3] = Math.min(a[3], b[3]); - return out; - }; + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeMax = Math.max; /** - * Returns the maximum of two vec4's + * Creates a function that invokes `func` with the `this` binding of the + * created function and arguments from `start` and beyond provided as an array. * - * @param {vec4} out the receiving vector - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {vec4} out - */ - vec4.max = function(out, a, b) { - out[0] = Math.max(a[0], b[0]); - out[1] = Math.max(a[1], b[1]); - out[2] = Math.max(a[2], b[2]); - out[3] = Math.max(a[3], b[3]); - return out; - }; - - /** - * Scales a vec4 by a scalar number + * **Note:** This method is based on the [rest parameter](https://mdn.io/rest_parameters). * - * @param {vec4} out the receiving vector - * @param {vec4} a the vector to scale - * @param {Number} b amount to scale the vector by - * @returns {vec4} out - */ - vec4.scale = function(out, a, b) { - out[0] = a[0] * b; - out[1] = a[1] * b; - out[2] = a[2] * b; - out[3] = a[3] * b; - return out; - }; - - /** - * Adds two vec4's after scaling the second operand by a scalar value + * @static + * @memberOf _ + * @category Function + * @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. + * @example * - * @param {vec4} out the receiving vector - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @param {Number} scale the amount to scale b by before adding - * @returns {vec4} out - */ - vec4.scaleAndAdd = function(out, a, b, scale) { - out[0] = a[0] + (b[0] * scale); - out[1] = a[1] + (b[1] * scale); - out[2] = a[2] + (b[2] * scale); - out[3] = a[3] + (b[3] * scale); - return out; - }; - - /** - * Calculates the euclidian distance between two vec4's + * var say = _.rest(function(what, names) { + * return what + ' ' + _.initial(names).join(', ') + + * (_.size(names) > 1 ? ', & ' : '') + _.last(names); + * }); * - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {Number} distance between a and b + * say('hello', 'fred', 'barney', 'pebbles'); + * // => 'hello fred, barney, & pebbles' */ - vec4.distance = function(a, b) { - var x = b[0] - a[0], - y = b[1] - a[1], - z = b[2] - a[2], - w = b[3] - a[3]; - return Math.sqrt(x*x + y*y + z*z + w*w); - }; + function rest(func, start) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + start = nativeMax(start === undefined ? (func.length - 1) : toInteger(start), 0); + return function() { + var args = arguments, + index = -1, + length = nativeMax(args.length - start, 0), + array = Array(length); - /** - * Alias for {@link vec4.distance} - * @function - */ - vec4.dist = vec4.distance; + while (++index < length) { + array[index] = args[start + index]; + } + switch (start) { + case 0: return func.call(this, array); + case 1: return func.call(this, args[0], array); + case 2: return func.call(this, args[0], args[1], array); + } + var otherArgs = Array(start + 1); + index = -1; + while (++index < start) { + otherArgs[index] = args[index]; + } + otherArgs[start] = array; + return apply(func, this, otherArgs); + }; + } - /** - * Calculates the squared euclidian distance between two vec4's - * - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {Number} squared distance between a and b - */ - vec4.squaredDistance = function(a, b) { - var x = b[0] - a[0], - y = b[1] - a[1], - z = b[2] - a[2], - w = b[3] - a[3]; - return x*x + y*y + z*z + w*w; - }; + module.e = rest; + + +/***/ }, +/* 48 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = function(module) { + if(!module.webpackPolyfill) { + module.deprecate = function() {}; + module.paths = []; + // module.parent = undefined by default + module.children = []; + Object.defineProperty(module, "exports", { + enumerable: true, + configurable: false, + get: function() { return module.e; }, + set: function(v) { return module.e = v; } + }); + Object.defineProperty(module, "loaded", { + enumerable: true, + configurable: false, + get: function() { return module.l; } + }); + Object.defineProperty(module, "id", { + enumerable: true, + configurable: false, + get: function() { return module.i; } + }); + module.webpackPolyfill = 1; + } + return module; + } + + +/***/ }, +/* 49 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_merge__ = __webpack_require__(28); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_merge___default = __WEBPACK_IMPORTED_MODULE_0_lodash_merge__ && __WEBPACK_IMPORTED_MODULE_0_lodash_merge__.__esModule ? function() { return __WEBPACK_IMPORTED_MODULE_0_lodash_merge__['default'] } : function() { return __WEBPACK_IMPORTED_MODULE_0_lodash_merge__; } + /* harmony import */ Object.defineProperty(__WEBPACK_IMPORTED_MODULE_0_lodash_merge___default, 'a', { get: __WEBPACK_IMPORTED_MODULE_0_lodash_merge___default }); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__common_typedefs__ = __webpack_require__(54); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__common_typedefs___default = __WEBPACK_IMPORTED_MODULE_1__common_typedefs__ && __WEBPACK_IMPORTED_MODULE_1__common_typedefs__.__esModule ? function() { return __WEBPACK_IMPORTED_MODULE_1__common_typedefs__['default'] } : function() { return __WEBPACK_IMPORTED_MODULE_1__common_typedefs__; } + /* harmony import */ Object.defineProperty(__WEBPACK_IMPORTED_MODULE_1__common_typedefs___default, 'a', { get: __WEBPACK_IMPORTED_MODULE_1__common_typedefs___default }); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_webrtc_adapter__ = __webpack_require__(147); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_webrtc_adapter___default = __WEBPACK_IMPORTED_MODULE_2_webrtc_adapter__ && __WEBPACK_IMPORTED_MODULE_2_webrtc_adapter__.__esModule ? function() { return __WEBPACK_IMPORTED_MODULE_2_webrtc_adapter__['default'] } : function() { return __WEBPACK_IMPORTED_MODULE_2_webrtc_adapter__; } + /* harmony import */ Object.defineProperty(__WEBPACK_IMPORTED_MODULE_2_webrtc_adapter___default, 'a', { get: __WEBPACK_IMPORTED_MODULE_2_webrtc_adapter___default }); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__common_image_wrapper__ = __webpack_require__(18); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__locator_barcode_locator__ = __webpack_require__(63); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__decoder_barcode_decoder__ = __webpack_require__(57); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__common_events__ = __webpack_require__(52); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__input_camera_access__ = __webpack_require__(59); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__common_image_debug__ = __webpack_require__(9); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__analytics_result_collector__ = __webpack_require__(50); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__config_config__ = __webpack_require__(56); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_11_input_stream__ = __webpack_require__(62); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_12_frame_grabber__ = __webpack_require__(60); - /** - * Alias for {@link vec4.squaredDistance} - * @function - */ - vec4.sqrDist = vec4.squaredDistance; + // eslint-disable-line no-unused-vars + // eslint-disable-line no-unused-vars - /** - * Calculates the length of a vec4 - * - * @param {vec4} a vector to calculate length of - * @returns {Number} length of a - */ - vec4.length = function (a) { - var x = a[0], - y = a[1], - z = a[2], - w = a[3]; - return Math.sqrt(x*x + y*y + z*z + w*w); - }; - /** - * Alias for {@link vec4.length} - * @function - */ - vec4.len = vec4.length; - /** - * Calculates the squared length of a vec4 - * - * @param {vec4} a vector to calculate squared length of - * @returns {Number} squared length of a - */ - vec4.squaredLength = function (a) { - var x = a[0], - y = a[1], - z = a[2], - w = a[3]; - return x*x + y*y + z*z + w*w; - }; - /** - * Alias for {@link vec4.squaredLength} - * @function - */ - vec4.sqrLen = vec4.squaredLength; - /** - * Negates the components of a vec4 - * - * @param {vec4} out the receiving vector - * @param {vec4} a vector to negate - * @returns {vec4} out - */ - vec4.negate = function(out, a) { - out[0] = -a[0]; - out[1] = -a[1]; - out[2] = -a[2]; - out[3] = -a[3]; - return out; - }; - /** - * Returns the inverse of the components of a vec4 - * - * @param {vec4} out the receiving vector - * @param {vec4} a vector to invert - * @returns {vec4} out - */ - vec4.inverse = function(out, a) { - out[0] = 1.0 / a[0]; - out[1] = 1.0 / a[1]; - out[2] = 1.0 / a[2]; - out[3] = 1.0 / a[3]; - return out; - }; - /** - * Normalize a vec4 - * - * @param {vec4} out the receiving vector - * @param {vec4} a vector to normalize - * @returns {vec4} out - */ - vec4.normalize = function(out, a) { - var x = a[0], - y = a[1], - z = a[2], - w = a[3]; - var len = x*x + y*y + z*z + w*w; - if (len > 0) { - len = 1 / Math.sqrt(len); - out[0] = x * len; - out[1] = y * len; - out[2] = z * len; - out[3] = w * len; - } - return out; - }; - /** - * Calculates the dot product of two vec4's - * - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @returns {Number} dot product of a and b - */ - vec4.dot = function (a, b) { - return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3]; - }; - /** - * Performs a linear interpolation between two vec4's - * - * @param {vec4} out the receiving vector - * @param {vec4} a the first operand - * @param {vec4} b the second operand - * @param {Number} t interpolation amount between the two inputs - * @returns {vec4} out - */ - vec4.lerp = function (out, a, b, t) { - var ax = a[0], - ay = a[1], - az = a[2], - aw = a[3]; - out[0] = ax + t * (b[0] - ax); - out[1] = ay + t * (b[1] - ay); - out[2] = az + t * (b[2] - az); - out[3] = aw + t * (b[3] - aw); - return out; - }; - /** - * Generates a random vector with the given scale - * - * @param {vec4} out the receiving vector - * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned - * @returns {vec4} out - */ - vec4.random = function (out, scale) { - scale = scale || 1.0; - //TODO: This is a pretty awful way of doing this. Find something better. - out[0] = glMatrix.RANDOM(); - out[1] = glMatrix.RANDOM(); - out[2] = glMatrix.RANDOM(); - out[3] = glMatrix.RANDOM(); - vec4.normalize(out, out); - vec4.scale(out, out, scale); - return out; + var vec2 = { + clone: __webpack_require__(6) }; - /** - * Transforms the vec4 with a mat4. - * - * @param {vec4} out the receiving vector - * @param {vec4} a the vector to transform - * @param {mat4} m matrix to transform with - * @returns {vec4} out - */ - vec4.transformMat4 = function(out, a, m) { - var x = a[0], y = a[1], z = a[2], w = a[3]; - out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w; - out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w; - out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w; - out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w; - return out; - }; + var _inputStream, + _framegrabber, + _stopped, + _canvasContainer = { + ctx: { + image: null, + overlay: null + }, + dom: { + image: null, + overlay: null + } + }, + _inputImageWrapper, + _boxSize, + _decoder, + _workerPool = [], + _onUIThread = true, + _resultCollector, + _config = {}; - /** - * Transforms the vec4 with a quat - * - * @param {vec4} out the receiving vector - * @param {vec4} a the vector to transform - * @param {quat} q quaternion to transform with - * @returns {vec4} out - */ - vec4.transformQuat = function(out, a, q) { - var x = a[0], y = a[1], z = a[2], - qx = q[0], qy = q[1], qz = q[2], qw = q[3], + function initializeData(imageWrapper) { + initBuffers(imageWrapper); + _decoder = /* harmony import */__WEBPACK_IMPORTED_MODULE_5__decoder_barcode_decoder__["a"].create(_config.decoder, _inputImageWrapper); + } - // calculate quat * vec - ix = qw * x + qy * z - qz * y, - iy = qw * y + qz * x - qx * z, - iz = qw * z + qx * y - qy * x, - iw = -qx * x - qy * y - qz * z; + function initInputStream(cb) { + var video; + if (_config.inputStream.type === "VideoStream") { + video = document.createElement("video"); + _inputStream = /* harmony import */__WEBPACK_IMPORTED_MODULE_11_input_stream__["a"].createVideoStream(video); + } else if (_config.inputStream.type === "ImageStream") { + _inputStream = /* harmony import */__WEBPACK_IMPORTED_MODULE_11_input_stream__["a"].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 = /* harmony import */__WEBPACK_IMPORTED_MODULE_11_input_stream__["a"].createLiveStream(video); + /* harmony import */__WEBPACK_IMPORTED_MODULE_7__input_camera_access__["a"].request(video, _config.inputStream.constraints).then(function () { + _inputStream.trigger("canrecord"); + }).catch(function (err) { + return cb(err); + }); + } - // calculate result * inverse quat - out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy; - out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz; - out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx; - out[3] = a[3]; - return out; - }; + _inputStream.setAttribute("preload", "auto"); + _inputStream.setAttribute("autoplay", true); + _inputStream.setInputStream(_config.inputStream); + _inputStream.addEventListener("canrecord", canRecord.bind(undefined, cb)); + } - /** - * Perform some operation over an array of vec4s. - * - * @param {Array} a the array of vectors to iterate over - * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed - * @param {Number} offset Number of elements to skip at the beginning of the array - * @param {Number} count Number of vec4s to iterate over. If 0 iterates over entire array - * @param {Function} fn Function to call for each vector in the array - * @param {Object} [arg] additional argument to pass to fn - * @returns {Array} a - * @function - */ - vec4.forEach = (function() { - var vec = vec4.create(); + 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); + } + } - return function(a, stride, offset, count, fn, arg) { - var i, l; - if(!stride) { - stride = 4; - } + function canRecord(cb) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_4__locator_barcode_locator__["a"].checkImageConstraints(_inputStream, _config.locator); + initCanvas(_config); + _framegrabber = /* harmony import */__WEBPACK_IMPORTED_MODULE_12_frame_grabber__["a"].create(_inputStream, _canvasContainer.dom.image); - if(!offset) { - offset = 0; + adjustWorkerPool(_config.numOfWorkers, function () { + if (_config.numOfWorkers === 0) { + initializeData(); } - - if(count) { - l = Math.min((count * stride) + offset, a.length); - } else { - l = a.length; + 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; - for(i = offset; i < l; i += stride) { - vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2]; vec[3] = a[i+3]; - fn(vec, vec, arg); - a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2]; a[i+3] = vec[3]; + _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); + } } - - return a; - }; - })(); + _canvasContainer.ctx.overlay = _canvasContainer.dom.overlay.getContext("2d"); + _canvasContainer.dom.overlay.width = _inputStream.getCanvasSize().x; + _canvasContainer.dom.overlay.height = _inputStream.getCanvasSize().y; + } + } - /** - * Returns a string representation of a vector - * - * @param {vec4} vec vector to represent as a string - * @returns {String} string representation of the vector - */ - vec4.str = function (a) { - return 'vec4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')'; - }; + function initBuffers(imageWrapper) { + if (imageWrapper) { + _inputImageWrapper = imageWrapper; + } else { + _inputImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_wrapper__["a"]({ + x: _inputStream.getWidth(), + y: _inputStream.getHeight() + }); + } - module.exports = vec4; - - -/***/ }, -/* 16 */ -/***/ function(module, exports, __webpack_require__) { - - /* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV. + if (true) { + 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])]; + /* harmony import */__WEBPACK_IMPORTED_MODULE_4__locator_barcode_locator__["a"].init(_inputImageWrapper, _config.locator); + } - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: + function getBoundingBoxes() { + if (_config.locate) { + return /* harmony import */__WEBPACK_IMPORTED_MODULE_4__locator_barcode_locator__["a"].locate(); + } else { + return [[vec2.clone(_boxSize[0]), vec2.clone(_boxSize[1]), vec2.clone(_boxSize[2]), vec2.clone(_boxSize[3])]]; + } + } - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. + function transformResult(result) { + var topRight = _inputStream.getTopRight(), + xOffset = topRight.x, + yOffset = topRight.y, + i; - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. */ + if (xOffset === 0 && yOffset === 0) { + return; + } - var glMatrix = __webpack_require__(8); + if (result.barcodes) { + for (i = 0; i < result.barcodes.length; i++) { + transformResult(result.barcodes[i]); + } + } - /** - * @class 2 Dimensional Vector - * @name vec2 - */ - var vec2 = {}; + if (result.line && result.line.length === 2) { + moveLine(result.line); + } - /** - * Creates a new, empty vec2 - * - * @returns {vec2} a new 2D vector - */ - vec2.create = function() { - var out = new glMatrix.ARRAY_TYPE(2); - out[0] = 0; - out[1] = 0; - return out; - }; + if (result.box) { + moveBox(result.box); + } - /** - * Creates a new vec2 initialized with values from an existing vector - * - * @param {vec2} a vector to clone - * @returns {vec2} a new 2D vector - */ - vec2.clone = function(a) { - var out = new glMatrix.ARRAY_TYPE(2); - out[0] = a[0]; - out[1] = a[1]; - return out; - }; + if (result.boxes && result.boxes.length > 0) { + for (i = 0; i < result.boxes.length; i++) { + moveBox(result.boxes[i]); + } + } - /** - * Creates a new vec2 initialized with the given values - * - * @param {Number} x X component - * @param {Number} y Y component - * @returns {vec2} a new 2D vector - */ - vec2.fromValues = function(x, y) { - var out = new glMatrix.ARRAY_TYPE(2); - out[0] = x; - out[1] = y; - return out; - }; + function moveBox(box) { + var corner = box.length; - /** - * Copy the values from one vec2 to another - * - * @param {vec2} out the receiving vector - * @param {vec2} a the source vector - * @returns {vec2} out - */ - vec2.copy = function(out, a) { - out[0] = a[0]; - out[1] = a[1]; - return out; - }; + while (corner--) { + box[corner][0] += xOffset; + box[corner][1] += yOffset; + } + } - /** - * Set the components of a vec2 to the given values - * - * @param {vec2} out the receiving vector - * @param {Number} x X component - * @param {Number} y Y component - * @returns {vec2} out - */ - vec2.set = function(out, x, y) { - out[0] = x; - out[1] = y; - return out; - }; + function moveLine(line) { + line[0].x += xOffset; + line[0].y += yOffset; + line[1].x += xOffset; + line[1].y += yOffset; + } + } - /** - * Adds two vec2's - * - * @param {vec2} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {vec2} out - */ - vec2.add = function(out, a, b) { - out[0] = a[0] + b[0]; - out[1] = a[1] + b[1]; - return out; - }; + function addResult(result, imageData) { + if (!imageData || !_resultCollector) { + return; + } - /** - * Subtracts vector b from vector a - * - * @param {vec2} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {vec2} out - */ - vec2.subtract = function(out, a, b) { - out[0] = a[0] - b[0]; - out[1] = a[1] - b[1]; - return out; - }; + 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); + } + } - /** - * Alias for {@link vec2.subtract} - * @function - */ - vec2.sub = vec2.subtract; + function hasCodeResult(result) { + return result && (result.barcodes ? result.barcodes.some(function (barcode) { + return barcode.codeResult; + }) : result.codeResult); + } - /** - * Multiplies two vec2's - * - * @param {vec2} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {vec2} out - */ - vec2.multiply = function(out, a, b) { - out[0] = a[0] * b[0]; - out[1] = a[1] * b[1]; - return out; - }; - - /** - * Alias for {@link vec2.multiply} - * @function - */ - vec2.mul = vec2.multiply; - - /** - * Divides two vec2's - * - * @param {vec2} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {vec2} out - */ - vec2.divide = function(out, a, b) { - out[0] = a[0] / b[0]; - out[1] = a[1] / b[1]; - return out; - }; + function publishResult(result, imageData) { + var resultToPublish = result && (result.barcodes || result); - /** - * Alias for {@link vec2.divide} - * @function - */ - vec2.div = vec2.divide; + if (result && _onUIThread) { + transformResult(result); + addResult(result, imageData); + } - /** - * Returns the minimum of two vec2's - * - * @param {vec2} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {vec2} out - */ - vec2.min = function(out, a, b) { - out[0] = Math.min(a[0], b[0]); - out[1] = Math.min(a[1], b[1]); - return out; - }; + /* harmony import */__WEBPACK_IMPORTED_MODULE_6__common_events__["a"].publish("processed", resultToPublish); + if (hasCodeResult(result)) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_6__common_events__["a"].publish("detected", resultToPublish); + } + } - /** - * Returns the maximum of two vec2's - * - * @param {vec2} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {vec2} out - */ - vec2.max = function(out, a, b) { - out[0] = Math.max(a[0], b[0]); - out[1] = Math.max(a[1], b[1]); - return out; - }; + function locateAndDecode() { + var result, boxes; - /** - * 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 - */ - vec2.scale = function(out, a, b) { - out[0] = a[0] * b; - out[1] = a[1] * b; - return out; - }; + boxes = getBoundingBoxes(); + if (boxes) { + result = _decoder.decodeFromBoundingBoxes(boxes); + result = result || {}; + result.boxes = boxes; + publishResult(result, _inputImageWrapper.data); + } else { + publishResult(); + } + } - /** - * Adds two vec2's after scaling the second operand by a scalar value - * - * @param {vec2} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @param {Number} scale the amount to scale b by before adding - * @returns {vec2} out - */ - vec2.scaleAndAdd = function(out, a, b, scale) { - out[0] = a[0] + (b[0] * scale); - out[1] = a[1] + (b[1] * scale); - return out; - }; + function update() { + var availableWorker; - /** - * Calculates the euclidian distance between two vec2's - * - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {Number} distance between a and b - */ - vec2.distance = function(a, b) { - var x = b[0] - a[0], - y = b[1] - a[1]; - return Math.sqrt(x*x + y*y); - }; + 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(); + } + } - /** - * Alias for {@link vec2.distance} - * @function - */ - vec2.dist = vec2.distance; + function startContinuousUpdate() { + var next = null, + delay = 1000 / (_config.frequency || 60); - /** - * Calculates the squared euclidian distance between two vec2's - * - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {Number} squared distance between a and b - */ - vec2.squaredDistance = function(a, b) { - var x = b[0] - a[0], - y = b[1] - a[1]; - return x*x + y*y; - }; + _stopped = false; + (function frame(timestamp) { + next = next || timestamp; + if (!_stopped) { + if (timestamp >= next) { + next += delay; + update(); + } + window.requestAnimFrame(frame); + } + })(performance.now()); + } - /** - * Alias for {@link vec2.squaredDistance} - * @function - */ - vec2.sqrDist = vec2.squaredDistance; + function _start() { + if (_onUIThread && _config.inputStream.type === "LiveStream") { + startContinuousUpdate(); + } else { + update(); + } + } - /** - * Calculates the length of a vec2 - * - * @param {vec2} a vector to calculate length of - * @returns {Number} length of a - */ - vec2.length = function (a) { - var x = a[0], - y = a[1]; - return Math.sqrt(x*x + y*y); - }; + function initWorker(cb) { + var blobURL, + workerThread = { + worker: undefined, + imageData: new Uint8Array(_inputStream.getWidth() * _inputStream.getHeight()), + busy: true + }; - /** - * Alias for {@link vec2.length} - * @function - */ - vec2.len = vec2.length; + blobURL = generateWorkerBlob(); + workerThread.worker = new Worker(blobURL); - /** - * Calculates the squared length of a vec2 - * - * @param {vec2} a vector to calculate squared length of - * @returns {Number} squared length of a - */ - vec2.squaredLength = function (a) { - var x = a[0], - y = a[1]; - return x*x + y*y; - }; + workerThread.worker.onmessage = function (e) { + if (e.data.event === 'initialized') { + URL.revokeObjectURL(blobURL); + workerThread.busy = false; + workerThread.imageData = new Uint8Array(e.data.imageData); + if (true) { + console.log("Worker initialized"); + } + 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 (true) { + console.log("Worker error: " + e.data.message); + } + } + }; - /** - * Alias for {@link vec2.squaredLength} - * @function - */ - vec2.sqrLen = vec2.squaredLength; + workerThread.worker.postMessage({ + cmd: 'init', + size: { x: _inputStream.getWidth(), y: _inputStream.getHeight() }, + imageData: workerThread.imageData, + config: _config + }, [workerThread.imageData.buffer]); + } - /** - * Negates the components of a vec2 - * - * @param {vec2} out the receiving vector - * @param {vec2} a vector to negate - * @returns {vec2} out - */ - vec2.negate = function(out, a) { - out[0] = -a[0]; - out[1] = -a[1]; - return out; - }; + 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; - /** - * Returns the inverse of the components of a vec2 - * - * @param {vec2} out the receiving vector - * @param {vec2} a vector to invert - * @returns {vec2} out - */ - vec2.inverse = function(out, a) { - out[0] = 1.0 / a[0]; - out[1] = 1.0 / a[1]; - return out; - }; + 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); + } + }; - /** - * Normalize a vec2 - * - * @param {vec2} out the receiving vector - * @param {vec2} a vector to normalize - * @returns {vec2} out - */ - vec2.normalize = function(out, a) { - var x = a[0], - y = a[1]; - var len = x*x + y*y; - if (len > 0) { - //TODO: evaluate use of glm_invsqrt here? - len = 1 / Math.sqrt(len); - out[0] = a[0] * len; - out[1] = a[1] * len; + function onProcessed(result) { + self.postMessage({ + 'event': 'processed', + imageData: imageWrapper.data, + result: result + }, [imageWrapper.data.buffer]); } - return out; - }; - /** - * 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 - */ - vec2.dot = function (a, b) { - return a[0] * b[0] + a[1] * b[1]; - }; + function ready() { + // eslint-disable-line + self.postMessage({ 'event': 'initialized', imageData: imageWrapper.data }, [imageWrapper.data.buffer]); + } - /** - * Computes the cross product of two vec2's - * Note that the cross product must by definition produce a 3D vector - * - * @param {vec3} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @returns {vec3} out - */ - vec2.cross = function(out, a, b) { - var z = a[0] * b[1] - a[1] * b[0]; - out[0] = out[1] = 0; - out[2] = z; - return out; - }; + /* eslint-enable */ + } - /** - * Performs a linear interpolation between two vec2's - * - * @param {vec2} out the receiving vector - * @param {vec2} a the first operand - * @param {vec2} b the second operand - * @param {Number} t interpolation amount between the two inputs - * @returns {vec2} out - */ - vec2.lerp = function (out, a, b, t) { - var ax = a[0], - ay = a[1]; - out[0] = ax + t * (b[0] - ax); - out[1] = ay + t * (b[1] - ay); - return out; - }; - - /** - * Generates a random vector with the given scale - * - * @param {vec2} out the receiving vector - * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned - * @returns {vec2} out - */ - vec2.random = function (out, scale) { - scale = scale || 1.0; - var r = glMatrix.RANDOM() * 2.0 * Math.PI; - out[0] = Math.cos(r) * scale; - out[1] = Math.sin(r) * scale; - return out; - }; + function generateWorkerBlob() { + var blob, factorySource; - /** - * 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 - */ - vec2.transformMat2 = function(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; - }; + /* jshint ignore:start */ + if (typeof __factorySource__ !== 'undefined') { + factorySource = __factorySource__; // eslint-disable-line no-undef + } + /* jshint ignore:end */ - /** - * Transforms the vec2 with a mat2d - * - * @param {vec2} out the receiving vector - * @param {vec2} a the vector to transform - * @param {mat2d} m matrix to transform with - * @returns {vec2} out - */ - vec2.transformMat2d = function(out, a, m) { - var x = a[0], - y = a[1]; - out[0] = m[0] * x + m[2] * y + m[4]; - out[1] = m[1] * x + m[3] * y + m[5]; - return out; - }; + blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'], { type: 'text/javascript' }); - /** - * Transforms the vec2 with a mat3 - * 3rd vector component is implicitly '1' - * - * @param {vec2} out the receiving vector - * @param {vec2} a the vector to transform - * @param {mat3} m matrix to transform with - * @returns {vec2} out - */ - vec2.transformMat3 = function(out, a, m) { - var x = a[0], - y = a[1]; - out[0] = m[0] * x + m[3] * y + m[6]; - out[1] = m[1] * x + m[4] * y + m[7]; - return out; - }; + return window.URL.createObjectURL(blob); + } - /** - * Transforms the vec2 with a mat4 - * 3rd vector component is implicitly '0' - * 4th vector component is implicitly '1' - * - * @param {vec2} out the receiving vector - * @param {vec2} a the vector to transform - * @param {mat4} m matrix to transform with - * @returns {vec2} out - */ - vec2.transformMat4 = function(out, a, m) { - var x = a[0], - y = a[1]; - out[0] = m[0] * x + m[4] * y + m[12]; - out[1] = m[1] * x + m[5] * y + m[13]; - return out; - }; + 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 }); + }); + } + } - /** - * Perform some operation over an array of vec2s. - * - * @param {Array} a the array of vectors to iterate over - * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed - * @param {Number} offset Number of elements to skip at the beginning of the array - * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array - * @param {Function} fn Function to call for each vector in the array - * @param {Object} [arg] additional argument to pass to fn - * @returns {Array} a - * @function - */ - vec2.forEach = (function() { - var vec = vec2.create(); + 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 (true) { + 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(); + } + }; - return function(a, stride, offset, count, fn, arg) { - var i, l; - if(!stride) { - stride = 2; + for (var i = 0; i < increaseBy; i++) { + initWorker(workerInitialized); } + } + } - if(!offset) { - offset = 0; - } - - if(count) { - l = Math.min((count * stride) + offset, a.length); + /* harmony default export */ exports["default"] = { + init: function init(config, cb, imageWrapper) { + _config = /* harmony import */__WEBPACK_IMPORTED_MODULE_0_lodash_merge___default.a.bind()({}, /* harmony import */__WEBPACK_IMPORTED_MODULE_10__config_config__["a"], config); + if (imageWrapper) { + _onUIThread = false; + initializeData(imageWrapper); + return cb(); } else { - l = a.length; - } - - for(i = offset; i < l; i += stride) { - vec[0] = a[i]; vec[1] = a[i+1]; - fn(vec, vec, arg); - a[i] = vec[0]; a[i+1] = vec[1]; - } - - return a; - }; - })(); - - /** - * Returns a string representation of a vector - * - * @param {vec2} vec vector to represent as a string - * @returns {String} string representation of the vector - */ - vec2.str = function (a) { - return 'vec2(' + a[0] + ', ' + a[1] + ')'; - }; - - module.exports = vec2; - - -/***/ }, -/* 17 */ -/***/ function(module, exports) { - - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports["default"] = { - init: function init(arr, val) { - var l = arr.length; - while (l--) { - arr[l] = val; + initInputStream(cb); } }, - - /** - * 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; + start: function start() { + _start(); }, - - 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(",") + "]"; + stop: function stop() { + _stopped = true; + adjustWorkerPool(0); + if (_config.inputStream.type === "LiveStream") { + /* harmony import */__WEBPACK_IMPORTED_MODULE_7__input_camera_access__["a"].release(); + _inputStream.clearEventHandlers(); } - 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; + pause: function pause() { + _stopped = true; }, - - maxIndex: function maxIndex(arr) { - var i, - max = 0; - for (i = 0; i < arr.length; i++) { - if (arr[i] > arr[max]) { - max = i; - } + onDetected: function onDetected(callback) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_6__common_events__["a"].subscribe("detected", callback); + }, + offDetected: function offDetected(callback) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_6__common_events__["a"].unsubscribe("detected", callback); + }, + onProcessed: function onProcessed(callback) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_6__common_events__["a"].subscribe("processed", callback); + }, + offProcessed: function offProcessed(callback) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_6__common_events__["a"].unsubscribe("processed", callback); + }, + setReaders: function setReaders(readers) { + _setReaders(readers); + }, + registerResultCollector: function registerResultCollector(resultCollector) { + if (resultCollector && typeof resultCollector.addResult === 'function') { + _resultCollector = resultCollector; } - return max; }, + canvas: _canvasContainer, + decodeSingle: function decodeSingle(config, resultCallback) { + var _this = this; - max: function max(arr) { - var i, - max = 0; - for (i = 0; i < arr.length; i++) { - if (arr[i] > max) { - max = arr[i]; + config = /* harmony import */__WEBPACK_IMPORTED_MODULE_0_lodash_merge___default.a.bind()({ + inputStream: { + type: "ImageStream", + sequence: false, + size: 800, + src: config.src + }, + numOfWorkers: true && config.debug ? 0 : 1, + locator: { + halfSample: false } - } - return max; + }, config); + this.init(config, function () { + /* harmony import */__WEBPACK_IMPORTED_MODULE_6__common_events__["a"].once("processed", function (result) { + _this.stop(); + resultCallback.call(null, result); + }, true); + _start(); + }); }, - - sum: function sum(arr) { - var length = arr.length, - sum = 0; - - while (length--) { - sum += arr[length]; - } - return sum; - } + ImageWrapper: /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_wrapper__["a"], + ImageDebug: /* harmony import */__WEBPACK_IMPORTED_MODULE_8__common_image_debug__["a"], + ResultCollector: /* harmony import */__WEBPACK_IMPORTED_MODULE_9__analytics_result_collector__["a"] }; - module.exports = exports["default"]; /***/ }, -/* 18 */ +/* 50 */ /***/ function(module, exports, __webpack_require__) { - /* WEBPACK VAR INJECTION */(function(global) {'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__common_image_debug__ = __webpack_require__(9); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - var _commonImage_wrapper = __webpack_require__(3); + 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; + } - var _commonImage_wrapper2 = _interopRequireDefault(_commonImage_wrapper); + function passesFilter(codeResult, filter) { + if (typeof filter === 'function') { + return filter(codeResult); + } + return true; + } - var _commonCv_utils = __webpack_require__(5); - - var _commonCv_utils2 = _interopRequireDefault(_commonCv_utils); - - var _commonArray_helper = __webpack_require__(17); - - var _commonArray_helper2 = _interopRequireDefault(_commonArray_helper); - - var _commonImage_debug = __webpack_require__(19); - - var _commonImage_debug2 = _interopRequireDefault(_commonImage_debug); - - var _rasterizer = __webpack_require__(20); - - var _rasterizer2 = _interopRequireDefault(_rasterizer); - - var _tracer = __webpack_require__(21); - - var _tracer2 = _interopRequireDefault(_tracer); - - var _skeletonizer2 = __webpack_require__(22); - - var _skeletonizer3 = _interopRequireDefault(_skeletonizer2); - - var _glMatrix = __webpack_require__(7); - - 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 _commonImage_wrapper2['default']({ - x: _inputImageWrapper.size.x / 2 | 0, - y: _inputImageWrapper.size.y / 2 | 0 - }); - } else { - _currentImageWrapper = _inputImageWrapper; - } - - _patchSize = _commonCv_utils2['default'].calculatePatchSize(_config.patchSize, _currentImageWrapper.size); - - _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0; - _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0; - - _binaryImageWrapper = new _commonImage_wrapper2['default'](_currentImageWrapper.size, undefined, Uint8Array, false); - - _labelImageWrapper = new _commonImage_wrapper2['default'](_patchSize, undefined, Array, true); + /* harmony default export */ exports["a"] = { + create: function create(config) { + var canvas = document.createElement("canvas"), + ctx = canvas.getContext("2d"), + results = [], + capacity = config.capacity || 20, + capture = config.capture === true; - skeletonImageData = new ArrayBuffer(64 * 1024); - _subImageWrapper = new _commonImage_wrapper2['default'](_patchSize, new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y)); - _skelImageWrapper = new _commonImage_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); + function matchesConstraints(codeResult) { + return capacity && codeResult && !contains(codeResult, config.blacklist) && passesFilter(codeResult, config.filter); + } - _imageToPatchGrid = new _commonImage_wrapper2['default']({ - x: _currentImageWrapper.size.x / _subImageWrapper.size.x | 0, - y: _currentImageWrapper.size.y / _subImageWrapper.size.y | 0 - }, undefined, Array, true); - _patchGrid = new _commonImage_wrapper2['default'](_imageToPatchGrid.size, undefined, undefined, true); - _patchLabelGrid = new _commonImage_wrapper2['default'](_imageToPatchGrid.size, undefined, Int32Array, true); - } + return { + addResult: function addResult(data, imageSize, codeResult) { + var result = {}; - function initCanvas() { - if (_config.useWorker || typeof document === 'undefined') { - return; - } - _canvasContainer.dom.binary = document.createElement("canvas"); - _canvasContainer.dom.binary.className = "binaryBuffer"; - if ((true) && _config.debug.showCanvas === true) { - document.querySelector("#debug").appendChild(_canvasContainer.dom.binary); + if (matchesConstraints(codeResult)) { + capacity--; + result.codeResult = codeResult; + if (capture) { + canvas.width = imageSize.x; + canvas.height = imageSize.y; + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_debug__["a"].drawImage(data, imageSize, ctx); + result.frame = canvas.toDataURL(); + } + results.push(result); + } + }, + getResults: function getResults() { + return results; + } + }; } - _canvasContainer.ctx.binary = _canvasContainer.dom.binary.getContext("2d"); - _canvasContainer.dom.binary.width = _binaryImageWrapper.size.x; - _canvasContainer.dom.binary.height = _binaryImageWrapper.size.y; - } - + }; + +/***/ }, +/* 51 */ +/***/ function(module, exports, __webpack_require__) { + + var vec2 = { + clone: __webpack_require__(6), + dot: __webpack_require__(31) + }; /** - * Creates a bounding box which encloses all the given patches - * @returns {Array} The minimal bounding box + * Creates a cluster for grouping similar orientations of datapoints */ - 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 ((true) && _config.debug.showPatches) { - _commonImage_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 = _glMatrix.mat2.clone([Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]); + /* harmony default export */ exports["a"] = { + create: function create(point, threshold) { + var points = [], + center = { + rad: 0, + vec: vec2.clone([0, 0]) + }, + pointMap = {}; - // iterate over patches and rotate by angle - for (i = 0; i < patches.length; i++) { - patch = patches[i]; - for (j = 0; j < 4; j++) { - _glMatrix.vec2.transformMat2(patch.box[j], patch.box[j], transMat); + function init() { + _add(point); + updateCenter(); } - if ((true) && _config.debug.boxFromPatches.showTransformed) { - _commonImage_debug2['default'].drawPath(patch.box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#99ff00', lineWidth: 2 }); + function _add(pointToAdd) { + pointMap[pointToAdd.id] = pointToAdd; + points.push(pointToAdd); } - } - // 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]; + 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)]); } - } - box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]]; + init(); - if ((true) && _config.debug.boxFromPatches.showTransformedBox) { - _commonImage_debug2['default'].drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); + 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 + }; } + }; + +/***/ }, +/* 52 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony default export */ exports["a"] = function () { + var events = {}; - scale = _config.halfSample ? 2 : 1; - // reverse rotation; - transMat = _glMatrix.mat2.invert(transMat, transMat); - for (j = 0; j < 4; j++) { - _glMatrix.vec2.transformMat2(box[j], box[j], transMat); + function getEvent(eventName) { + if (!events[eventName]) { + events[eventName] = { + subscribers: [] + }; + } + return events[eventName]; } - if ((true) && _config.debug.boxFromPatches.showBB) { - _commonImage_debug2['default'].drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); + function clearEvents() { + events = {}; } - for (j = 0; j < 4; j++) { - _glMatrix.vec2.scale(box[j], box[j], scale); + function publishSubscription(subscription, data) { + if (subscription.async) { + setTimeout(function () { + subscription.callback(data); + }, 4); + } else { + subscription.callback(data); + } } - return box; - } + function _subscribe(event, callback, async) { + var subscription; - /** - * Creates a binary image of the current image - */ - function binarizeImage() { - _commonCv_utils2['default'].otsuThreshold(_currentImageWrapper, _binaryImageWrapper); - _binaryImageWrapper.zeroBorder(); - if (_config.showCanvas) { - _binaryImageWrapper.show(_canvasContainer.dom.binary, 255); - } - } + if (typeof callback === "function") { + subscription = { + callback: callback, + async: async + }; + } else { + subscription = callback; + if (!subscription.callback) { + throw "Callback was not specified on options"; + } + } - /** - * 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; + getEvent(event).subscribers.push(subscription); + } - // seperate parts - skeletonize(x, y); + return { + subscribe: function subscribe(event, callback, async) { + return _subscribe(event, callback, async); + }, + publish: function publish(eventName, data) { + var event = getEvent(eventName), + subscribers = event.subscribers; - // Rasterize, find individual bars - _skelImageWrapper.zeroBorder(); - _commonArray_helper2['default'].init(_labelImageWrapper.data, 0); - rasterizer = _rasterizer2['default'].create(_skelImageWrapper, _labelImageWrapper); - rasterResult = rasterizer.rasterize(0); + event.subscribers = subscribers.filter(function (subscriber) { + publishSubscription(subscriber, data); + return !subscriber.once; + }); + }, + once: function once(event, callback, async) { + _subscribe(event, { + callback: callback, + async: async, + once: true + }); + }, + unsubscribe: function unsubscribe(eventName, callback) { + var event; - if ((true) && _config.debug.showLabels) { - _labelImageWrapper.overlay(_canvasContainer.dom.binary, Math.floor(360 / rasterResult.count), { x: x, y: y }); + if (eventName) { + event = getEvent(eventName); + if (event && callback) { + event.subscribers = event.subscribers.filter(function (subscriber) { + return subscriber.callback !== callback; + }); + } else { + event.subscribers = []; + } + } else { + clearEvents(); } - - // calculate moments from the skeletonized patch - moments = _labelImageWrapper.moments(rasterResult.count); - - // extract eligible patches - patchesFound = patchesFound.concat(describePatch(moments, [i, j], x, y)); - } - } - - if ((true) && _config.debug.showFoundPatches) { - for (i = 0; i < patchesFound.length; i++) { - patch = patchesFound[i]; - _commonImage_debug2['default'].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "#99ff00", lineWidth: 2 }); } + }; + }(); + +/***/ }, +/* 53 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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; - return patchesFound; + this.from = from; + this.size = size; } /** - * Finds those connected areas which contain at least 6 patches - * and returns them ordered DESC by the number of contained patches - * @param {Number} maxLabel + * 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 */ - function findBiggestConnectedAreas(maxLabel) { - var i, - sum, - labelHist = [], - topLabels = []; + SubImage.prototype.show = function (canvas, scale) { + var ctx, frame, data, current, y, x, pixel; - for (i = 0; i < maxLabel; i++) { - labelHist.push(0); + if (!scale) { + scale = 1.0; } - sum = _patchLabelGrid.data.length; - while (sum--) { - if (_patchLabelGrid.data[sum] > 0) { - labelHist[_patchLabelGrid.data[sum] - 1]++; + 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; } } - - 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; - } + 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 */ - 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 ((true) && _config.debug.showRemainingPatchLabels) { - for (j = 0; j < patches.length; j++) { - patch = patches[j]; - hsv[0] = topLabels[i].label / (maxLabel + 1) * 360; - _commonCv_utils2['default'].hsv2rgb(hsv, rgb); - _commonImage_debug2['default'].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "rgb(" + rgb.join(",") + ")", lineWidth: 2 }); - } - } - } - } - return boxes; - } + SubImage.prototype.get = function (x, y) { + return this.data[(this.from.y + y) * this.originalSize.x + this.from.x + x]; + }; /** - * Find similar moments (via cluster) - * @param {Object} moments + * Updates the underlying data from a given {ImageWrapper} + * @param image {ImageWrapper} The updated image */ - function similarMoments(moments) { - var clusters = _commonCv_utils2['default'].cluster(moments, 0.90); - var topCluster = _commonCv_utils2['default'].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, _commonCv_utils2['default'].imageRef(x, y)); - _skeletonizer.skeletonize(); - - // Show skeleton if requested - if ((true) && _config.debug.showSkeleton) { - _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, _commonCv_utils2['default'].imageRef(x, y)); - } - } + SubImage.prototype.updateData = function (image) { + this.originalSize = image.size; + this.data = image.data; + }; /** - * 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 + * Updates the position of the shared area + * @param from {x,y} The new location + * @returns {SubImage} returns {this} for possible chaining */ - 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]); - } - } + SubImage.prototype.updateFrom = function (from) { + this.from = from; + return this; + }; - // 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; - } + /* harmony default export */ exports["a"] = SubImage; + +/***/ }, +/* 54 */ +/***/ function(module, exports) { + + /* + * typedefs.js + * Normalizes browser-specific prefixes + */ - // 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: [_glMatrix.vec2.clone([x, y]), _glMatrix.vec2.clone([x + _subImageWrapper.size.x, y]), _glMatrix.vec2.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]), _glMatrix.vec2.clone([x, y + _subImageWrapper.size.y])], - moments: matchingMoments, - rad: avg, - vec: _glMatrix.vec2.clone([Math.cos(avg), Math.sin(avg)]) - }; - patchesFound.push(patch); + 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; + }; + +/***/ }, +/* 55 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = { + inputStream: { + name: "Live", + type: "LiveStream", + constraints: { + width: 640, + height: 480, + // aspectRatio: 640/480, // optional + facingMode: "environment" }, + // or user + // deviceId: "38745983457387598375983759834" + area: { + top: "0%", + right: "0%", + left: "0%", + bottom: "0%" + }, + singleChannel: false // true: only the red color-channel is read + }, + locate: true, + numOfWorkers: 0, + decoder: { + readers: ['code_128_reader'], + debug: { + drawBoundingBox: false, + showFrequency: false, + drawScanline: false, + showPattern: false + } + }, + locator: { + halfSample: true, + patchSize: "medium", // x-small, small, medium, large, x-large + debug: { + showCanvas: false, + showPatches: false, + showFoundPatches: false, + showSkeleton: false, + showLabels: false, + showPatchLabels: false, + showRemainingPatchLabels: false, + boxFromPatches: { + showTransformed: false, + showTransformedBox: false, + showBB: false } } } - return patchesFound; + }; + +/***/ }, +/* 56 */ +/***/ function(module, exports, __webpack_require__) { + + var config = void 0; + + if (true) { + config = __webpack_require__(55); + } else if (ENV.node) { + config = require('./config.node.js'); + } else { + config = require('./config.prod.js'); } - /** - * 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]; + /* harmony default export */ exports["a"] = config; + +/***/ }, +/* 57 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__bresenham__ = __webpack_require__(58); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__common_image_debug__ = __webpack_require__(9); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__reader_code_128_reader__ = __webpack_require__(67); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__reader_ean_reader__ = __webpack_require__(10); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__reader_code_39_reader__ = __webpack_require__(30); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__reader_code_39_vin_reader__ = __webpack_require__(68); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__reader_codabar_reader__ = __webpack_require__(66); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__reader_upc_reader__ = __webpack_require__(72); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__reader_ean_8_reader__ = __webpack_require__(69); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__reader_upc_e_reader__ = __webpack_require__(71); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__reader_i2of5_reader__ = __webpack_require__(70); + var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; }; - 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(_glMatrix.vec2.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec)); - if (similarity > threshold) { - trace(idx); - } - } - } - } - } - // prepare for finding the right patches - _commonArray_helper2['default'].init(_patchGrid.data, 0); - _commonArray_helper2['default'].init(_patchLabelGrid.data, 0); - _commonArray_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 ((true) && _config.debug.showPatchLabels) { - for (j = 0; j < _patchLabelGrid.data.length; j++) { - if (_patchLabelGrid.data[j] > 0 && _patchLabelGrid.data[j] <= label) { - patch = _imageToPatchGrid.data[j]; - hsv[0] = _patchLabelGrid.data[j] / (label + 1) * 360; - _commonCv_utils2['default'].hsv2rgb(hsv, rgb); - _commonImage_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(); + var READERS = { + code_128_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_2__reader_code_128_reader__["a"], + ean_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_3__reader_ean_reader__["a"], + ean_8_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_8__reader_ean_8_reader__["a"], + code_39_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_4__reader_code_39_reader__["a"], + code_39_vin_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_5__reader_code_39_vin_reader__["a"], + codabar_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_6__reader_codabar_reader__["a"], + upc_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_7__reader_upc_reader__["a"], + upc_e_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_9__reader_upc_e_reader__["a"], + i2of5_reader: /* harmony import */__WEBPACK_IMPORTED_MODULE_10__reader_i2of5_reader__["a"] + }; + /* harmony default export */ exports["a"] = { + 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(); - locate: function locate() { - var patchesFound, topLabels, boxes; + function initCanvas() { + if (true && typeof document !== 'undefined') { + 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"); - if (_config.halfSample) { - _commonCv_utils2['default'].halfSample(_inputImageWrapper, _currentImageWrapper); - } + _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"); - binarizeImage(); - patchesFound = findPatches(); - // return unless 5% or more patches are found - if (patchesFound.length < _numPatches.x * _numPatches.y * 0.05) { - return null; + _canvas.dom.overlay = document.querySelector("canvas.drawingBuffer"); + if (_canvas.dom.overlay) { + _canvas.ctx.overlay = _canvas.dom.overlay.getContext("2d"); + } + } } - // rasterrize area by comparing angular similarity; - var maxLabel = rasterizeAngularSimilarity(patchesFound); - if (maxLabel < 1) { - return null; + function initReaders() { + config.readers.forEach(function (readerConfig) { + var reader, + configuration = {}; + + if ((typeof readerConfig === 'undefined' ? 'undefined' : _typeof(readerConfig)) === 'object') { + reader = readerConfig.format; + configuration = readerConfig.config; + } else if (typeof readerConfig === 'string') { + reader = readerConfig; + } + if (true) { + console.log("Before registering reader: ", reader); + } + _barcodeReaders.push(new READERS[reader](configuration)); + }); + if (true) { + console.log("Registered Readers: " + _barcodeReaders.map(function (reader) { + return JSON.stringify({ format: reader.FORMAT, config: reader.config }); + }).join(', ')); + } } - // search for area with the most patches (biggest connected area) - topLabels = findBiggestConnectedAreas(maxLabel); - if (topLabels.length === 0) { - return null; + function initConfig() { + if (true && typeof document !== 'undefined') { + 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"; + } + } + } } - boxes = findBoxes(topLabels, maxLabel); - return boxes; - }, + /** + * 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) + }; - checkImageConstraints: function checkImageConstraints(inputStream, config) { - var patchSize, - width = inputStream.getWidth(), - height = inputStream.getHeight(), - halfSample = config.halfSample ? 0.5 : 1, - size, - area; + line[0].y -= extension.y; + line[0].x -= extension.x; + line[1].y += extension.y; + line[1].x += extension.x; + } - // calculate width and height based on area - if (inputStream.getConfig().area) { - area = _commonCv_utils2['default'].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; + // 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; } - size = { - x: Math.floor(width * halfSample), - y: Math.floor(height * halfSample) - }; - - patchSize = _commonCv_utils2['default'].calculatePatchSize(config.patchSize, size); - if (true) { - console.log("Patch-Size: " + JSON.stringify(patchSize)); + 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] + }]; } - 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)); + function tryDecode(line) { + var result = null, + i, + barcodeLine = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__bresenham__["a"].getBarcodeLine(inputImageWrapper, line[0], line[1]); - if (inputStream.getWidth() % patchSize.x === 0 && inputStream.getHeight() % patchSize.y === 0) { - return true; - } + if (true && config.debug.showFrequency) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_image_debug__["a"].drawPath(line, { x: 'x', y: 'y' }, _canvas.ctx.overlay, { color: 'red', lineWidth: 3 }); + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__bresenham__["a"].debug.printFrequency(barcodeLine.line, _canvas.dom.frequency); + } - throw new Error("Image dimensions do not comply with the current settings: Width (" + width + " )and height (" + height + ") must a multiple of " + patchSize.x); - } - }; - module.exports = exports['default']; - /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) - -/***/ }, -/* 19 */ -/***/ function(module, exports) { - - "use strict"; + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__bresenham__["a"].toBinaryLine(barcodeLine); - Object.defineProperty(exports, "__esModule", { - value: 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]); + if (true && config.debug.showPattern) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__bresenham__["a"].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 + }; } - 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; + /** + * 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; } - while (imageDataPos--) { - value = imageData[imageDataPos]; - data[--canvasDataPos] = 255; - data[--canvasDataPos] = value; - data[--canvasDataPos] = value; - data[--canvasDataPos] = value; + + 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)); } - ctx.putImageData(canvasData, 0, 0); - return true; - } - }; - module.exports = exports["default"]; - -/***/ }, -/* 20 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); + /** + * 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; - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + if (true) { + if (config.debug.drawBoundingBox && ctx) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_image_debug__["a"].drawPath(box, { x: 0, y: 1 }, ctx, { color: "blue", lineWidth: 2 }); + } + } - var _tracer = __webpack_require__(21); + 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; + } - var _tracer2 = _interopRequireDefault(_tracer); + result = tryDecode(line); + if (result === null) { + result = tryDecodeBruteForce(box, line, lineAngle); + } - /** - * 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); + if (result === null) { + return null; + } + + if (true && result && config.debug.drawScanline && ctx) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_image_debug__["a"].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 { - 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 - }; + decodeFromBoundingBox: function decodeFromBoundingBox(box) { + return _decodeFromBoundingBox(box); }, - debug: { - drawContour: function drawContour(canvas, firstContour) { - var ctx = canvas.getContext("2d"), - pq = firstContour, - iq, - q, - p; + decodeFromBoundingBoxes: function decodeFromBoundingBoxes(boxes) { + var i, + result, + barcodes = [], + multiple = config.multiple; - ctx.strokeStyle = "red"; - ctx.fillStyle = "red"; - ctx.lineWidth = 1; + for (i = 0; i < boxes.length; i++) { + var box = boxes[i]; + result = _decodeFromBoundingBox(box) || {}; + result.box = box; - if (pq !== null) { - iq = pq.insideContours; - } else { - iq = null; + if (multiple) { + barcodes.push(result); + } else if (result.codeResult) { + return result; } + } - 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(); - } + if (multiple) { + return { + barcodes: barcodes + }; } + }, + setReaders: function setReaders(readers) { + config.readers = readers; + _barcodeReaders.length = 0; + initReaders(); } }; } }; - - exports["default"] = Rasterizer; - module.exports = exports["default"]; /***/ }, -/* 21 */ -/***/ function(module, exports) { +/* 58 */ +/***/ function(module, exports, __webpack_require__) { + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__ = __webpack_require__(18); + + + var Bresenham = {}; + + var Slope = { + DIR: { + UP: 1, + DOWN: -1 + } + }; /** - * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization + * 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} */ - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - 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; + 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 _trace(current, color, label, edgelabel) { - var i, y, x; + function read(a, b) { + val = imageData[b * width + a]; + sum += val; + min = val < min ? val : min; + max = val > max ? val : max; + line.push(val); + } - 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; - } + if (steep) { + tmp = x0; + x0 = y0; + y0 = tmp; - function vertex2D(x, y, dir) { - return { - dir: dir, - x: x, - y: y, - next: null, - prev: null - }; + 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; } + } - function _contourTracing(sy, sx, label, color, edgelabel) { - var Fv = null, - Cv, - P, - ldir, - current = { - cx: sx, - cy: sy, - dir: 0 - }; + return { + line: line, + min: min, + max: max + }; + }; - 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; + /** + * 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; } - 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); + 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"] = Tracer; - module.exports = exports["default"]; + /* harmony default export */ exports["a"] = Bresenham; /***/ }, -/* 22 */ -/***/ function(module, exports) { +/* 59 */ +/***/ function(module, exports, __webpack_require__) { - /* @preserve ASM BEGIN */ - /* eslint-disable eqeqeq*/ - "use strict"; + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_pick__ = __webpack_require__(143); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_pick___default = __WEBPACK_IMPORTED_MODULE_0_lodash_pick__ && __WEBPACK_IMPORTED_MODULE_0_lodash_pick__.__esModule ? function() { return __WEBPACK_IMPORTED_MODULE_0_lodash_pick__['default'] } : function() { return __WEBPACK_IMPORTED_MODULE_0_lodash_pick__; } + /* harmony import */ Object.defineProperty(__WEBPACK_IMPORTED_MODULE_0_lodash_pick___default, 'a', { get: __WEBPACK_IMPORTED_MODULE_0_lodash_pick___default }); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_lodash_merge__ = __webpack_require__(28); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_lodash_merge___default = __WEBPACK_IMPORTED_MODULE_1_lodash_merge__ && __WEBPACK_IMPORTED_MODULE_1_lodash_merge__.__esModule ? function() { return __WEBPACK_IMPORTED_MODULE_1_lodash_merge__['default'] } : function() { return __WEBPACK_IMPORTED_MODULE_1_lodash_merge__; } + /* harmony import */ Object.defineProperty(__WEBPACK_IMPORTED_MODULE_1_lodash_merge___default, 'a', { get: __WEBPACK_IMPORTED_MODULE_1_lodash_merge___default }); - Object.defineProperty(exports, "__esModule", { - value: true - }); - 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; + var streamRef, loadedDataHandler; - 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; + function waitForVideo(video) { + return new Promise(function (resolve, reject) { + var attempts = 10; + + function checkVideo() { + if (attempts > 0) { + if (video.videoWidth > 0 && video.videoHeight > 0) { + if (true) { + console.log(video.videoWidth + "px x " + video.videoHeight + "px"); + } + resolve(); } else { - images[outImagePtr + offset + u | 0] = 0; + window.setTimeout(checkVideo, 500); } + } else { + reject('Unable to play video stream. Is webcam working?'); } + attempts--; } - return; - } - - function subtract(aImagePtr, bImagePtr, outImagePtr) { - aImagePtr = aImagePtr | 0; - bImagePtr = bImagePtr | 0; - outImagePtr = outImagePtr | 0; + checkVideo(); + }); + } - var length = 0; + /** + * 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 navigator.mediaDevices.getUserMedia(constraints).then(function (stream) { + return new Promise(function (resolve, reject) { + streamRef = stream; + video.src = window.URL.createObjectURL(stream); + video.onloadedmetadata = function (e) { + video.play(); + resolve(); + }; + }); + }).then(waitForVideo.bind(null, video)); + } - length = imul(size, size) | 0; + function deprecatedConstraints(videoConstraints) { + var normalized = /* harmony import */__WEBPACK_IMPORTED_MODULE_0_lodash_pick___default.a.bind()(videoConstraints, ["width", "height", "facingMode", "aspectRatio", "deviceId"]); - while ((length | 0) > 0) { - length = length - 1 | 0; - images[outImagePtr + length | 0] = (images[aImagePtr + length | 0] | 0) - (images[bImagePtr + length | 0] | 0) | 0; - } + 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 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 applyCameraFacing(facing, constraints) { + if (typeof constraints.video.deviceId !== 'undefined' || !facing) { + return Promise.resolve(constraints); } + if (typeof MediaStreamTrack !== 'undefined' && typeof MediaStreamTrack.getSources !== 'undefined') { + return new Promise(function (resolve, reject) { + MediaStreamTrack.getSources(function (sourceInfos) { + var videoSource = sourceInfos.filter(function (sourceInfo) { + return sourceInfo.kind === "video" && sourceInfo.facing === facing; + })[0]; + if (videoSource) { + return resolve(/* harmony import */__WEBPACK_IMPORTED_MODULE_1_lodash_merge___default.a.bind()({}, constraints, { video: { deviceId: videoSource.id } })); + } + return resolve(constraints); + }); + }); + } + return Promise.resolve(/* harmony import */__WEBPACK_IMPORTED_MODULE_1_lodash_merge___default.a.bind()({}, constraints, { video: { facingMode: facing } })); + } - function countNonZero(imagePtr) { - imagePtr = imagePtr | 0; - - var sum = 0, - length = 0; - - length = imul(size, size) | 0; + function pickConstraints(videoConstraints) { + var constraints = { + audio: false, + video: deprecatedConstraints(videoConstraints) + }; + return applyCameraFacing(constraints.video.facingMode, constraints); + } - while ((length | 0) > 0) { - length = length - 1 | 0; - sum = (sum | 0) + (images[imagePtr + length | 0] | 0) | 0; + /* harmony default export */ exports["a"] = { + 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(); } - - return sum | 0; + streamRef = null; } + }; + +/***/ }, +/* 60 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__common_cv_utils__ = __webpack_require__(17); - function init(imagePtr, value) { - imagePtr = imagePtr | 0; - value = value | 0; - var length = 0; + var FrameGrabber = {}; - length = imul(size, size) | 0; + FrameGrabber.create = function (inputStream, canvas) { + var _that = {}, + _streamConfig = inputStream.getConfig(), + _video_size = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_cv_utils__["f"].bind()(inputStream.getRealWidth(), inputStream.getRealHeight()), + _canvasSize = inputStream.getCanvasSize(), + _size = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_cv_utils__["f"].bind()(inputStream.getWidth(), inputStream.getHeight()), + topRight = inputStream.getTopRight(), + _sx = topRight.x, + _sy = topRight.y, + _canvas, + _ctx = null, + _data = null; - while ((length | 0) > 0) { - length = length - 1 | 0; - images[imagePtr + length | 0] = value; - } + _canvas = canvas ? canvas : document.createElement("canvas"); + _canvas.width = _canvasSize.x; + _canvas.height = _canvasSize.y; + _ctx = _canvas.getContext("2d"); + _data = new Uint8Array(_size.x * _size.y); + if (true) { + console.log("FrameGrabber", JSON.stringify({ + size: _size, + topRight: topRight, + videoSize: _video_size, + canvasSize: _canvasSize + })); } - function dilate(inImagePtr, outImagePtr) { - inImagePtr = inImagePtr | 0; - outImagePtr = outImagePtr | 0; + /** + * Uses the given array as frame-buffer + */ + _that.attachData = function (data) { + _data = data; + }; - var v = 0, - u = 0, - sum = 0, - yStart1 = 0, - yStart2 = 0, - xStart1 = 0, - xStart2 = 0, - offset = 0; + /** + * Returns the used frame-buffer + */ + _that.getData = function () { + return _data; + }; - 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; - } + /** + * Fetches a frame from the input-stream and puts into the frame-buffer. + * The image-data is converted to gray-scale and then half-sampled if configured. + */ + _that.grab = function () { + var doHalfSample = _streamConfig.halfSample, + frame = inputStream.getFrame(), + ctxData; + if (frame) { + _ctx.drawImage(frame, 0, 0, _canvasSize.x, _canvasSize.y); + ctxData = _ctx.getImageData(_sx, _sy, _size.x, _size.y).data; + if (doHalfSample) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_cv_utils__["i"].bind()(ctxData, _size, _data); + } else { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_cv_utils__["j"].bind()(ctxData, _data, _streamConfig); } + return true; + } else { + return false; } - return; - } + }; - function memcpy(srcImagePtr, dstImagePtr) { - srcImagePtr = srcImagePtr | 0; - dstImagePtr = dstImagePtr | 0; + _that.getSize = function () { + return _size; + }; - var length = 0; + return _that; + }; - length = imul(size, size) | 0; + /* harmony default export */ exports["a"] = FrameGrabber; + +/***/ }, +/* 61 */ +/***/ function(module, exports, __webpack_require__) { + + var ImageLoader = {}; + ImageLoader.load = function (directory, callback, offset, size, sequence) { + var htmlImagesSrcArray = new Array(size), + htmlImagesArray = new Array(htmlImagesSrcArray.length), + i, + img, + num; - while ((length | 0) > 0) { - length = length - 1 | 0; - images[dstImagePtr + length | 0] = images[srcImagePtr + length | 0] | 0; + if (sequence === false) { + htmlImagesSrcArray[0] = directory; + } else { + for (i = 0; i < htmlImagesSrcArray.length; i++) { + num = offset + i; + htmlImagesSrcArray[i] = directory + "image-" + ("00" + num).slice(-3) + ".jpg"; } } - - 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; + htmlImagesArray.notLoaded = []; + htmlImagesArray.addImage = function (image) { + htmlImagesArray.notLoaded.push(image); + }; + htmlImagesArray.loaded = function (loadedImg) { + var notloadedImgs = htmlImagesArray.notLoaded; + for (var x = 0; x < notloadedImgs.length; x++) { + if (notloadedImgs[x] === loadedImg) { + notloadedImgs.splice(x, 1); + for (var y = 0; y < htmlImagesSrcArray.length; y++) { + var imgName = htmlImagesSrcArray[y].substr(htmlImagesSrcArray[y].lastIndexOf("/")); + if (loadedImg.src.lastIndexOf(imgName) !== -1) { + htmlImagesArray[y] = loadedImg; + break; + } + } + break; + } } - for (x = 0; (x | 0) < (size | 0); x = x + 1 | 0) { - images[imagePtr + y | 0] = 0; - y = y + 1 | 0; + if (notloadedImgs.length === 0) { + if (true) { + console.log("Images loaded"); + } + callback.apply(null, [htmlImagesArray]); } - } - - 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); + for (i = 0; i < htmlImagesSrcArray.length; i++) { + img = new Image(); + htmlImagesArray.addImage(img); + addOnloadHandler(img, htmlImagesArray); + img.src = htmlImagesSrcArray[i]; } + }; - return { - skeletonize: skeletonize + function addOnloadHandler(img, htmlImagesArray) { + img.onload = function () { + htmlImagesArray.loaded(this); }; } - exports["default"] = Skeletonizer; - - /* eslint-enable eqeqeq*/ - /* @preserve ASM END */ - module.exports = exports["default"]; + /* harmony default export */ exports["a"] = ImageLoader; /***/ }, -/* 23 */ +/* 62 */ /***/ function(module, exports, __webpack_require__) { - 'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _bresenham = __webpack_require__(24); - - var _bresenham2 = _interopRequireDefault(_bresenham); - - var _commonImage_debug = __webpack_require__(19); - - var _commonImage_debug2 = _interopRequireDefault(_commonImage_debug); - - var _readerCode_128_reader = __webpack_require__(25); - - var _readerCode_128_reader2 = _interopRequireDefault(_readerCode_128_reader); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__image_loader__ = __webpack_require__(61); - var _readerEan_reader = __webpack_require__(27); - var _readerEan_reader2 = _interopRequireDefault(_readerEan_reader); - - var _readerCode_39_reader = __webpack_require__(28); - - var _readerCode_39_reader2 = _interopRequireDefault(_readerCode_39_reader); + var InputStream = {}; + InputStream.createVideoStream = function (video) { + var that = {}, + _config = null, + _eventNames = ['canrecord', 'ended'], + _eventHandlers = {}, + _calculatedWidth, + _calculatedHeight, + _topRight = { x: 0, y: 0 }, + _canvasSize = { x: 0, y: 0 }; - var _readerCode_39_vin_reader = __webpack_require__(29); + function initSize() { + var width = video.videoWidth, + height = video.videoHeight; - var _readerCode_39_vin_reader2 = _interopRequireDefault(_readerCode_39_vin_reader); + _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; - var _readerCodabar_reader = __webpack_require__(30); + _canvasSize.x = _calculatedWidth; + _canvasSize.y = _calculatedHeight; + } - var _readerCodabar_reader2 = _interopRequireDefault(_readerCodabar_reader); + that.getRealWidth = function () { + return video.videoWidth; + }; - var _readerUpc_reader = __webpack_require__(31); + that.getRealHeight = function () { + return video.videoHeight; + }; - var _readerUpc_reader2 = _interopRequireDefault(_readerUpc_reader); + that.getWidth = function () { + return _calculatedWidth; + }; - var _readerEan_8_reader = __webpack_require__(32); + that.getHeight = function () { + return _calculatedHeight; + }; - var _readerEan_8_reader2 = _interopRequireDefault(_readerEan_8_reader); + that.setWidth = function (width) { + _calculatedWidth = width; + }; - var _readerUpc_e_reader = __webpack_require__(33); + that.setHeight = function (height) { + _calculatedHeight = height; + }; - var _readerUpc_e_reader2 = _interopRequireDefault(_readerUpc_e_reader); + that.setInputStream = function (config) { + _config = config; + video.src = typeof config.src !== 'undefined' ? config.src : ''; + }; - var _readerI2of5_reader = __webpack_require__(34); + that.ended = function () { + return video.ended; + }; - var _readerI2of5_reader2 = _interopRequireDefault(_readerI2of5_reader); + that.getConfig = function () { + return _config; + }; - var READERS = { - code_128_reader: _readerCode_128_reader2['default'], - ean_reader: _readerEan_reader2['default'], - ean_8_reader: _readerEan_8_reader2['default'], - code_39_reader: _readerCode_39_reader2['default'], - code_39_vin_reader: _readerCode_39_vin_reader2['default'], - codabar_reader: _readerCodabar_reader2['default'], - upc_reader: _readerUpc_reader2['default'], - upc_e_reader: _readerUpc_e_reader2['default'], - i2of5_reader: _readerI2of5_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 = []; + that.setAttribute = function (name, value) { + video.setAttribute(name, value); + }; - initCanvas(); - initReaders(); - initConfig(); + that.pause = function () { + video.pause(); + }; - function initCanvas() { - if ((true) && typeof document !== 'undefined') { - 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"); + that.play = function () { + video.play(); + }; - _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"); + that.setCurrentTime = function (time) { + if (_config.type !== "LiveStream") { + video.currentTime = time; + } + }; - _canvas.dom.overlay = document.querySelector("canvas.drawingBuffer"); - if (_canvas.dom.overlay) { - _canvas.ctx.overlay = _canvas.dom.overlay.getContext("2d"); - } + that.addEventListener = function (event, f, bool) { + if (_eventNames.indexOf(event) !== -1) { + if (!_eventHandlers[event]) { + _eventHandlers[event] = []; } + _eventHandlers[event].push(f); + } else { + video.addEventListener(event, f, bool); } + }; - function initReaders() { - config.readers.forEach(function (readerConfig) { - var reader, - configuration = {}; - - if (typeof readerConfig === 'object') { - reader = readerConfig.format; - configuration = readerConfig.config; - } else if (typeof readerConfig === 'string') { - reader = readerConfig; - } - if (true) { - console.log("Before registering reader: ", reader); - } - _barcodeReaders.push(new READERS[reader](configuration)); - }); - if (true) { - console.log("Registered Readers: " + _barcodeReaders.map(function (reader) { - return JSON.stringify({ format: reader.FORMAT, config: reader.config }); - }).join(', ')); + that.clearEventHandlers = function () { + _eventNames.forEach(function (eventName) { + var handlers = _eventHandlers[eventName]; + if (handlers && handlers.length > 0) { + handlers.forEach(function (handler) { + video.removeEventListener(eventName, handler); + }); } - } + }); + }; - function initConfig() { - if ((true) && typeof document !== 'undefined') { - var i, - vis = [{ - node: _canvas.dom.frequency, - prop: config.debug.showFrequency - }, { - node: _canvas.dom.pattern, - prop: config.debug.showPattern - }]; + that.trigger = function (eventName, args) { + var j, + handlers = _eventHandlers[eventName]; - 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"; - } - } + if (eventName === 'canrecord') { + initSize(); + } + if (handlers && handlers.length > 0) { + for (j = 0; j < handlers.length; j++) { + handlers[j].apply(that, args); } } + }; - /** - * 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) - }; + that.setTopRight = function (topRight) { + _topRight.x = topRight.x; + _topRight.y = topRight.y; + }; - line[0].y -= extension.y; - line[0].x -= extension.x; - line[1].y += extension.y; - line[1].x += extension.x; - } + that.getTopRight = function () { + return _topRight; + }; - // 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; - } + that.setCanvasSize = function (size) { + _canvasSize.x = size.x; + _canvasSize.y = size.y; + }; - 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] - }]; - } + that.getCanvasSize = function () { + return _canvasSize; + }; - function tryDecode(line) { - var result = null, - i, - barcodeLine = _bresenham2['default'].getBarcodeLine(inputImageWrapper, line[0], line[1]); + that.getFrame = function () { + return video; + }; - if ((true) && config.debug.showFrequency) { - _commonImage_debug2['default'].drawPath(line, { x: 'x', y: 'y' }, _canvas.ctx.overlay, { color: 'red', lineWidth: 3 }); - _bresenham2['default'].debug.printFrequency(barcodeLine.line, _canvas.dom.frequency); - } + return that; + }; - _bresenham2['default'].toBinaryLine(barcodeLine); + InputStream.createLiveStream = function (video) { + video.setAttribute("autoplay", true); + var that = InputStream.createVideoStream(video); - if ((true) && config.debug.showPattern) { - _bresenham2['default'].debug.printPattern(barcodeLine.line, _canvas.dom.pattern); - } + that.ended = function () { + return false; + }; - 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 - }; - } + return that; + }; - /** - * 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); + InputStream.createImageStream = function () { + var that = {}; + var _config = null; - 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; + var width = 0, + height = 0, + frameIdx = 0, + paused = true, + loaded = false, + imgArray = null, + size = 0, + offset = 1, + baseUrl = null, + ended = false, + calculatedWidth, + calculatedHeight, + _eventNames = ['canrecord', 'ended'], + _eventHandlers = {}, + _topRight = { x: 0, y: 0 }, + _canvasSize = { x: 0, y: 0 }; - result = tryDecode(line); + function loadImages() { + loaded = false; + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__image_loader__["a"].load(baseUrl, function (imgs) { + imgArray = imgs; + width = imgs[0].width; + height = imgs[0].height; + 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; + loaded = true; + frameIdx = 0; + setTimeout(function () { + publishEvent("canrecord", []); + }, 0); + }, offset, size, _config.sequence); + } + + 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); } - 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)); + that.trigger = publishEvent; + + that.getWidth = function () { + return calculatedWidth; + }; + + that.getHeight = function () { + return calculatedHeight; + }; + + that.setWidth = function (newWidth) { + calculatedWidth = newWidth; + }; + + that.setHeight = function (newHeight) { + calculatedHeight = newHeight; + }; + + that.getRealWidth = function () { + return width; + }; + + that.getRealHeight = function () { + return height; + }; + + that.setInputStream = function (stream) { + _config = stream; + if (stream.sequence === false) { + baseUrl = stream.src; + size = 1; + } else { + baseUrl = stream.src; + size = stream.length; } + loadImages(); + }; - /** - * 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; + that.ended = function () { + return ended; + }; - if (true) { - if (config.debug.drawBoundingBox && ctx) { - _commonImage_debug2['default'].drawPath(box, { x: 0, y: 1 }, ctx, { color: "blue", lineWidth: 2 }); - } - } + that.setAttribute = function () {}; - 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; - } + that.getConfig = function () { + return _config; + }; - result = tryDecode(line); - if (result === null) { - result = tryDecodeBruteForce(box, line, lineAngle); - } + that.pause = function () { + paused = true; + }; - if (result === null) { - return null; - } + that.play = function () { + paused = false; + }; - if ((true) && result && config.debug.drawScanline && ctx) { - _commonImage_debug2['default'].drawPath(line, { x: 'x', y: 'y' }, ctx, { color: 'red', lineWidth: 3 }); - } + that.setCurrentTime = function (time) { + frameIdx = time; + }; - return { - codeResult: result.codeResult, - line: line, - angle: lineAngle, - pattern: result.barcodeLine.line, - threshold: result.barcodeLine.threshold - }; + that.addEventListener = function (event, f) { + if (_eventNames.indexOf(event) !== -1) { + if (!_eventHandlers[event]) { + _eventHandlers[event] = []; + } + _eventHandlers[event].push(f); } + }; - return { - decodeFromBoundingBox: function decodeFromBoundingBox(box) { - return _decodeFromBoundingBox(box); - }, - decodeFromBoundingBoxes: function decodeFromBoundingBoxes(boxes) { - var i, - result, - barcodes = [], - multiple = config.multiple; + that.setTopRight = function (topRight) { + _topRight.x = topRight.x; + _topRight.y = topRight.y; + }; - for (i = 0; i < boxes.length; i++) { - var box = boxes[i]; - result = _decodeFromBoundingBox(box) || {}; - result.box = box; + that.getTopRight = function () { + return _topRight; + }; - if (multiple) { - barcodes.push(result); - } else if (result.codeResult) { - return result; - } - } + that.setCanvasSize = function (canvasSize) { + _canvasSize.x = canvasSize.x; + _canvasSize.y = canvasSize.y; + }; - if (multiple) { - return { - barcodes: barcodes - }; - } - }, - setReaders: function setReaders(readers) { - config.readers = readers; - _barcodeReaders.length = 0; - initReaders(); + that.getCanvasSize = function () { + return _canvasSize; + }; + + that.getFrame = function () { + var frame; + + if (!loaded) { + return null; + } + if (!paused) { + frame = imgArray[frameIdx]; + if (frameIdx < size - 1) { + frameIdx++; + } else { + setTimeout(function () { + ended = true; + publishEvent("ended", []); + }, 0); } - }; - } + } + return frame; + }; + + return that; }; - module.exports = exports['default']; + + /* harmony default export */ exports["a"] = InputStream; /***/ }, -/* 24 */ +/* 63 */ /***/ function(module, exports, __webpack_require__) { - 'use strict'; + /* WEBPACK VAR INJECTION */(function(global) {/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__ = __webpack_require__(18); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__common_cv_utils__ = __webpack_require__(17); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__common_array_helper__ = __webpack_require__(8); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__common_image_debug__ = __webpack_require__(9); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__rasterizer__ = __webpack_require__(64); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__tracer__ = __webpack_require__(29); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__skeletonizer__ = __webpack_require__(65); - Object.defineProperty(exports, '__esModule', { - value: true - }); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - var _commonCv_utils = __webpack_require__(5); - var _commonCv_utils2 = _interopRequireDefault(_commonCv_utils); - var _commonImage_wrapper = __webpack_require__(3); - var _commonImage_wrapper2 = _interopRequireDefault(_commonImage_wrapper); - var Bresenham = {}; + var vec2 = { + clone: __webpack_require__(6), + dot: __webpack_require__(31), + scale: __webpack_require__(76), + transformMat2: __webpack_require__(77) + }; + var mat2 = { + copy: __webpack_require__(73), + create: __webpack_require__(74), + invert: __webpack_require__(75) + }; - var Slope = { - DIR: { - UP: 1, - DOWN: -1 + var _config, + _currentImageWrapper, + _skelImageWrapper, + _subImageWrapper, + _labelImageWrapper, + _patchGrid, + _patchLabelGrid, + _imageToPatchGrid, + _binaryImageWrapper, + _patchSize, + _canvasContainer = { + ctx: { + binary: null + }, + dom: { + binary: null } - }; - /** - * 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; + }, + _numPatches = { x: 0, y: 0 }, + _inputImageWrapper, + _skeletonizer; - function read(a, b) { - val = imageData[b * width + a]; - sum += val; - min = val < min ? val : min; - max = val > max ? val : max; - line.push(val); + function initBuffers() { + var skeletonImageData; + + if (_config.halfSample) { + _currentImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"]({ + x: _inputImageWrapper.size.x / 2 | 0, + y: _inputImageWrapper.size.y / 2 | 0 + }); + } else { + _currentImageWrapper = _inputImageWrapper; } - if (steep) { - tmp = x0; - x0 = y0; - y0 = tmp; + _patchSize = /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["b"].bind()(_config.patchSize, _currentImageWrapper.size); - tmp = x1; - x1 = y1; - y1 = tmp; - } - if (x0 > x1) { - tmp = x0; - x0 = x1; - x1 = tmp; + _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0; + _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0; - 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; - } - } + _binaryImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"](_currentImageWrapper.size, undefined, Uint8Array, false); - return { - line: line, - min: min, - max: max - }; - }; + _labelImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"](_patchSize, undefined, Array, true); - Bresenham.toOtsuBinaryLine = function (result) { - var line = result.line, - image = new _commonImage_wrapper2['default']({ x: line.length - 1, y: 1 }, line), - threshold = _commonCv_utils2['default'].determineOtsuThreshold(image, 5); + skeletonImageData = new ArrayBuffer(64 * 1024); + _subImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"](_patchSize, new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y)); + _skelImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"](_patchSize, new Uint8Array(skeletonImageData, _patchSize.x * _patchSize.y * 3, _patchSize.x * _patchSize.y), undefined, true); + _skeletonizer = /* harmony import */__WEBPACK_IMPORTED_MODULE_6__skeletonizer__["a"].bind()(typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : global, { + size: _patchSize.x + }, skeletonImageData); - line = _commonCv_utils2['default'].sharpenLine(line); - _commonCv_utils2['default'].thresholdImage(image, threshold); + _imageToPatchGrid = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"]({ + x: _currentImageWrapper.size.x / _subImageWrapper.size.x | 0, + y: _currentImageWrapper.size.y / _subImageWrapper.size.y | 0 + }, undefined, Array, true); + _patchGrid = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"](_imageToPatchGrid.size, undefined, undefined, true); + _patchLabelGrid = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"](_imageToPatchGrid.size, undefined, Int32Array, true); + } - return { - line: line, - threshold: threshold - }; - }; + function initCanvas() { + if (_config.useWorker || typeof document === 'undefined') { + return; + } + _canvasContainer.dom.binary = document.createElement("canvas"); + _canvasContainer.dom.binary.className = "binaryBuffer"; + if (true && _config.debug.showCanvas === true) { + 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; + } /** - * 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} + * Creates a bounding box which encloses all the given patches + * @returns {Array} The minimal bounding box */ - 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, + function boxFromPatches(patches) { + var overAvg, 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; - } + j, + patch, + transMat, + minx = _binaryImageWrapper.size.x, + miny = _binaryImageWrapper.size.y, + maxx = -_binaryImageWrapper.size.x, + maxy = -_binaryImageWrapper.size.y, + box, + scale; - if (currentDir !== dir) { - extrema.push({ - pos: i, - val: line[i] - }); - currentDir = dir; + // draw all patches which are to be taken into consideration + overAvg = 0; + for (i = 0; i < patches.length; i++) { + patch = patches[i]; + overAvg += patch.rad; + if (true && _config.debug.showPatches) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "red" }); } } - 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; + overAvg /= patches.length; + overAvg = (overAvg * 180 / Math.PI + 90) % 180 - 90; + if (overAvg < 0) { + overAvg += 180; } - // 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; - } + overAvg = (180 - overAvg) * Math.PI / 180; + transMat = mat2.copy(mat2.create(), [Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]); - for (j = extrema[i].pos; j < extrema[i + 1].pos; j++) { - line[j] = line[j] > threshold ? 0 : 1; + // 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); } - } - - 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]); + if (true && _config.debug.boxFromPatches.showTransformed) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].drawPath(patch.box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#99ff00', lineWidth: 2 }); } - 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); + // 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]; } } } - }; - exports['default'] = Bresenham; - module.exports = exports['default']; - -/***/ }, -/* 25 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; + box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]]; - Object.defineProperty(exports, "__esModule", { - value: true - }); + if (true && _config.debug.boxFromPatches.showTransformedBox) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); + } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + 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); + } - var _barcode_reader = __webpack_require__(26); + if (true && _config.debug.boxFromPatches.showBB) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); + } - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); + for (j = 0; j < 4; j++) { + vec2.scale(box[j], box[j], scale); + } - function Code128Reader() { - _barcode_reader2["default"].call(this); + return box; } - 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 }, - MODULO: { value: 11 }, - 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: 1 }, - AVG_CODE_ERROR: { value: 0.5 }, - FORMAT: { value: "code_128", writeable: false } - }; + /** + * Creates a binary image of the current image + */ + function binarizeImage() { + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["c"].bind()(_currentImageWrapper, _binaryImageWrapper); + _binaryImageWrapper.zeroBorder(); + if (_config.showCanvas) { + _binaryImageWrapper.show(_canvasContainer.dom.binary, 255); + } + } - Code128Reader.prototype = Object.create(_barcode_reader2["default"].prototype, properties); - Code128Reader.prototype.constructor = Code128Reader; + /** + * 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; - Code128Reader.prototype._decodeCode = function (start) { - 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 - }, - code, - error, - normalized; + // seperate parts + skeletonize(x, y); - for (i = offset; i < self._row.length; i++) { - if (self._row[i] ^ isWhite) { - counter[counterPos]++; - } else { - if (counterPos === counter.length - 1) { - normalized = self._normalize(counter); - if (normalized) { - for (code = 0; code < self.CODE_PATTERN.length; code++) { - error = self._matchPattern(normalized, self.CODE_PATTERN[code]); - if (error < bestMatch.error) { - bestMatch.code = code; - bestMatch.error = error; - } - } - bestMatch.end = i; - return bestMatch; - } - } else { - counterPos++; + // Rasterize, find individual bars + _skelImageWrapper.zeroBorder(); + /* harmony import */__WEBPACK_IMPORTED_MODULE_2__common_array_helper__["a"].init(_labelImageWrapper.data, 0); + rasterizer = /* harmony import */__WEBPACK_IMPORTED_MODULE_4__rasterizer__["a"].create(_skelImageWrapper, _labelImageWrapper); + rasterResult = rasterizer.rasterize(0); + + if (true && _config.debug.showLabels) { + _labelImageWrapper.overlay(_canvasContainer.dom.binary, Math.floor(360 / rasterResult.count), { x: x, y: y }); } - counter[counterPos] = 1; - isWhite = !isWhite; - } - } - return null; - }; - 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 - }, - code, - error, - j, - sum, - normalized; + // calculate moments from the skeletonized patch + moments = _labelImageWrapper.moments(rasterResult.count); - 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]; - } - normalized = self._normalize(counter); - if (normalized) { - for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) { - error = self._matchPattern(normalized, 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; - return bestMatch; - } - } + // extract eligible patches + patchesFound = patchesFound.concat(describePatch(moments, [i, j], x, y)); + } + } - 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; + if (true && _config.debug.showFoundPatches) { + for (i = 0; i < patchesFound.length; i++) { + patch = patchesFound[i]; + /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "#99ff00", lineWidth: 2 }); } } - 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; + return patchesFound; + } - if (startInfo === null) { - return null; + /** + * 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); } - code = { - code: startInfo.code, - start: startInfo.start, - end: startInfo.end - }; - 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; + sum = _patchLabelGrid.data.length; + while (sum--) { + if (_patchLabelGrid.data[sum] > 0) { + labelHist[_patchLabelGrid.data[sum] - 1]++; + } } - while (!done) { - unshift = shiftNext; - shiftNext = false; - code = self._decodeCode(code.end); - if (code !== null) { - if (code.code !== self.STOP_CODE) { - removeLastCharacter = true; - } + labelHist = labelHist.map(function (val, idx) { + return { + val: val, + label: idx + 1 + }; + }); - if (code.code !== self.STOP_CODE) { - rawResult.push(code.code); - multiplier++; - checksum += multiplier * code.code; - } - decodedCodes.push(code); + labelHist.sort(function (a, b) { + return b.val - a.val; + }); - 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; + // 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 (true && _config.debug.showRemainingPatchLabels) { + for (j = 0; j < patches.length; j++) { + patch = patches[j]; + hsv[0] = topLabels[i].label / (maxLabel + 1) * 360; + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["a"].bind()(hsv, rgb); + /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].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 = /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["d"].bind()(moments, 0.90); + var topCluster = /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["e"].bind()(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, /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["f"].bind()(x, y)); + _skeletonizer.skeletonize(); + + // Show skeleton if requested + if (true && _config.debug.showSkeleton) { + _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["f"].bind()(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 < /* harmony import */__WEBPACK_IMPORTED_MODULE_5__tracer__["a"].searchDirections.length; dir++) { + y = current.y + /* harmony import */__WEBPACK_IMPORTED_MODULE_5__tracer__["a"].searchDirections[dir][0]; + x = current.x + /* harmony import */__WEBPACK_IMPORTED_MODULE_5__tracer__["a"].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 + /* harmony import */__WEBPACK_IMPORTED_MODULE_2__common_array_helper__["a"].init(_patchGrid.data, 0); + /* harmony import */__WEBPACK_IMPORTED_MODULE_2__common_array_helper__["a"].init(_patchLabelGrid.data, 0); + /* harmony import */__WEBPACK_IMPORTED_MODULE_2__common_array_helper__["a"].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 (true && _config.debug.showPatchLabels) { + for (j = 0; j < _patchLabelGrid.data.length; j++) { + if (_patchLabelGrid.data[j] > 0 && _patchLabelGrid.data[j] <= label) { + patch = _imageToPatchGrid.data[j]; + hsv[0] = _patchLabelGrid.data[j] / (label + 1) * 360; + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["a"].bind()(hsv, rgb); + /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "rgb(" + rgb.join(",") + ")", lineWidth: 2 }); + } + } + } + + return label; + } + + /* harmony default export */ exports["a"] = { + init: function init(inputImageWrapper, config) { + _config = config; + _inputImageWrapper = inputImageWrapper; + + initBuffers(); + initCanvas(); + }, + + locate: function locate() { + var patchesFound, topLabels, boxes; + + if (_config.halfSample) { + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["g"].bind()(_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 = /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["h"].bind()(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 = /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["b"].bind()(config.patchSize, size); + if (true) { + 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, (function() { return this; }()))) + +/***/ }, +/* 64 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__tracer__ = __webpack_require__(29); + + + /** + * 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 = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__tracer__["a"].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]; } } - break; - case self.CODE_B: - if (code.code < 96) { - result.push(String.fromCharCode(32 + code.code)); + } + 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 { - 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; - } + iq = null; } - 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; + + 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 (code.code) { - case self.CODE_A: - codeset = self.CODE_A; + + switch (q.dir) { + case Rasterizer.CONTOUR_DIR.CW_DIR: + ctx.strokeStyle = "red"; break; - case self.CODE_B: - codeset = self.CODE_B; + case Rasterizer.CONTOUR_DIR.CCW_DIR: + ctx.strokeStyle = "blue"; break; - case self.STOP_CODE: - done = true; + 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(); } - break; + } } - } else { - done = true; + }; + } + }; + + /* harmony default export */ exports["a"] = Rasterizer; + +/***/ }, +/* 65 */ +/***/ function(module, exports, __webpack_require__) { + + /* @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; } - if (unshift) { - codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A; + for (x = 0; (x | 0) < (size | 0); x = x + 1 | 0) { + images[imagePtr + y | 0] = 0; + y = y + 1 | 0; } } - if (code === null) { - return null; + 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 */ + /* harmony default export */ exports["a"] = Skeletonizer; + /* eslint-enable eqeqeq*/ + +/***/ }, +/* 66 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__barcode_reader__ = __webpack_require__(5); - code.end = self._nextUnset(self._row, code.end); - if (!self._verifyTrailingWhitespace(code)) { + + function CodabarReader() { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].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(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].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; - checksum -= multiplier * rawResult[rawResult.length - 1]; - if (checksum % 103 !== rawResult[rawResult.length - 1]) { + 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; } - if (!result.length) { + // verify end white space + if (!self._verifyWhitespace(start.startCounter, nextStart - 8)) { return null; } - // remove last code from result (checksum) - if (removeLastCharacter) { - result.splice(result.length - 1, 1); + 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: startInfo.start, - end: code.end, - codeset: codeset, - startInfo: startInfo, - decodedCodes: decodedCodes, - endInfo: code + start: start.start, + end: end, + startInfo: start, + decodedCodes: result }; }; - _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; + 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 null; + return false; }; - exports["default"] = Code128Reader; - module.exports = exports["default"]; - -/***/ }, -/* 26 */ -/***/ function(module, exports) { - - 'use strict'; + CodabarReader.prototype._calculatePatternLength = function (offset) { + var i, + sum = 0; - Object.defineProperty(exports, '__esModule', { - value: true - }); - function BarcodeReader(config) { - this._row = []; - this.config = config || {}; - return this; - } + for (i = offset; i < offset + 7; i++) { + sum += this._counters[i]; + } - BarcodeReader.prototype._nextUnset = function (line, start) { - var i; + return sum; + }; - if (start === undefined) { - start = 0; - } - for (i = start; i < line.length; i++) { - if (!line[i]) { - return i; + 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; } - return line.length; + + ["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; }; - BarcodeReader.prototype._matchPattern = function (counter, code) { - var i, - error = 0, - singleError = 0, - modulo = this.MODULO, - maxSingleError = this.SINGLE_CODE_ERROR || 1; + CodabarReader.prototype._charToPattern = function (char) { + var self = this, + charCode = char.charCodeAt(0), + i; - for (i = 0; i < counter.length; i++) { - singleError = Math.abs(code[i] - counter[i]); - if (singleError > maxSingleError) { - return Number.MAX_VALUE; + for (i = 0; i < self.ALPHABET.length; i++) { + if (self.ALPHABET[i] === charCode) { + return self.CHARACTER_ENCODINGS[i]; } - error += singleError; } - return error / modulo; + return 0x0; }; - BarcodeReader.prototype._nextSet = function (line, offset) { - var i; + CodabarReader.prototype._validateResult = function (result, startCounter) { + var self = this, + thresholds = self._thresholdResultPattern(result, startCounter), + i, + j, + kind, + cat, + size, + pos = startCounter, + pattern; - offset = offset || 0; - for (i = offset; i < line.length; i++) { - if (line[i]) { - return i; + 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 line.length; + return -1; }; - BarcodeReader.prototype._normalize = function (counter, modulo) { + CodabarReader.prototype._computeAlternatingThreshold = function (offset, end) { var i, - self = this, - sum = 0, - ratio, - numOnes = 0, - normalized = [], - norm = 0; + min = Number.MAX_VALUE, + max = 0, + counter; - if (!modulo) { - modulo = self.MODULO; - } - for (i = 0; i < counter.length; i++) { - if (counter[i] === 1) { - numOnes++; - } else { - sum += counter[i]; - } - } - ratio = sum / (modulo - numOnes); - if (ratio > 1.0) { - for (i = 0; i < counter.length; i++) { - norm = counter[i] === 1 ? counter[i] : counter[i] / ratio; - normalized.push(norm); + for (i = offset; i < end; i += 2) { + counter = this._counters[i]; + if (counter > max) { + max = counter; } - } else { - ratio = (sum + numOnes) / modulo; - for (i = 0; i < counter.length; i++) { - norm = counter[i] / ratio; - normalized.push(norm); + if (counter < min) { + min = counter; } } - return normalized; + + return (min + max) / 2.0 | 0; }; - BarcodeReader.prototype._matchTrace = function (cmpCounter, epsilon) { - var counter = [], + CodabarReader.prototype._toPattern = function (offset) { + var numCounters = 7, + end = offset + numCounters, + barThreshold, + spaceThreshold, + bitmask = 1 << numCounters - 1, + pattern = 0, i, - self = this, - offset = self._nextSet(self._row), - isWhite = !self._row[offset], - counterPos = 0, - bestMatch = { - error: Number.MAX_VALUE, - code: -1, - start: 0 - }, - error; + threshold; - 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 (end > this._counters.length) { + return -1; + } - 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; - } + 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; } - // if cmpCounter was not given - bestMatch.start = offset; - bestMatch.end = self._row.length - 1; - bestMatch.counter = counter; - return bestMatch; + return pattern; }; - BarcodeReader.prototype.decodePattern = function (pattern) { - var self = this, - result; + CodabarReader.prototype._isStartEnd = function (pattern) { + var i; - 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; + for (i = 0; i < this.START_END.length; i++) { + if (this.START_END[i] === pattern) { + return true; } - } else { - result.direction = BarcodeReader.DIRECTION.FORWARD; - } - if (result) { - result.format = self.FORMAT; } - return result; + return false; }; - BarcodeReader.prototype._matchRange = function (start, end, value) { - var i; + CodabarReader.prototype._sumCounters = function (start, end) { + var i, + sum = 0; - start = start < 0 ? 0 : start; for (i = start; i < end; i++) { - if (this._row[i] !== value) { - return false; - } + sum += this._counters[i]; } - return true; + return sum; }; - BarcodeReader.prototype._fillCounters = function (offset, end, isWhite) { + CodabarReader.prototype._findStart = function () { 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; + pattern, + start = self._nextUnset(self._row), + end; - counters[counterPos] = 0; - for (i = offset; i < end; i++) { - if (self._row[i] ^ isWhite) { - counters[counterPos]++; - } else { - counterPos++; - counters[counterPos] = 1; - isWhite = !isWhite; + 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 + }; } } - return counters; - }; - - 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; - module.exports = exports['default']; + /* harmony default export */ exports["a"] = CodabarReader; /***/ }, -/* 27 */ +/* 67 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__barcode_reader__ = __webpack_require__(5); - Object.defineProperty(exports, "__esModule", { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } - - var _barcode_reader = __webpack_require__(26); - - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); - function EANReader(opts) { - _barcode_reader2["default"].call(this, opts); + function Code128Reader() { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].call(this); } var properties = { - CODE_L_START: { value: 0 }, - MODULO: { value: 7 }, - CODE_G_START: { value: 10 }, - START_PATTERN: { value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7] }, - STOP_PATTERN: { value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7] }, - MIDDLE_PATTERN: { value: [1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7] }, - 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.67 }, - AVG_CODE_ERROR: { value: 0.27 }, - FORMAT: { value: "ean_13", writeable: false } + 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 }, + MODULO: { value: 11 }, + 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: 1 }, + AVG_CODE_ERROR: { value: 0.5 }, + FORMAT: { value: "code_128", writeable: false } }; - EANReader.prototype = Object.create(_barcode_reader2["default"].prototype, properties); - EANReader.prototype.constructor = EANReader; + Code128Reader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].prototype, properties); + Code128Reader.prototype.constructor = Code128Reader; - EANReader.prototype._decodeCode = function (start, coderange) { - var counter = [0, 0, 0, 0], + Code128Reader.prototype._decodeCode = function (start) { + var counter = [0, 0, 0, 0, 0, 0], i, self = this, offset = start, @@ -9424,10 +7031,6 @@ return /******/ (function(modules) { // webpackBootstrap error, normalized; - if (!coderange) { - coderange = self.CODE_PATTERN.length; - } - for (i = offset; i < self._row.length; i++) { if (self._row[i] ^ isWhite) { counter[counterPos]++; @@ -9435,7 +7038,7 @@ return /******/ (function(modules) { // webpackBootstrap if (counterPos === counter.length - 1) { normalized = self._normalize(counter); if (normalized) { - for (code = 0; code < coderange; code++) { + for (code = 0; code < self.CODE_PATTERN.length; code++) { error = self._matchPattern(normalized, self.CODE_PATTERN[code]); if (error < bestMatch.error) { bestMatch.code = code; @@ -9443,9 +7046,6 @@ return /******/ (function(modules) { // webpackBootstrap } } bestMatch.end = i; - if (bestMatch.error > self.AVG_CODE_ERROR) { - return null; - } return bestMatch; } } else { @@ -9458,10 +7058,12 @@ return /******/ (function(modules) { // webpackBootstrap return null; }; - EANReader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder, epsilon) { - var counter = [], - self = this, + 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, @@ -9469,31 +7071,12 @@ return /******/ (function(modules) { // webpackBootstrap start: 0, end: 0 }, + code, error, j, sum, normalized; - 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]++; @@ -9505,25 +7088,26 @@ return /******/ (function(modules) { // webpackBootstrap } normalized = self._normalize(counter); if (normalized) { - error = self._matchPattern(normalized, pattern); - - if (error < epsilon) { - bestMatch.error = error; + for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) { + error = self._matchPattern(normalized, 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; 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; + + for (j = 0; j < 4; j++) { + counter[j] = counter[j + 2]; } + counter[4] = 0; + counter[5] = 0; + counterPos--; } else { counterPos++; } @@ -9534,413 +7118,199 @@ return /******/ (function(modules) { // webpackBootstrap return null; }; - EANReader.prototype._findStart = function () { + Code128Reader.prototype._decode = function () { var self = this, - leadingWhitespaceStart, - offset = self._nextSet(self._row), - startInfo; + startInfo = self._findStart(), + code = null, + done = false, + result = [], + multiplier = 0, + checksum = 0, + codeset, + rawResult = [], + decodedCodes = [], + shiftNext = false, + unshift, + removeLastCharacter = true; - 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; + if (startInfo === null) { + return 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; - } + code = { + code: startInfo.code, + start: startInfo.start, + end: startInfo.end + }; + 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; } - 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; - }; + while (!done) { + unshift = shiftNext; + shiftNext = false; + code = self._decodeCode(code.end); + if (code !== null) { + if (code.code !== self.STOP_CODE) { + removeLastCharacter = true; + } - EANReader.prototype._decodePayload = function (code, result, decodedCodes) { - var i, - self = this, - codeFrequency = 0x0, - firstDigit; + if (code.code !== self.STOP_CODE) { + rawResult.push(code.code); + multiplier++; + checksum += multiplier * code.code; + } + decodedCodes.push(code); - 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; + 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 { - codeFrequency |= 0 << 5 - i; + done = true; } - 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; + if (unshift) { + codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A; } - decodedCodes.push(code); - result.push(code.code); } - return code; - }; - - EANReader.prototype._decode = function () { - var startInfo, - self = this, - code, - result = [], - decodedCodes = []; - - 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) { + if (code === null) { return null; } - decodedCodes.push(code); - - // Checksum - if (!self._checksum(result)) { + code.end = self._nextUnset(self._row, code.end); + if (!self._verifyTrailingWhitespace(code)) { return null; } - return { - code: result.join(""), - start: startInfo.start, - end: code.end, - codeset: "", - startInfo: startInfo, - decodedCodes: decodedCodes - }; - }; - - 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; - }; - - exports["default"] = EANReader; - module.exports = exports["default"]; - -/***/ }, -/* 28 */ -/***/ function(module, exports, __webpack_require__) { - - 'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _barcode_reader = __webpack_require__(26); - - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); - - var _commonArray_helper = __webpack_require__(17); - - var _commonArray_helper2 = _interopRequireDefault(_commonArray_helper); - - 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._toCounters = function (start, counter) { - var self = this, - numCounters = counter.length, - end = self._row.length, - isWhite = !self._row[start], - i, - counterPos = 0; - - _commonArray_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; - }; - - 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) { + checksum -= multiplier * rawResult[rawResult.length - 1]; + if (checksum % 103 !== rawResult[rawResult.length - 1]) { 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 += _commonArray_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; + // remove last code from result (checksum) + if (removeLastCharacter) { + result.splice(result.length - 1, 1); } return { code: result.join(""), - start: start.start, - end: nextStart, - startInfo: start, - decodedCodes: result - }; - }; - - Code39Reader.prototype._verifyTrailingWhitespace = function (lastStart, nextStart, counters) { - var trailingWhitespaceEnd, - patternSize = _commonArray_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 - }; - } - } + start: startInfo.start, + end: code.end, + codeset: codeset, + startInfo: startInfo, + decodedCodes: decodedCodes, + endInfo: code + }; + }; - 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; + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].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; }; - exports['default'] = Code39Reader; - module.exports = exports['default']; + /* harmony default export */ exports["a"] = Code128Reader; /***/ }, -/* 29 */ +/* 68 */ /***/ function(module, exports, __webpack_require__) { - 'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__code_39_reader__ = __webpack_require__(30); - var _code_39_reader = __webpack_require__(28); - - var _code_39_reader2 = _interopRequireDefault(_code_39_reader); function Code39VINReader() { - _code_39_reader2['default'].call(this); + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__code_39_reader__["a"].call(this); } var patterns = { @@ -9948,13 +7318,13 @@ return /******/ (function(modules) { // webpackBootstrap AZ09: /[A-Z0-9]{17}/ }; - Code39VINReader.prototype = Object.create(_code_39_reader2['default'].prototype); + Code39VINReader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__code_39_reader__["a"].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); + var result = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__code_39_reader__["a"].prototype._decode.apply(this); if (!result) { return null; } @@ -9987,428 +7357,399 @@ return /******/ (function(modules) { // webpackBootstrap return !!code; }; - exports['default'] = Code39VINReader; - module.exports = exports['default']; + /* harmony default export */ exports["a"] = Code39VINReader; /***/ }, -/* 30 */ +/* 69 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__ean_reader__ = __webpack_require__(10); - var _barcode_reader = __webpack_require__(26); - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); - - function CodabarReader() { - _barcode_reader2["default"].call(this); - this._counters = []; + function EAN8Reader() { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].call(this); } 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 } + FORMAT: { value: "ean_8", 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; + EAN8Reader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].prototype, properties); + EAN8Reader.prototype.constructor = EAN8Reader; - this._counters = self._fillCounters(); - start = self._findStart(); - if (!start) { - return null; - } - nextStart = start.startCounter; + EAN8Reader.prototype._decodePayload = function (code, result, decodedCodes) { + var i, + self = this; - do { - pattern = self._toPattern(nextStart); - if (pattern < 0) { - return null; - } - decodedChar = self._patternToChar(pattern); - if (decodedChar < 0) { + for (i = 0; i < 4; i++) { + code = self._decodeCode(code.end, self.CODE_G_START); + if (!code) { 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; + result.push(code.code); + decodedCodes.push(code); } - if (!self._validateResult(result, start.startCounter)) { + code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); + if (code === null) { return null; } + decodedCodes.push(code); - 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; + for (i = 0; i < 4; i++) { + code = self._decodeCode(code.end, self.CODE_G_START); + if (!code) { + return null; } - } - return false; - }; - - CodabarReader.prototype._calculatePatternLength = function (offset) { - var i, - sum = 0; - - for (i = offset; i < offset + 7; i++) { - sum += this._counters[i]; + decodedCodes.push(code); + result.push(code.code); } - return sum; + return code; }; - 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; - } + /* harmony default export */ exports["a"] = EAN8Reader; + +/***/ }, +/* 70 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_merge__ = __webpack_require__(28); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_lodash_merge___default = __WEBPACK_IMPORTED_MODULE_0_lodash_merge__ && __WEBPACK_IMPORTED_MODULE_0_lodash_merge__.__esModule ? function() { return __WEBPACK_IMPORTED_MODULE_0_lodash_merge__['default'] } : function() { return __WEBPACK_IMPORTED_MODULE_0_lodash_merge__; } + /* harmony import */ Object.defineProperty(__WEBPACK_IMPORTED_MODULE_0_lodash_merge___default, 'a', { get: __WEBPACK_IMPORTED_MODULE_0_lodash_merge___default }); + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__barcode_reader__ = __webpack_require__(5); - ["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]; - } + function I2of5Reader(opts) { + opts = /* harmony import */__WEBPACK_IMPORTED_MODULE_0_lodash_merge___default.a.bind()(getDefaulConfig(), opts); + /* harmony import */__WEBPACK_IMPORTED_MODULE_1__barcode_reader__["a"].call(this, opts); + this.barSpaceRatio = [1, 1]; + if (opts.normalizeBarSpaceWidth) { + this.SINGLE_CODE_ERROR = 0.38; + this.AVG_CODE_ERROR = 0.09; } - 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; - }; + function getDefaulConfig() { + var config = {}; - CodabarReader.prototype._patternToChar = function (pattern) { - var i, - self = this; + Object.keys(I2of5Reader.CONFIG_KEYS).forEach(function (key) { + config[key] = I2of5Reader.CONFIG_KEYS[key].default; + }); + return config; + } - for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) { - if (self.CHARACTER_ENCODINGS[i] === pattern) { - return String.fromCharCode(self.ALPHABET[i]); - } - } - return -1; + var N = 1, + W = 3, + properties = { + MODULO: { value: 10 }, + START_PATTERN: { value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5] }, + STOP_PATTERN: { value: [N * 2, N * 2, W * 2] }, + 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" } }; - CodabarReader.prototype._computeAlternatingThreshold = function (offset, end) { - var i, - min = Number.MAX_VALUE, - max = 0, - counter; + I2of5Reader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_1__barcode_reader__["a"].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 = offset; i < end; i += 2) { - counter = this._counters[i]; - if (counter > max) { - max = counter; + for (i = 0; i < counter.length; i++) { + counterSum[i % 2] += counter[i]; + codeSum[i % 2] += code[i]; } - if (counter < min) { - min = counter; + 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 (min + max) / 2.0 | 0; + return /* harmony import */__WEBPACK_IMPORTED_MODULE_1__barcode_reader__["a"].prototype._matchPattern.call(this, counter, code); }; - CodabarReader.prototype._toPattern = function (offset) { - var numCounters = 7, - end = offset + numCounters, - barThreshold, - spaceThreshold, - bitmask = 1 << numCounters - 1, - pattern = 0, + I2of5Reader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder) { + var counter = [], + self = this, i, - threshold; - - if (end > this._counters.length) { - return -1; - } + counterPos = 0, + bestMatch = { + error: Number.MAX_VALUE, + code: -1, + start: 0, + end: 0 + }, + error, + j, + sum, + normalized, + epsilon = self.AVG_CODE_ERROR; - barThreshold = this._computeAlternatingThreshold(offset, end); - spaceThreshold = this._computeAlternatingThreshold(offset + 1, end); + isWhite = isWhite || false; + tryHarder = tryHarder || false; - for (i = 0; i < numCounters; i++) { - threshold = (i & 1) === 0 ? barThreshold : spaceThreshold; - if (this._counters[offset + i] > threshold) { - pattern |= bitmask; - } - bitmask >>= 1; + if (!offset) { + offset = self._nextSet(self._row); } - return pattern; - }; + for (i = 0; i < pattern.length; i++) { + counter[i] = 0; + } - CodabarReader.prototype._isStartEnd = function (pattern) { - var i; + 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]; + } + normalized = self._normalize(counter); + if (normalized) { + error = self._matchPattern(normalized, pattern); - for (i = 0; i < this.START_END.length; i++) { - if (this.START_END[i] === pattern) { - return true; + 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 false; + return null; }; - CodabarReader.prototype._sumCounters = function (start, end) { - var i, - sum = 0; + I2of5Reader.prototype._findStart = function () { + var self = this, + leadingWhitespaceStart, + offset = self._nextSet(self._row), + startInfo, + narrowBarWidth = 1; - for (i = start; i < end; i++) { - sum += this._counters[i]; + 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; } - return sum; }; - CodabarReader.prototype._findStart = function () { + I2of5Reader.prototype._verifyTrailingWhitespace = function (endInfo) { var self = this, - i, - pattern, - start = self._nextUnset(self._row), - end; + trailingWhitespaceEnd; - 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 - }; + trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; + if (trailingWhitespaceEnd < self._row.length) { + if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { + return endInfo; } } + return null; }; - exports["default"] = CodabarReader; - module.exports = exports["default"]; - -/***/ }, -/* 31 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; + I2of5Reader.prototype._findEnd = function () { + var self = this, + endInfo, + tmp; - Object.defineProperty(exports, "__esModule", { - value: true - }); + self._row.reverse(); + endInfo = self._findPattern(self.STOP_PATTERN); + self._row.reverse(); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + if (endInfo === null) { + return null; + } - var _ean_reader = __webpack_require__(27); + // reverse numbers + tmp = endInfo.start; + endInfo.start = self._row.length - endInfo.end; + endInfo.end = self._row.length - tmp; - var _ean_reader2 = _interopRequireDefault(_ean_reader); + return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null; + }; - function UPCReader() { - _ean_reader2["default"].call(this); - } + I2of5Reader.prototype._decodePair = function (counterPair) { + var i, + code, + codes = [], + self = this; - var properties = { - FORMAT: { value: "upc_a", writeable: false } + for (i = 0; i < counterPair.length; i++) { + code = self._decodeCode(counterPair[i]); + if (!code) { + return null; + } + codes.push(code); + } + return codes; }; - UPCReader.prototype = Object.create(_ean_reader2["default"].prototype, properties); - UPCReader.prototype.constructor = UPCReader; + 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 + }; - UPCReader.prototype._decode = function () { - var result = _ean_reader2["default"].prototype._decode.call(this); + for (j = 0; j < counter.length; j++) { + sum += counter[j]; + } + normalized = self._normalize(counter); + if (normalized) { + for (code = 0; code < self.CODE_PATTERN.length; code++) { + error = self._matchPattern(normalized, self.CODE_PATTERN[code]); + if (error < bestMatch.error) { + bestMatch.code = code; + bestMatch.error = error; + } + } + if (bestMatch.error < epsilon) { + return bestMatch; + } + } + return null; + }; - if (result && result.code && result.code.length === 13 && result.code.charAt(0) === "0") { - result.code = result.code.substring(1); - return result; + 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 null; + return codes; }; - exports["default"] = UPCReader; - module.exports = exports["default"]; - -/***/ }, -/* 32 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } - - var _ean_reader = __webpack_require__(27); - - var _ean_reader2 = _interopRequireDefault(_ean_reader); - - function EAN8Reader() { - _ean_reader2["default"].call(this); - } - - var properties = { - FORMAT: { value: "ean_8", writeable: false } + I2of5Reader.prototype._verifyCounterLength = function (counters) { + return counters.length % 10 === 0; }; - EAN8Reader.prototype = Object.create(_ean_reader2["default"].prototype, properties); - EAN8Reader.prototype.constructor = EAN8Reader; - - EAN8Reader.prototype._decodePayload = function (code, result, decodedCodes) { - var i, - self = this; + I2of5Reader.prototype._decode = function () { + var startInfo, + endInfo, + self = this, + code, + result = [], + decodedCodes = [], + counters; - 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); + startInfo = self._findStart(); + if (!startInfo) { + return null; } + decodedCodes.push(startInfo); - code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); - if (code === null) { + endInfo = self._findEnd(); + if (!endInfo) { 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); + 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; } - return code; + 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"] = EAN8Reader; - module.exports = exports["default"]; + /* harmony default export */ exports["a"] = I2of5Reader; /***/ }, -/* 33 */ +/* 71 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__ean_reader__ = __webpack_require__(10); - var _ean_reader = __webpack_require__(27); - - var _ean_reader2 = _interopRequireDefault(_ean_reader); function UPCEReader() { - _ean_reader2["default"].call(this); + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].call(this); } var properties = { @@ -10417,7 +7758,7 @@ return /******/ (function(modules) { // webpackBootstrap FORMAT: { value: "upc_e", writeable: false } }; - UPCEReader.prototype = Object.create(_ean_reader2["default"].prototype, properties); + UPCEReader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].prototype, properties); UPCEReader.prototype.constructor = UPCEReader; UPCEReader.prototype._decodePayload = function (code, result, decodedCodes) { @@ -10459,2601 +7800,4599 @@ return /******/ (function(modules) { // webpackBootstrap return false; }; - UPCEReader.prototype._convertToUPCA = function (result) { - var upca = [result[0]], - lastDigit = result[result.length - 2]; + 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 /* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].prototype._checksum.call(this, this._convertToUPCA(result)); + }; + + UPCEReader.prototype._findEnd = function (offset, isWhite) { + isWhite = true; + return /* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].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; + } + } + }; + + /* harmony default export */ exports["a"] = UPCEReader; + +/***/ }, +/* 72 */ +/***/ function(module, exports, __webpack_require__) { + + /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__ean_reader__ = __webpack_require__(10); + + + function UPCReader() { + /* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].call(this); + } + + var properties = { + FORMAT: { value: "upc_a", writeable: false } + }; + + UPCReader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].prototype, properties); + UPCReader.prototype.constructor = UPCReader; + + UPCReader.prototype._decode = function () { + var result = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].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; + }; + + /* harmony default export */ exports["a"] = UPCReader; + +/***/ }, +/* 73 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = 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 + } + + +/***/ }, +/* 74 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = 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 + } + + +/***/ }, +/* 75 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = 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 + } + + +/***/ }, +/* 76 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = 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 + } + +/***/ }, +/* 77 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = 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 + } + +/***/ }, +/* 78 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = 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 + } + +/***/ }, +/* 79 */ +/***/ function(module, exports, __webpack_require__) { + + var nativeCreate = __webpack_require__(14); + + /** Used for built-in method references. */ + var objectProto = Object.prototype; + + /** + * Creates an hash object. + * + * @private + * @constructor + * @returns {Object} Returns the new hash object. + */ + function Hash() {} + + // Avoid inheriting from `Object.prototype` when possible. + Hash.prototype = nativeCreate ? nativeCreate(null) : objectProto; + + module.e = Hash; + + +/***/ }, +/* 80 */ +/***/ function(module, exports, __webpack_require__) { + + var mapClear = __webpack_require__(126), + mapDelete = __webpack_require__(127), + mapGet = __webpack_require__(128), + mapHas = __webpack_require__(129), + mapSet = __webpack_require__(130); + + /** + * Creates a map cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [values] The values to cache. + */ + function MapCache(values) { + var index = -1, + length = values ? values.length : 0; - 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]); - } + this.clear(); + while (++index < length) { + var entry = values[index]; + this.set(entry[0], entry[1]); + } + } - upca.push(result[result.length - 1]); - return upca; - }; + // Add functions to the `MapCache`. + MapCache.prototype.clear = mapClear; + MapCache.prototype['delete'] = mapDelete; + MapCache.prototype.get = mapGet; + MapCache.prototype.has = mapHas; + MapCache.prototype.set = mapSet; - UPCEReader.prototype._checksum = function (result) { - return _ean_reader2["default"].prototype._checksum.call(this, this._convertToUPCA(result)); - }; + module.e = MapCache; + + +/***/ }, +/* 81 */ +/***/ function(module, exports, __webpack_require__) { + + var root = __webpack_require__(1); - UPCEReader.prototype._findEnd = function (offset, isWhite) { - isWhite = true; - return _ean_reader2["default"].prototype._findEnd.call(this, offset, isWhite); - }; + /** Built-in value references. */ + var Reflect = root.Reflect; - UPCEReader.prototype._verifyTrailingWhitespace = function (endInfo) { - var self = this, - trailingWhitespaceEnd; + module.e = Reflect; + + +/***/ }, +/* 82 */ +/***/ function(module, exports, __webpack_require__) { + + var getNative = __webpack_require__(12), + root = __webpack_require__(1); - trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; - if (trailingWhitespaceEnd < self._row.length) { - if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { - return endInfo; - } - } - }; + /* Built-in method references that are verified to be native. */ + var Set = getNative(root, 'Set'); - exports["default"] = UPCEReader; - module.exports = exports["default"]; + module.e = Set; + /***/ }, -/* 34 */ +/* 83 */ /***/ function(module, exports, __webpack_require__) { - 'use strict'; + var root = __webpack_require__(1); - Object.defineProperty(exports, '__esModule', { - value: true - }); + /** Built-in value references. */ + var Symbol = root.Symbol; - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + module.e = Symbol; + + +/***/ }, +/* 84 */ +/***/ function(module, exports, __webpack_require__) { + + var root = __webpack_require__(1); - var _barcode_reader = __webpack_require__(26); + /** Built-in value references. */ + var Uint8Array = root.Uint8Array; - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); + module.e = Uint8Array; + + +/***/ }, +/* 85 */ +/***/ function(module, exports, __webpack_require__) { + + var getNative = __webpack_require__(12), + root = __webpack_require__(1); - var merge = __webpack_require__(35); + /* Built-in method references that are verified to be native. */ + var WeakMap = getNative(root, 'WeakMap'); - function I2of5Reader(opts) { - opts = merge(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; - } + module.e = WeakMap; + + +/***/ }, +/* 86 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Adds the key-value `pair` to `map`. + * + * @private + * @param {Object} map The map to modify. + * @param {Array} pair The key-value pair to add. + * @returns {Object} Returns `map`. + */ + function addMapEntry(map, pair) { + // Don't return `Map#set` because it doesn't return the map instance in IE 11. + map.set(pair[0], pair[1]); + return map; } - function getDefaulConfig() { - var config = {}; + module.e = addMapEntry; + + +/***/ }, +/* 87 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Adds `value` to `set`. + * + * @private + * @param {Object} set The set to modify. + * @param {*} value The value to add. + * @returns {Object} Returns `set`. + */ + function addSetEntry(set, value) { + set.add(value); + return set; + } - Object.keys(I2of5Reader.CONFIG_KEYS).forEach(function (key) { - config[key] = I2of5Reader.CONFIG_KEYS[key]['default']; - }); - return config; + module.e = addSetEntry; + + +/***/ }, +/* 88 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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 {...*} args The arguments to invoke `func` with. + * @returns {*} Returns the result of `func`. + */ + function apply(func, thisArg, args) { + var length = args.length; + switch (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); } - var N = 1, - W = 3, - properties = { - MODULO: { value: 10 }, - START_PATTERN: { value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5] }, - STOP_PATTERN: { value: [N * 2, N * 2, W * 2] }, - 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" } - }; + module.e = apply; + + +/***/ }, +/* 89 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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; - I2of5Reader.prototype = Object.create(_barcode_reader2['default'].prototype, properties); - I2of5Reader.prototype.constructor = I2of5Reader; + while (++index < length) { + array[offset + index] = values[index]; + } + return array; + } - 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; + module.e = arrayPush; + + +/***/ }, +/* 90 */ +/***/ function(module, exports, __webpack_require__) { + + var copyObject = __webpack_require__(20), + keys = __webpack_require__(45); - 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]; + /** + * The base implementation of `_.assign` without support for multiple sources + * or `customizer` functions. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @returns {Object} Returns `object`. + */ + function baseAssign(object, source) { + return object && copyObject(source, keys(source), object); + } - 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); - }; + module.e = baseAssign; + + +/***/ }, +/* 91 */ +/***/ function(module, exports, __webpack_require__) { + + var Stack = __webpack_require__(32), + arrayEach = __webpack_require__(33), + assignValue = __webpack_require__(35), + baseAssign = __webpack_require__(90), + baseForOwn = __webpack_require__(95), + cloneBuffer = __webpack_require__(105), + copyArray = __webpack_require__(41), + copySymbols = __webpack_require__(112), + getTag = __webpack_require__(117), + initCloneArray = __webpack_require__(121), + initCloneByTag = __webpack_require__(122), + initCloneObject = __webpack_require__(123), + isArray = __webpack_require__(4), + isBuffer = __webpack_require__(139), + isHostObject = __webpack_require__(21), + isObject = __webpack_require__(2); - 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; + /** `Object#toString` result references. */ + var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + mapTag = '[object Map]', + numberTag = '[object Number]', + objectTag = '[object Object]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]', + weakMapTag = '[object WeakMap]'; - isWhite = isWhite || false; - tryHarder = tryHarder || false; + var arrayBufferTag = '[object ArrayBuffer]', + 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]'; - if (!offset) { - offset = self._nextSet(self._row); + /** Used to identify `toStringTag` values supported by `_.clone`. */ + var cloneableTags = {}; + cloneableTags[argsTag] = cloneableTags[arrayTag] = + cloneableTags[arrayBufferTag] = cloneableTags[boolTag] = + cloneableTags[dateTag] = cloneableTags[float32Tag] = + cloneableTags[float64Tag] = cloneableTags[int8Tag] = + cloneableTags[int16Tag] = cloneableTags[int32Tag] = + cloneableTags[mapTag] = cloneableTags[numberTag] = + cloneableTags[objectTag] = cloneableTags[regexpTag] = + cloneableTags[setTag] = cloneableTags[stringTag] = + cloneableTags[symbolTag] = cloneableTags[uint8Tag] = + cloneableTags[uint8ClampedTag] = cloneableTags[uint16Tag] = + cloneableTags[uint32Tag] = true; + cloneableTags[errorTag] = cloneableTags[funcTag] = + cloneableTags[weakMapTag] = false; + + /** + * The base implementation of `_.clone` and `_.cloneDeep` which tracks + * traversed objects. + * + * @private + * @param {*} value The value to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @param {boolean} [isFull] Specify a clone including symbols. + * @param {Function} [customizer] The function to customize cloning. + * @param {string} [key] The key of `value`. + * @param {Object} [object] The parent object of `value`. + * @param {Object} [stack] Tracks traversed objects and their clone counterparts. + * @returns {*} Returns the cloned value. + */ + function baseClone(value, isDeep, isFull, customizer, key, object, stack) { + var result; + if (customizer) { + result = object ? customizer(value, key, object, stack) : customizer(value); + } + if (result !== undefined) { + return result; + } + if (!isObject(value)) { + return value; + } + var isArr = isArray(value); + if (isArr) { + result = initCloneArray(value); + if (!isDeep) { + return copyArray(value, result); + } + } else { + var tag = getTag(value), + isFunc = tag == funcTag || tag == genTag; + + if (isBuffer(value)) { + return cloneBuffer(value, isDeep); + } + if (tag == objectTag || tag == argsTag || (isFunc && !object)) { + if (isHostObject(value)) { + return object ? value : {}; + } + result = initCloneObject(isFunc ? {} : value); + if (!isDeep) { + result = baseAssign(result, value); + return isFull ? copySymbols(value, result) : result; + } + } else { + if (!cloneableTags[tag]) { + return object ? value : {}; + } + result = initCloneByTag(value, tag, isDeep); } + } + // Check for circular references and return its corresponding clone. + stack || (stack = new Stack); + var stacked = stack.get(value); + if (stacked) { + return stacked; + } + stack.set(value, result); + + // Recursively populate clone (susceptible to call stack limits). + (isArr ? arrayEach : baseForOwn)(value, function(subValue, key) { + assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack)); + }); + return (isFull && !isArr) ? copySymbols(value, result) : result; + } + + module.e = baseClone; + + +/***/ }, +/* 92 */ +/***/ function(module, exports, __webpack_require__) { + + var isObject = __webpack_require__(2); + + /** 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} prototype The object to inherit from. + * @returns {Object} Returns the new object. + */ + function baseCreate(proto) { + return isObject(proto) ? objectCreate(proto) : {}; + } + + module.e = baseCreate; + + +/***/ }, +/* 93 */ +/***/ function(module, exports, __webpack_require__) { + + var arrayPush = __webpack_require__(89), + isArguments = __webpack_require__(24), + isArray = __webpack_require__(4), + isArrayLikeObject = __webpack_require__(26); + + /** + * 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} [isStrict] Restrict flattening to arrays-like objects. + * @param {Array} [result=[]] The initial result value. + * @returns {Array} Returns the new flattened array. + */ + function baseFlatten(array, depth, isStrict, result) { + result || (result = []); + + var index = -1, + length = array.length; - for (i = 0; i < pattern.length; i++) { - counter[i] = 0; + while (++index < length) { + var value = array[index]; + if (depth > 0 && isArrayLikeObject(value) && + (isStrict || isArray(value) || isArguments(value))) { + if (depth > 1) { + // Recursively flatten arrays (susceptible to call stack limits). + baseFlatten(value, depth - 1, isStrict, result); + } else { + arrayPush(result, value); + } + } else if (!isStrict) { + result[result.length] = value; } + } + return result; + } - 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]; - } - normalized = self._normalize(counter); - if (normalized) { - error = self._matchPattern(normalized, pattern); + module.e = baseFlatten; + + +/***/ }, +/* 94 */ +/***/ function(module, exports, __webpack_require__) { + + var createBaseFor = __webpack_require__(114); - 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; - }; + /** + * The base implementation of `baseForIn` and `baseForOwn` which iterates + * over `object` properties returned by `keysFunc` invoking `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(); - I2of5Reader.prototype._findStart = function () { - var self = this, - leadingWhitespaceStart, - offset = self._nextSet(self._row), - startInfo, - narrowBarWidth = 1; + module.e = baseFor; + + +/***/ }, +/* 95 */ +/***/ function(module, exports, __webpack_require__) { + + var baseFor = __webpack_require__(94), + keys = __webpack_require__(45); - 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; - } - }; + /** + * The base implementation of `_.forOwn` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ + function baseForOwn(object, iteratee) { + return object && baseFor(object, iteratee, keys); + } - I2of5Reader.prototype._verifyTrailingWhitespace = function (endInfo) { - var self = this, - trailingWhitespaceEnd; + module.e = baseForOwn; + + +/***/ }, +/* 96 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used for built-in method references. */ + var objectProto = Object.prototype; - trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; - if (trailingWhitespaceEnd < self._row.length) { - if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { - return endInfo; - } - } - return null; - }; + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; - I2of5Reader.prototype._findEnd = function () { - var self = this, - endInfo, - tmp; + /** Built-in value references. */ + var getPrototypeOf = Object.getPrototypeOf; - self._row.reverse(); - endInfo = self._findPattern(self.STOP_PATTERN); - self._row.reverse(); + /** + * The base implementation of `_.has` 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 baseHas(object, key) { + // Avoid a bug in IE 10-11 where objects with a [[Prototype]] of `null`, + // that are composed entirely of index properties, return `false` for + // `hasOwnProperty` checks of them. + return hasOwnProperty.call(object, key) || + (typeof object == 'object' && key in object && getPrototypeOf(object) === null); + } - if (endInfo === null) { - return null; - } + module.e = baseHas; + + +/***/ }, +/* 97 */ +/***/ function(module, exports, __webpack_require__) { + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeKeys = Object.keys; - // reverse numbers - tmp = endInfo.start; - endInfo.start = self._row.length - endInfo.end; - endInfo.end = self._row.length - tmp; + /** + * The base implementation of `_.keys` which doesn't skip the constructor + * property of prototypes or treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeys(object) { + return nativeKeys(Object(object)); + } - return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null; - }; + module.e = baseKeys; + + +/***/ }, +/* 98 */ +/***/ function(module, exports, __webpack_require__) { + + var Reflect = __webpack_require__(81), + iteratorToArray = __webpack_require__(125); - I2of5Reader.prototype._decodePair = function (counterPair) { - var i, - code, - codes = [], - self = this; + /** Used for built-in method references. */ + var objectProto = Object.prototype; - for (i = 0; i < counterPair.length; i++) { - code = self._decodeCode(counterPair[i]); - if (!code) { - return null; - } - codes.push(code); - } - return codes; - }; + /** Built-in value references. */ + var enumerate = Reflect ? Reflect.enumerate : undefined, + propertyIsEnumerable = objectProto.propertyIsEnumerable; - 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 - }; + /** + * The base implementation of `_.keysIn` which doesn't skip the constructor + * property of prototypes or treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeysIn(object) { + object = object == null ? object : Object(object); - for (j = 0; j < counter.length; j++) { - sum += counter[j]; - } - normalized = self._normalize(counter); - if (normalized) { - for (code = 0; code < self.CODE_PATTERN.length; code++) { - error = self._matchPattern(normalized, self.CODE_PATTERN[code]); - if (error < bestMatch.error) { - bestMatch.code = code; - bestMatch.error = error; - } - } - if (bestMatch.error < epsilon) { - return bestMatch; - } - } - return null; - }; + var result = []; + for (var key in object) { + result.push(key); + } + return result; + } - 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; + // Fallback for IE < 9 with es6-shim. + if (enumerate && !propertyIsEnumerable.call({ 'valueOf': 1 }, 'valueOf')) { + baseKeysIn = function(object) { + return iteratorToArray(enumerate(object)); + }; + } - 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]); - } + module.e = baseKeysIn; + + +/***/ }, +/* 99 */ +/***/ function(module, exports, __webpack_require__) { + + var Stack = __webpack_require__(32), + arrayEach = __webpack_require__(33), + assignMergeValue = __webpack_require__(34), + baseMergeDeep = __webpack_require__(100), + isArray = __webpack_require__(4), + isObject = __webpack_require__(2), + isTypedArray = __webpack_require__(44), + keysIn = __webpack_require__(46); + + /** + * 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; + } + var props = (isArray(source) || isTypedArray(source)) + ? undefined + : keysIn(source); + + arrayEach(props || source, function(srcValue, key) { + if (props) { + key = srcValue; + srcValue = source[key]; + } + if (isObject(srcValue)) { + stack || (stack = new Stack); + baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack); } - return codes; - }; + else { + var newValue = customizer + ? customizer(object[key], srcValue, (key + ''), object, source, stack) + : undefined; - I2of5Reader.prototype._verifyCounterLength = function (counters) { - return counters.length % 10 === 0; - }; + if (newValue === undefined) { + newValue = srcValue; + } + assignMergeValue(object, key, newValue); + } + }); + } - I2of5Reader.prototype._decode = function () { - var startInfo, - endInfo, - self = this, - code, - result = [], - decodedCodes = [], - counters; + module.e = baseMerge; + + +/***/ }, +/* 100 */ +/***/ function(module, exports, __webpack_require__) { + + var assignMergeValue = __webpack_require__(34), + baseClone = __webpack_require__(91), + copyArray = __webpack_require__(41), + isArguments = __webpack_require__(24), + isArray = __webpack_require__(4), + isArrayLikeObject = __webpack_require__(26), + isFunction = __webpack_require__(16), + isObject = __webpack_require__(2), + isPlainObject = __webpack_require__(141), + isTypedArray = __webpack_require__(44), + toPlainObject = __webpack_require__(146); - startInfo = self._findStart(); - if (!startInfo) { - return null; - } - decodedCodes.push(startInfo); + /** + * 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 = object[key], + srcValue = source[key], + stacked = stack.get(srcValue); - endInfo = self._findEnd(); - if (!endInfo) { - return null; - } + if (stacked) { + assignMergeValue(object, key, stacked); + return; + } + var newValue = customizer + ? customizer(objValue, srcValue, (key + ''), object, source, stack) + : undefined; - counters = self._fillCounters(startInfo.end, endInfo.start, false); - if (!self._verifyCounterLength(counters)) { - return null; + var isCommon = newValue === undefined; + + if (isCommon) { + newValue = srcValue; + if (isArray(srcValue) || isTypedArray(srcValue)) { + if (isArray(objValue)) { + newValue = objValue; + } + else if (isArrayLikeObject(objValue)) { + newValue = copyArray(objValue); + } + else { + isCommon = false; + newValue = baseClone(srcValue, !customizer); + } } - code = self._decodePayload(counters, result, decodedCodes); - if (!code) { - return null; + else if (isPlainObject(srcValue) || isArguments(srcValue)) { + if (isArguments(objValue)) { + newValue = toPlainObject(objValue); + } + else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) { + isCommon = false; + newValue = baseClone(srcValue, !customizer); + } + else { + newValue = objValue; + } } - if (result.length % 2 !== 0 || result.length < 6) { - return null; + else { + isCommon = false; } + } + stack.set(srcValue, newValue); - decodedCodes.push(endInfo); - return { - code: result.join(""), - start: startInfo.start, - end: endInfo.end, - startInfo: startInfo, - decodedCodes: decodedCodes - }; - }; + if (isCommon) { + // Recursively merge objects and arrays (susceptible to call stack limits). + mergeFunc(newValue, srcValue, srcIndex, customizer, stack); + } + stack['delete'](srcValue); + assignMergeValue(object, key, newValue); + } - I2of5Reader.CONFIG_KEYS = { - normalizeBarSpaceWidth: { - 'type': 'boolean', - 'default': false, - 'description': 'If true, the reader tries to normalize the' + 'width-difference between bars and spaces' + module.e = baseMergeDeep; + + +/***/ }, +/* 101 */ +/***/ function(module, exports, __webpack_require__) { + + var arrayReduce = __webpack_require__(19); + + /** + * The base implementation of `_.pick` without support for individual + * property names. + * + * @private + * @param {Object} object The source object. + * @param {string[]} props The property names to pick. + * @returns {Object} Returns the new object. + */ + function basePick(object, props) { + object = Object(object); + return arrayReduce(props, function(result, key) { + if (key in object) { + result[key] = object[key]; } - }; + return result; + }, {}); + } - exports['default'] = I2of5Reader; - module.exports = exports['default']; + module.e = basePick; + /***/ }, -/* 35 */ +/* 102 */ /***/ function(module, exports, __webpack_require__) { - var baseMerge = __webpack_require__(36), - createAssigner = __webpack_require__(63); + /** + * The base implementation of `_.property` without support for deep paths. + * + * @private + * @param {string} key The key of the property to get. + * @returns {Function} Returns the new function. + */ + function baseProperty(key) { + return function(object) { + return object == null ? undefined : object[key]; + }; + } + module.e = baseProperty; + + +/***/ }, +/* 103 */ +/***/ function(module, exports, __webpack_require__) { + /** - * Recursively merges own enumerable properties of the source object(s), that - * don't resolve to `undefined` into the destination object. Subsequent sources - * overwrite property assignments of previous sources. If `customizer` is - * provided it's invoked to produce the merged values of the destination and - * source properties. If `customizer` returns `undefined` merging is handled - * by the method instead. The `customizer` is bound to `thisArg` and invoked - * with five arguments: (objectValue, sourceValue, key, object, source). + * The base implementation of `_.times` without support for iteratee shorthands + * or max array length checks. * - * @static - * @memberOf _ - * @category Object - * @param {Object} object The destination object. - * @param {...Object} [sources] The source objects. - * @param {Function} [customizer] The function to customize assigned values. - * @param {*} [thisArg] The `this` binding of `customizer`. - * @returns {Object} Returns `object`. - * @example + * @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.e = baseTimes; + + +/***/ }, +/* 104 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Checks if `value` is a global object. * - * var users = { - * 'data': [{ 'user': 'barney' }, { 'user': 'fred' }] - * }; + * @private + * @param {*} value The value to check. + * @returns {null|Object} Returns `value` if it's a global object, else `null`. + */ + function checkGlobal(value) { + return (value && value.Object === Object) ? value : null; + } + + module.e = checkGlobal; + + +/***/ }, +/* 105 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Creates a clone of `buffer`. * - * var ages = { - * 'data': [{ 'age': 36 }, { 'age': 40 }] - * }; + * @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 result = new buffer.constructor(buffer.length); + buffer.copy(result); + return result; + } + + module.e = cloneBuffer; + + +/***/ }, +/* 106 */ +/***/ function(module, exports, __webpack_require__) { + + var addMapEntry = __webpack_require__(86), + arrayReduce = __webpack_require__(19), + mapToArray = __webpack_require__(131); + + /** + * Creates a clone of `map`. * - * _.merge(users, ages); - * // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] } + * @private + * @param {Object} map The map to clone. + * @returns {Object} Returns the cloned map. + */ + function cloneMap(map) { + return arrayReduce(mapToArray(map), addMapEntry, new map.constructor); + } + + module.e = cloneMap; + + +/***/ }, +/* 107 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used to match `RegExp` flags from their coerced string values. */ + var reFlags = /\w*$/; + + /** + * Creates a clone of `regexp`. * - * // using a customizer callback - * var object = { - * 'fruits': ['apple'], - * 'vegetables': ['beet'] - * }; + * @private + * @param {Object} regexp The regexp to clone. + * @returns {Object} Returns the cloned regexp. + */ + function cloneRegExp(regexp) { + var result = new regexp.constructor(regexp.source, reFlags.exec(regexp)); + result.lastIndex = regexp.lastIndex; + return result; + } + + module.e = cloneRegExp; + + +/***/ }, +/* 108 */ +/***/ function(module, exports, __webpack_require__) { + + var addSetEntry = __webpack_require__(87), + arrayReduce = __webpack_require__(19), + setToArray = __webpack_require__(132); + + /** + * Creates a clone of `set`. * - * var other = { - * 'fruits': ['banana'], - * 'vegetables': ['carrot'] - * }; + * @private + * @param {Object} set The set to clone. + * @returns {Object} Returns the cloned set. + */ + function cloneSet(set) { + return arrayReduce(setToArray(set), addSetEntry, new set.constructor); + } + + module.e = cloneSet; + + +/***/ }, +/* 109 */ +/***/ function(module, exports, __webpack_require__) { + + var Symbol = __webpack_require__(83); + + /** Used to convert symbols to primitives and strings. */ + var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolValueOf = symbolProto ? symbolProto.valueOf : undefined; + + /** + * Creates a clone of the `symbol` object. + * + * @private + * @param {Object} symbol The symbol object to clone. + * @returns {Object} Returns the cloned symbol object. + */ + function cloneSymbol(symbol) { + return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {}; + } + + module.e = cloneSymbol; + + +/***/ }, +/* 110 */ +/***/ function(module, exports, __webpack_require__) { + + var cloneArrayBuffer = __webpack_require__(40); + + /** + * 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.e = cloneTypedArray; + + +/***/ }, +/* 111 */ +/***/ function(module, exports, __webpack_require__) { + + var assignValue = __webpack_require__(35); + + /** + * This function is like `copyObject` except that it accepts a function to + * customize copied values. + * + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property names 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 copyObjectWith(source, props, object, customizer) { + 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) + : source[key]; + + assignValue(object, key, newValue); + } + return object; + } + + module.e = copyObjectWith; + + +/***/ }, +/* 112 */ +/***/ function(module, exports, __webpack_require__) { + + var copyObject = __webpack_require__(20), + getSymbols = __webpack_require__(116); + + /** + * Copies own symbol properties of `source` to `object`. * - * _.merge(object, other, function(a, b) { - * if (_.isArray(a)) { - * return a.concat(b); - * } - * }); - * // => { 'fruits': ['apple', 'banana'], 'vegetables': ['beet', 'carrot'] } + * @private + * @param {Object} source The object to copy symbols from. + * @param {Object} [object={}] The object to copy symbols to. + * @returns {Object} Returns `object`. */ - var merge = createAssigner(baseMerge); + function copySymbols(source, object) { + return copyObject(source, getSymbols(source), object); + } - module.exports = merge; + module.e = copySymbols; /***/ }, -/* 36 */ +/* 113 */ /***/ function(module, exports, __webpack_require__) { - var arrayEach = __webpack_require__(37), - baseMergeDeep = __webpack_require__(38), - isArray = __webpack_require__(46), - isArrayLike = __webpack_require__(41), - isObject = __webpack_require__(50), - isObjectLike = __webpack_require__(45), - isTypedArray = __webpack_require__(58), - keys = __webpack_require__(61); + var isIterateeCall = __webpack_require__(124), + rest = __webpack_require__(47); /** - * The base implementation of `_.merge` without support for argument juggling, - * multiple sources, and `this` binding `customizer` functions. + * Creates a function like `_.assign`. * * @private - * @param {Object} object The destination object. - * @param {Object} source The source object. - * @param {Function} [customizer] The function to customize merged values. - * @param {Array} [stackA=[]] Tracks traversed source objects. - * @param {Array} [stackB=[]] Associates values with source counterparts. - * @returns {Object} Returns `object`. + * @param {Function} assigner The function to assign values. + * @returns {Function} Returns the new assigner function. */ - function baseMerge(object, source, customizer, stackA, stackB) { - if (!isObject(object)) { - return object; - } - var isSrcArr = isArrayLike(source) && (isArray(source) || isTypedArray(source)), - props = isSrcArr ? undefined : keys(source); + function createAssigner(assigner) { + return rest(function(object, sources) { + var index = -1, + length = sources.length, + customizer = length > 1 ? sources[length - 1] : undefined, + guard = length > 2 ? sources[2] : undefined; - arrayEach(props || source, function(srcValue, key) { - if (props) { - key = srcValue; - srcValue = source[key]; - } - if (isObjectLike(srcValue)) { - stackA || (stackA = []); - stackB || (stackB = []); - baseMergeDeep(object, source, key, baseMerge, customizer, stackA, stackB); - } - else { - var value = object[key], - result = customizer ? customizer(value, srcValue, key, object, source) : undefined, - isCommon = result === undefined; + customizer = typeof customizer == 'function' + ? (length--, customizer) + : undefined; - if (isCommon) { - result = srcValue; - } - if ((result !== undefined || (isSrcArr && !(key in object))) && - (isCommon || (result === result ? (result !== value) : (value === value)))) { - object[key] = result; + 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; }); - return object; } - module.exports = baseMerge; + module.e = createAssigner; /***/ }, -/* 37 */ -/***/ function(module, exports) { +/* 114 */ +/***/ function(module, exports, __webpack_require__) { /** - * A specialized version of `_.forEach` for arrays without support for callback - * shorthands and `this` binding. + * Creates a base function for methods like `_.forIn`. * * @private - * @param {Array} array The array to iterate over. - * @param {Function} iteratee The function invoked per iteration. - * @returns {Array} Returns `array`. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. */ - function arrayEach(array, iteratee) { - var index = -1, - length = array.length; + function createBaseFor(fromRight) { + return function(object, iteratee, keysFunc) { + var index = -1, + iterable = Object(object), + props = keysFunc(object), + length = props.length; - while (++index < length) { - if (iteratee(array[index], index, array) === false) { - break; + while (length--) { + var key = props[fromRight ? length : ++index]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } } - } - return array; + return object; + }; } - module.exports = arrayEach; + module.e = createBaseFor; /***/ }, -/* 38 */ +/* 115 */ /***/ function(module, exports, __webpack_require__) { - var arrayCopy = __webpack_require__(39), - isArguments = __webpack_require__(40), - isArray = __webpack_require__(46), - isArrayLike = __webpack_require__(41), - isPlainObject = __webpack_require__(51), - isTypedArray = __webpack_require__(58), - toPlainObject = __webpack_require__(59); + var baseProperty = __webpack_require__(102); /** - * 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. + * Gets the "length" property value of `object`. + * + * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) + * that affects Safari on at least iOS 8.1-8.3 ARM64. * * @private - * @param {Object} object The destination object. - * @param {Object} source The source object. - * @param {string} key The key of the value to merge. - * @param {Function} mergeFunc The function to merge values. - * @param {Function} [customizer] The function to customize merged values. - * @param {Array} [stackA=[]] Tracks traversed source objects. - * @param {Array} [stackB=[]] Associates values with source counterparts. - * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + * @param {Object} object The object to query. + * @returns {*} Returns the "length" value. */ - function baseMergeDeep(object, source, key, mergeFunc, customizer, stackA, stackB) { - var length = stackA.length, - srcValue = source[key]; - - while (length--) { - if (stackA[length] == srcValue) { - object[key] = stackB[length]; - return; - } - } - var value = object[key], - result = customizer ? customizer(value, srcValue, key, object, source) : undefined, - isCommon = result === undefined; - - if (isCommon) { - result = srcValue; - if (isArrayLike(srcValue) && (isArray(srcValue) || isTypedArray(srcValue))) { - result = isArray(value) - ? value - : (isArrayLike(value) ? arrayCopy(value) : []); - } - else if (isPlainObject(srcValue) || isArguments(srcValue)) { - result = isArguments(value) - ? toPlainObject(value) - : (isPlainObject(value) ? value : {}); - } - else { - isCommon = false; - } - } - // Add the source value to the stack of traversed objects and associate - // it with its merged value. - stackA.push(srcValue); - stackB.push(result); - - if (isCommon) { - // Recursively merge objects and arrays (susceptible to call stack limits). - object[key] = mergeFunc(result, srcValue, customizer, stackA, stackB); - } else if (result === result ? (result !== value) : (value === value)) { - object[key] = result; - } - } + var getLength = baseProperty('length'); - module.exports = baseMergeDeep; + module.e = getLength; /***/ }, -/* 39 */ -/***/ function(module, exports) { +/* 116 */ +/***/ function(module, exports, __webpack_require__) { + /** Built-in value references. */ + var getOwnPropertySymbols = Object.getOwnPropertySymbols; + /** - * Copies the values of `source` to `array`. + * Creates an array of the own symbol properties of `object`. * * @private - * @param {Array} source The array to copy values from. - * @param {Array} [array=[]] The array to copy values to. - * @returns {Array} Returns `array`. + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. */ - function arrayCopy(source, array) { - var index = -1, - length = source.length; - - array || (array = Array(length)); - while (++index < length) { - array[index] = source[index]; - } - return array; - } + var getSymbols = getOwnPropertySymbols || function() { + return []; + }; - module.exports = arrayCopy; + module.e = getSymbols; /***/ }, -/* 40 */ +/* 117 */ /***/ function(module, exports, __webpack_require__) { - var isArrayLike = __webpack_require__(41), - isObjectLike = __webpack_require__(45); + var Map = __webpack_require__(3), + Set = __webpack_require__(82), + WeakMap = __webpack_require__(85); - /** Used for native method references. */ - var objectProto = Object.prototype; + /** `Object#toString` result references. */ + var mapTag = '[object Map]', + objectTag = '[object Object]', + setTag = '[object Set]', + weakMapTag = '[object WeakMap]'; - /** Used to check objects for own properties. */ - var hasOwnProperty = objectProto.hasOwnProperty; + /** Used for built-in method references. */ + var objectProto = Object.prototype; - /** Native method references. */ - var propertyIsEnumerable = objectProto.propertyIsEnumerable; + /** Used to resolve the decompiled source of functions. */ + var funcToString = Function.prototype.toString; /** - * Checks if `value` is classified as an `arguments` object. - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. - * @example - * - * _.isArguments(function() { return arguments; }()); - * // => true - * - * _.isArguments([1, 2, 3]); - * // => false + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. */ - function isArguments(value) { - return isObjectLike(value) && isArrayLike(value) && - hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee'); - } + var objectToString = objectProto.toString; - module.exports = isArguments; - - -/***/ }, -/* 41 */ -/***/ function(module, exports, __webpack_require__) { - - var getLength = __webpack_require__(42), - isLength = __webpack_require__(44); + /** Used to detect maps, sets, and weakmaps. */ + var mapCtorString = Map ? funcToString.call(Map) : '', + setCtorString = Set ? funcToString.call(Set) : '', + weakMapCtorString = WeakMap ? funcToString.call(WeakMap) : ''; /** - * Checks if `value` is array-like. + * Gets the `toStringTag` of `value`. * * @private - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is array-like, else `false`. + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. */ - function isArrayLike(value) { - return value != null && isLength(getLength(value)); + function getTag(value) { + return objectToString.call(value); + } + + // Fallback for IE 11 providing `toStringTag` values for maps, sets, and weakmaps. + if ((Map && getTag(new Map) != mapTag) || + (Set && getTag(new Set) != setTag) || + (WeakMap && getTag(new WeakMap) != weakMapTag)) { + getTag = function(value) { + var result = objectToString.call(value), + Ctor = result == objectTag ? value.constructor : null, + ctorString = typeof Ctor == 'function' ? funcToString.call(Ctor) : ''; + + if (ctorString) { + switch (ctorString) { + case mapCtorString: return mapTag; + case setCtorString: return setTag; + case weakMapCtorString: return weakMapTag; + } + } + return result; + }; } - module.exports = isArrayLike; + module.e = getTag; /***/ }, -/* 42 */ +/* 118 */ /***/ function(module, exports, __webpack_require__) { - var baseProperty = __webpack_require__(43); + var hashHas = __webpack_require__(42); /** - * Gets the "length" property value of `object`. - * - * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) - * that affects Safari on at least iOS 8.1-8.3 ARM64. + * Removes `key` and its value from the hash. * * @private - * @param {Object} object The object to query. - * @returns {*} Returns the "length" value. + * @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`. */ - var getLength = baseProperty('length'); + function hashDelete(hash, key) { + return hashHas(hash, key) && delete hash[key]; + } - module.exports = getLength; + module.e = hashDelete; /***/ }, -/* 43 */ -/***/ function(module, exports) { +/* 119 */ +/***/ function(module, exports, __webpack_require__) { + var nativeCreate = __webpack_require__(14); + + /** 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; + /** - * The base implementation of `_.property` without support for deep paths. + * Gets the hash value for `key`. * * @private - * @param {string} key The key of the property to get. - * @returns {Function} Returns the new function. - */ - function baseProperty(key) { - return function(object) { - return object == null ? undefined : object[key]; - }; + * @param {Object} hash The hash to query. + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function hashGet(hash, key) { + if (nativeCreate) { + var result = hash[key]; + return result === HASH_UNDEFINED ? undefined : result; + } + return hasOwnProperty.call(hash, key) ? hash[key] : undefined; } - module.exports = baseProperty; + module.e = hashGet; /***/ }, -/* 44 */ -/***/ function(module, exports) { +/* 120 */ +/***/ function(module, exports, __webpack_require__) { - /** - * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) - * of an array-like value. - */ - var MAX_SAFE_INTEGER = 9007199254740991; + var nativeCreate = __webpack_require__(14); + + /** Used to stand-in for `undefined` hash values. */ + var HASH_UNDEFINED = '__lodash_hash_undefined__'; /** - * Checks if `value` is a valid array-like length. - * - * **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). + * Sets the hash `key` to `value`. * * @private - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. + * @param {Object} hash The hash to modify. + * @param {string} key The key of the value to set. + * @param {*} value The value to set. */ - function isLength(value) { - return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; + function hashSet(hash, key, value) { + hash[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value; } - module.exports = isLength; + module.e = hashSet; /***/ }, -/* 45 */ -/***/ function(module, exports) { +/* 121 */ +/***/ function(module, exports, __webpack_require__) { + /** Used for built-in method references. */ + var objectProto = Object.prototype; + + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; + /** - * Checks if `value` is object-like. + * Initializes an array clone. * * @private - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is object-like, else `false`. + * @param {Array} array The array to clone. + * @returns {Array} Returns the initialized clone. */ - function isObjectLike(value) { - return !!value && typeof value == 'object'; + function initCloneArray(array) { + var length = array.length, + result = array.constructor(length); + + // Add properties assigned by `RegExp#exec`. + if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) { + result.index = array.index; + result.input = array.input; + } + return result; } - module.exports = isObjectLike; + module.e = initCloneArray; /***/ }, -/* 46 */ +/* 122 */ /***/ function(module, exports, __webpack_require__) { - var getNative = __webpack_require__(47), - isLength = __webpack_require__(44), - isObjectLike = __webpack_require__(45); + var cloneArrayBuffer = __webpack_require__(40), + cloneMap = __webpack_require__(106), + cloneRegExp = __webpack_require__(107), + cloneSet = __webpack_require__(108), + cloneSymbol = __webpack_require__(109), + cloneTypedArray = __webpack_require__(110); /** `Object#toString` result references. */ - var arrayTag = '[object Array]'; - - /** Used for native method references. */ - var objectProto = Object.prototype; - - /** - * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) - * of values. - */ - var objToString = objectProto.toString; + var boolTag = '[object Boolean]', + dateTag = '[object Date]', + mapTag = '[object Map]', + numberTag = '[object Number]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]'; - /* Native method references for those with the same name as other `lodash` methods. */ - var nativeIsArray = getNative(Array, 'isArray'); + var arrayBufferTag = '[object ArrayBuffer]', + 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]'; /** - * Checks if `value` is classified as an `Array` object. - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. - * @example + * Initializes an object clone based on its `toStringTag`. * - * _.isArray([1, 2, 3]); - * // => true + * **Note:** This function only supports cloning values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. * - * _.isArray(function() { return arguments; }()); - * // => false + * @private + * @param {Object} object The object to clone. + * @param {string} tag The `toStringTag` of the object to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the initialized clone. */ - var isArray = nativeIsArray || function(value) { - return isObjectLike(value) && isLength(value.length) && objToString.call(value) == arrayTag; - }; + function initCloneByTag(object, tag, isDeep) { + var Ctor = object.constructor; + switch (tag) { + case arrayBufferTag: + return cloneArrayBuffer(object); + + case boolTag: + case dateTag: + return new Ctor(+object); + + case float32Tag: case float64Tag: + case int8Tag: case int16Tag: case int32Tag: + case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag: + return cloneTypedArray(object, isDeep); + + case mapTag: + return cloneMap(object); + + case numberTag: + case stringTag: + return new Ctor(object); + + case regexpTag: + return cloneRegExp(object); - module.exports = isArray; + case setTag: + return cloneSet(object); + + case symbolTag: + return cloneSymbol(object); + } + } + + module.e = initCloneByTag; /***/ }, -/* 47 */ +/* 123 */ /***/ function(module, exports, __webpack_require__) { - var isNative = __webpack_require__(48); + var baseCreate = __webpack_require__(92), + isPrototype = __webpack_require__(23); + + /** Built-in value references. */ + var getPrototypeOf = Object.getPrototypeOf; /** - * Gets the native function at `key` of `object`. + * Initializes an object clone. * * @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`. + * @param {Object} object The object to clone. + * @returns {Object} Returns the initialized clone. */ - function getNative(object, key) { - var value = object == null ? undefined : object[key]; - return isNative(value) ? value : undefined; + function initCloneObject(object) { + return (typeof object.constructor == 'function' && !isPrototype(object)) + ? baseCreate(getPrototypeOf(object)) + : {}; } - module.exports = getNative; + module.e = initCloneObject; /***/ }, -/* 48 */ +/* 124 */ /***/ function(module, exports, __webpack_require__) { - var isFunction = __webpack_require__(49), - isObjectLike = __webpack_require__(45); - - /** Used to detect host constructors (Safari > 5). */ - var reIsHostCtor = /^\[object .+?Constructor\]$/; - - /** Used for native method references. */ - var objectProto = Object.prototype; - - /** Used to resolve the decompiled source of functions. */ - var fnToString = Function.prototype.toString; - - /** Used to check objects for own properties. */ - var hasOwnProperty = objectProto.hasOwnProperty; - - /** Used to detect if a method is native. */ - var reIsNative = RegExp('^' + - fnToString.call(hasOwnProperty).replace(/[\\^$.*+?()[\]{}|]/g, '\\$&') - .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' - ); + var eq = __webpack_require__(15), + isArrayLike = __webpack_require__(25), + isIndex = __webpack_require__(22), + isObject = __webpack_require__(2); /** - * Checks if `value` is a native function. - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is a native function, else `false`. - * @example + * Checks if the given arguments are from an iteratee call. * - * _.isNative(Array.prototype.push); - * // => true - * - * _.isNative(_); - * // => false + * @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 isNative(value) { - if (value == null) { + function isIterateeCall(value, index, object) { + if (!isObject(object)) { return false; } - if (isFunction(value)) { - return reIsNative.test(fnToString.call(value)); + var type = typeof index; + if (type == 'number' + ? (isArrayLike(object) && isIndex(index, object.length)) + : (type == 'string' && index in object)) { + return eq(object[index], value); } - return isObjectLike(value) && reIsHostCtor.test(value); + return false; } - module.exports = isNative; + module.e = isIterateeCall; /***/ }, -/* 49 */ +/* 125 */ /***/ function(module, exports, __webpack_require__) { - var isObject = __webpack_require__(50); - - /** `Object#toString` result references. */ - var funcTag = '[object Function]'; - - /** Used for native method references. */ - var objectProto = Object.prototype; - - /** - * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) - * of values. - */ - var objToString = objectProto.toString; - /** - * Checks if `value` is classified as a `Function` object. - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. - * @example - * - * _.isFunction(_); - * // => true + * Converts `iterator` to an array. * - * _.isFunction(/abc/); - * // => false + * @private + * @param {Object} iterator The iterator to convert. + * @returns {Array} Returns the converted array. */ - function isFunction(value) { - // The use of `Object#toString` avoids issues with the `typeof` operator - // in older versions of Chrome and Safari which return 'function' for regexes - // and Safari 8 which returns 'object' for typed array constructors. - return isObject(value) && objToString.call(value) == funcTag; + function iteratorToArray(iterator) { + var data, + result = []; + + while (!(data = iterator.next()).done) { + result.push(data.value); + } + return result; } - module.exports = isFunction; + module.e = iteratorToArray; /***/ }, -/* 50 */ -/***/ function(module, exports) { +/* 126 */ +/***/ function(module, exports, __webpack_require__) { + var Hash = __webpack_require__(79), + Map = __webpack_require__(3); + /** - * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. - * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) - * - * @static - * @memberOf _ - * @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 + * Removes all key-value entries from the map. * - * _.isObject(1); - * // => false - */ - function isObject(value) { - // Avoid a V8 JIT bug in Chrome 19-20. - // See https://code.google.com/p/v8/issues/detail?id=2291 for more details. - var type = typeof value; - return !!value && (type == 'object' || type == 'function'); + * @private + * @name clear + * @memberOf MapCache + */ + function mapClear() { + this.__data__ = { + 'hash': new Hash, + 'map': Map ? new Map : [], + 'string': new Hash + }; } - module.exports = isObject; + module.e = mapClear; /***/ }, -/* 51 */ +/* 127 */ /***/ function(module, exports, __webpack_require__) { - var baseForIn = __webpack_require__(52), - isArguments = __webpack_require__(40), - isObjectLike = __webpack_require__(45); - - /** `Object#toString` result references. */ - var objectTag = '[object Object]'; - - /** Used for native method references. */ - var objectProto = Object.prototype; - - /** Used to check objects for own properties. */ - var hasOwnProperty = objectProto.hasOwnProperty; + var Map = __webpack_require__(3), + assocDelete = __webpack_require__(36), + hashDelete = __webpack_require__(118), + isKeyable = __webpack_require__(13); /** - * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) - * of values. - */ - var objToString = objectProto.toString; + * 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 mapDelete(key) { + var data = this.__data__; + if (isKeyable(key)) { + return hashDelete(typeof key == 'string' ? data.string : data.hash, key); + } + return Map ? data.map['delete'](key) : assocDelete(data.map, key); + } + + module.e = mapDelete; + + +/***/ }, +/* 128 */ +/***/ function(module, exports, __webpack_require__) { + + var Map = __webpack_require__(3), + assocGet = __webpack_require__(37), + hashGet = __webpack_require__(119), + isKeyable = __webpack_require__(13); /** - * Checks if `value` is a plain object, that is, an object created by the - * `Object` constructor or one with a `[[Prototype]]` of `null`. - * - * **Note:** This method assumes objects created by the `Object` constructor - * have no inherited enumerable properties. - * - * @static - * @memberOf _ - * @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 + * Gets the map value for `key`. * - * _.isPlainObject([1, 2, 3]); - * // => false - * - * _.isPlainObject({ 'x': 0, 'y': 0 }); - * // => true - * - * _.isPlainObject(Object.create(null)); - * // => true - */ - function isPlainObject(value) { - var Ctor; - - // Exit early for non `Object` objects. - if (!(isObjectLike(value) && objToString.call(value) == objectTag && !isArguments(value)) || - (!hasOwnProperty.call(value, 'constructor') && (Ctor = value.constructor, typeof Ctor == 'function' && !(Ctor instanceof Ctor)))) { - return false; + * @private + * @name get + * @memberOf MapCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function mapGet(key) { + var data = this.__data__; + if (isKeyable(key)) { + return hashGet(typeof key == 'string' ? data.string : data.hash, key); } - // IE < 9 iterates inherited properties before own properties. If the first - // iterated property is an object's own property then there are no inherited - // enumerable properties. - var result; - // In most environments an object's own properties are iterated before - // its inherited properties. If the last iterated property is an object's - // own property then there are no inherited enumerable properties. - baseForIn(value, function(subValue, key) { - result = key; - }); - return result === undefined || hasOwnProperty.call(value, result); + return Map ? data.map.get(key) : assocGet(data.map, key); } - module.exports = isPlainObject; + module.e = mapGet; /***/ }, -/* 52 */ +/* 129 */ /***/ function(module, exports, __webpack_require__) { - var baseFor = __webpack_require__(53), - keysIn = __webpack_require__(56); + var Map = __webpack_require__(3), + assocHas = __webpack_require__(38), + hashHas = __webpack_require__(42), + isKeyable = __webpack_require__(13); /** - * The base implementation of `_.forIn` without support for callback - * shorthands and `this` binding. + * Checks if a map value for `key` exists. * * @private - * @param {Object} object The object to iterate over. - * @param {Function} iteratee The function invoked per iteration. - * @returns {Object} Returns `object`. - */ - function baseForIn(object, iteratee) { - return baseFor(object, iteratee, keysIn); + * @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 mapHas(key) { + var data = this.__data__; + if (isKeyable(key)) { + return hashHas(typeof key == 'string' ? data.string : data.hash, key); + } + return Map ? data.map.has(key) : assocHas(data.map, key); } - module.exports = baseForIn; + module.e = mapHas; /***/ }, -/* 53 */ +/* 130 */ /***/ function(module, exports, __webpack_require__) { - var createBaseFor = __webpack_require__(54); + var Map = __webpack_require__(3), + assocSet = __webpack_require__(39), + hashSet = __webpack_require__(120), + isKeyable = __webpack_require__(13); /** - * The base implementation of `baseForIn` and `baseForOwn` which iterates - * over `object` properties returned by `keysFunc` invoking `iteratee` for - * each property. Iteratee functions may exit iteration early by explicitly - * returning `false`. + * Sets the map `key` to `value`. * * @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(); + * @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 object. + */ + function mapSet(key, value) { + var data = this.__data__; + if (isKeyable(key)) { + hashSet(typeof key == 'string' ? data.string : data.hash, key, value); + } else if (Map) { + data.map.set(key, value); + } else { + assocSet(data.map, key, value); + } + return this; + } - module.exports = baseFor; + module.e = mapSet; /***/ }, -/* 54 */ +/* 131 */ /***/ function(module, exports, __webpack_require__) { - var toObject = __webpack_require__(55); - /** - * Creates a base function for `_.forIn` or `_.forInRight`. + * Converts `map` to an array. * * @private - * @param {boolean} [fromRight] Specify iterating from right to left. - * @returns {Function} Returns the new base function. + * @param {Object} map The map to convert. + * @returns {Array} Returns the converted array. */ - function createBaseFor(fromRight) { - return function(object, iteratee, keysFunc) { - var iterable = toObject(object), - props = keysFunc(object), - length = props.length, - index = fromRight ? length : -1; + function mapToArray(map) { + var index = -1, + result = Array(map.size); - while ((fromRight ? index-- : ++index < length)) { - var key = props[index]; - if (iteratee(iterable[key], key, iterable) === false) { - break; - } - } - return object; - }; + map.forEach(function(value, key) { + result[++index] = [key, value]; + }); + return result; } - module.exports = createBaseFor; + module.e = mapToArray; /***/ }, -/* 55 */ +/* 132 */ /***/ function(module, exports, __webpack_require__) { - var isObject = __webpack_require__(50); - /** - * Converts `value` to an object if it's not one. + * Converts `set` to an array. * * @private - * @param {*} value The value to process. - * @returns {Object} Returns the object. + * @param {Object} set The set to convert. + * @returns {Array} Returns the converted array. */ - function toObject(value) { - return isObject(value) ? value : Object(value); + function setToArray(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = value; + }); + return result; } - module.exports = toObject; + module.e = setToArray; /***/ }, -/* 56 */ +/* 133 */ /***/ function(module, exports, __webpack_require__) { - var isArguments = __webpack_require__(40), - isArray = __webpack_require__(46), - isIndex = __webpack_require__(57), - isLength = __webpack_require__(44), - isObject = __webpack_require__(50); - - /** Used for native method references. */ - var objectProto = Object.prototype; - - /** Used to check objects for own properties. */ - var hasOwnProperty = objectProto.hasOwnProperty; - /** - * Creates an array of the own and inherited enumerable property names of `object`. - * - * **Note:** Non-object values are coerced to objects. - * - * @static - * @memberOf _ - * @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; + * Removes all key-value entries from the stack. * - * _.keysIn(new Foo); - * // => ['a', 'b', 'c'] (iteration order is not guaranteed) + * @private + * @name clear + * @memberOf Stack */ - function keysIn(object) { - if (object == null) { - return []; - } - if (!isObject(object)) { - object = Object(object); - } - var length = object.length; - length = (length && isLength(length) && - (isArray(object) || isArguments(object)) && length) || 0; - - var Ctor = object.constructor, - index = -1, - isProto = typeof Ctor == 'function' && Ctor.prototype === object, - result = Array(length), - skipIndexes = length > 0; + function stackClear() { + this.__data__ = { 'array': [], 'map': null }; + } - while (++index < length) { - result[index] = (index + ''); - } - for (var key in object) { - if (!(skipIndexes && isIndex(key, length)) && - !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { - result.push(key); - } - } - return result; + module.e = stackClear; + + +/***/ }, +/* 134 */ +/***/ function(module, exports, __webpack_require__) { + + var assocDelete = __webpack_require__(36); + + /** + * 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__, + array = data.array; + + return array ? assocDelete(array, key) : data.map['delete'](key); } - module.exports = keysIn; + module.e = stackDelete; /***/ }, -/* 57 */ -/***/ function(module, exports) { +/* 135 */ +/***/ function(module, exports, __webpack_require__) { - /** Used to detect unsigned integer values. */ - var reIsUint = /^\d+$/; - - /** - * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) - * of an array-like value. - */ - var MAX_SAFE_INTEGER = 9007199254740991; + var assocGet = __webpack_require__(37); /** - * Checks if `value` is a valid array-like index. + * Gets the stack value for `key`. * * @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`. + * @name get + * @memberOf Stack + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. */ - function isIndex(value, length) { - value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1; - length = length == null ? MAX_SAFE_INTEGER : length; - return value > -1 && value % 1 == 0 && value < length; + function stackGet(key) { + var data = this.__data__, + array = data.array; + + return array ? assocGet(array, key) : data.map.get(key); } - module.exports = isIndex; + module.e = stackGet; /***/ }, -/* 58 */ +/* 136 */ /***/ function(module, exports, __webpack_require__) { - var isLength = __webpack_require__(44), - isObjectLike = __webpack_require__(45); + var assocHas = __webpack_require__(38); - /** `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]'; + /** + * 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) { + var data = this.__data__, + array = data.array; - var arrayBufferTag = '[object ArrayBuffer]', - 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]'; + return array ? assocHas(array, key) : data.map.has(key); + } - /** 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[dateTag] = typedArrayTags[errorTag] = - typedArrayTags[funcTag] = typedArrayTags[mapTag] = - typedArrayTags[numberTag] = typedArrayTags[objectTag] = - typedArrayTags[regexpTag] = typedArrayTags[setTag] = - typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false; + module.e = stackHas; + + +/***/ }, +/* 137 */ +/***/ function(module, exports, __webpack_require__) { + + var MapCache = __webpack_require__(80), + assocSet = __webpack_require__(39); - /** Used for native method references. */ - var objectProto = Object.prototype; + /** Used as the size to enable large array optimizations. */ + var LARGE_ARRAY_SIZE = 200; /** - * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) - * of values. - */ - var objToString = objectProto.toString; + * 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 object. + */ + function stackSet(key, value) { + var data = this.__data__, + array = data.array; + + if (array) { + if (array.length < (LARGE_ARRAY_SIZE - 1)) { + assocSet(array, key, value); + } else { + data.array = null; + data.map = new MapCache(array); + } + } + var map = data.map; + if (map) { + map.set(key, value); + } + return this; + } + module.e = stackSet; + + +/***/ }, +/* 138 */ +/***/ function(module, exports, __webpack_require__) { + /** - * Checks if `value` is classified as a typed array. + * Creates a function that returns `value`. * * @static * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @category Util + * @param {*} value The value to return from the new function. + * @returns {Function} Returns the new function. * @example * - * _.isTypedArray(new Uint8Array); - * // => true + * var object = { 'user': 'fred' }; + * var getter = _.constant(object); * - * _.isTypedArray([]); - * // => false + * getter() === object; + * // => true */ - function isTypedArray(value) { - return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objToString.call(value)]; + function constant(value) { + return function() { + return value; + }; } - module.exports = isTypedArray; + module.e = constant; /***/ }, -/* 59 */ +/* 139 */ /***/ function(module, exports, __webpack_require__) { - var baseCopy = __webpack_require__(60), - keysIn = __webpack_require__(56); + /* WEBPACK VAR INJECTION */(function(module) {var constant = __webpack_require__(138), + root = __webpack_require__(1); + + /** Used to determine if values are of the language type `Object`. */ + var objectTypes = { + 'function': true, + 'object': true + }; + + /** Detect free variable `exports`. */ + var freeExports = (objectTypes[typeof exports] && exports && !exports.nodeType) + ? exports + : undefined; + + /** Detect free variable `module`. */ + var freeModule = (objectTypes[typeof module] && module && !module.nodeType) + ? module + : undefined; + + /** Detect the popular CommonJS extension `module.exports`. */ + var moduleExports = (freeModule && freeModule.exports === freeExports) + ? freeExports + : undefined; + + /** Built-in value references. */ + var Buffer = moduleExports ? root.Buffer : undefined; /** - * Converts `value` to a plain object flattening inherited enumerable - * properties of `value` to own properties of the plain object. + * Checks if `value` is a buffer. * * @static * @memberOf _ * @category Lang - * @param {*} value The value to convert. - * @returns {Object} Returns the converted plain object. + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a buffer, else `false`. * @example * - * function Foo() { - * this.b = 2; - * } - * - * Foo.prototype.c = 3; - * - * _.assign({ 'a': 1 }, new Foo); - * // => { 'a': 1, 'b': 2 } + * _.isBuffer(new Buffer(2)); + * // => true * - * _.assign({ 'a': 1 }, _.toPlainObject(new Foo)); - * // => { 'a': 1, 'b': 2, 'c': 3 } + * _.isBuffer(new Uint8Array(2)); + * // => false */ - function toPlainObject(value) { - return baseCopy(value, keysIn(value)); - } + var isBuffer = !Buffer ? constant(false) : function(value) { + return value instanceof Buffer; + }; - module.exports = toPlainObject; - + module.e = isBuffer; + + /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(48)(module))) /***/ }, -/* 60 */ -/***/ function(module, exports) { +/* 140 */ +/***/ function(module, exports, __webpack_require__) { - /** - * Copies properties of `source` to `object`. - * - * @private - * @param {Object} source The object to copy properties from. - * @param {Array} props The property names to copy. - * @param {Object} [object={}] The object to copy properties to. - * @returns {Object} Returns `object`. - */ - function baseCopy(source, props, object) { - object || (object = {}); + var isFunction = __webpack_require__(16), + isHostObject = __webpack_require__(21), + isObjectLike = __webpack_require__(7); - var index = -1, - length = props.length; + /** Used to match `RegExp` [syntax characters](http://ecma-international.org/ecma-262/6.0/#sec-patterns). */ + var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; - while (++index < length) { - var key = props[index]; - object[key] = source[key]; - } - return object; - } + /** Used to detect host constructors (Safari > 5). */ + var reIsHostCtor = /^\[object .+?Constructor\]$/; - module.exports = baseCopy; - - -/***/ }, -/* 61 */ -/***/ function(module, exports, __webpack_require__) { - - var getNative = __webpack_require__(47), - isArrayLike = __webpack_require__(41), - isObject = __webpack_require__(50), - shimKeys = __webpack_require__(62); + /** Used for built-in method references. */ + var objectProto = Object.prototype; - /* Native method references for those with the same name as other `lodash` methods. */ - var nativeKeys = getNative(Object, 'keys'); + /** Used to resolve the decompiled source of functions. */ + var funcToString = Function.prototype.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.*?') + '$' + ); /** - * Creates an array of the own enumerable property names of `object`. - * - * **Note:** Non-object values are coerced to objects. See the - * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys) - * for more details. + * Checks if `value` is a native function. * * @static * @memberOf _ - * @category Object - * @param {Object} object The object to query. - * @returns {Array} Returns the array of property names. + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, else `false`. * @example * - * function Foo() { - * this.a = 1; - * this.b = 2; - * } - * - * Foo.prototype.c = 3; - * - * _.keys(new Foo); - * // => ['a', 'b'] (iteration order is not guaranteed) + * _.isNative(Array.prototype.push); + * // => true * - * _.keys('hi'); - * // => ['0', '1'] + * _.isNative(_); + * // => false */ - var keys = !nativeKeys ? shimKeys : function(object) { - var Ctor = object == null ? undefined : object.constructor; - if ((typeof Ctor == 'function' && Ctor.prototype === object) || - (typeof object != 'function' && isArrayLike(object))) { - return shimKeys(object); + function isNative(value) { + if (value == null) { + return false; } - return isObject(object) ? nativeKeys(object) : []; - }; + if (isFunction(value)) { + return reIsNative.test(funcToString.call(value)); + } + return isObjectLike(value) && + (isHostObject(value) ? reIsNative : reIsHostCtor).test(value); + } - module.exports = keys; + module.e = isNative; /***/ }, -/* 62 */ +/* 141 */ /***/ function(module, exports, __webpack_require__) { - var isArguments = __webpack_require__(40), - isArray = __webpack_require__(46), - isIndex = __webpack_require__(57), - isLength = __webpack_require__(44), - keysIn = __webpack_require__(56); + var isHostObject = __webpack_require__(21), + isObjectLike = __webpack_require__(7); - /** Used for native method references. */ + /** `Object#toString` result references. */ + var objectTag = '[object Object]'; + + /** 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 decompiled source of functions. */ + var funcToString = Function.prototype.toString; + + /** Used to infer the `Object` constructor. */ + var objectCtorString = funcToString.call(Object); /** - * A fallback implementation of `Object.keys` which creates an array of the - * own enumerable property names of `object`. - * - * @private - * @param {Object} object The object to query. - * @returns {Array} Returns the array of property names. + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. */ - function shimKeys(object) { - var props = keysIn(object), - propsLength = props.length, - length = propsLength && object.length; + var objectToString = objectProto.toString; - var allowIndexes = !!length && isLength(length) && - (isArray(object) || isArguments(object)); - - var index = -1, - result = []; + /** Built-in value references. */ + var getPrototypeOf = Object.getPrototypeOf; - while (++index < propsLength) { - var key = props[index]; - if ((allowIndexes && isIndex(key, length)) || hasOwnProperty.call(object, key)) { - result.push(key); - } + /** + * 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 _ + * @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) || + objectToString.call(value) != objectTag || isHostObject(value)) { + return false; + } + var proto = getPrototypeOf(value); + if (proto === null) { + return true; } - return result; + var Ctor = proto.constructor; + return (typeof Ctor == 'function' && + Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString); } - module.exports = shimKeys; + module.e = isPlainObject; /***/ }, -/* 63 */ +/* 142 */ /***/ function(module, exports, __webpack_require__) { - var bindCallback = __webpack_require__(64), - isIterateeCall = __webpack_require__(66), - restParam = __webpack_require__(67); + var isArray = __webpack_require__(4), + isObjectLike = __webpack_require__(7); + + /** `Object#toString` result references. */ + var stringTag = '[object String]'; + + /** Used for built-in method references. */ + var objectProto = Object.prototype; + + /** + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; /** - * Creates a `_.assign`, `_.defaults`, or `_.merge` function. + * Checks if `value` is classified as a `String` primitive or object. * - * @private - * @param {Function} assigner The function to assign values. - * @returns {Function} Returns the new assigner function. + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example + * + * _.isString('abc'); + * // => true + * + * _.isString(1); + * // => false */ - function createAssigner(assigner) { - return restParam(function(object, sources) { - var index = -1, - length = object == null ? 0 : sources.length, - customizer = length > 2 ? sources[length - 2] : undefined, - guard = length > 2 ? sources[2] : undefined, - thisArg = length > 1 ? sources[length - 1] : undefined; - - if (typeof customizer == 'function') { - customizer = bindCallback(customizer, thisArg, 5); - length -= 2; - } else { - customizer = typeof thisArg == 'function' ? thisArg : undefined; - length -= (customizer ? 1 : 0); - } - if (guard && isIterateeCall(sources[0], sources[1], guard)) { - customizer = length < 3 ? undefined : customizer; - length = 1; - } - while (++index < length) { - var source = sources[index]; - if (source) { - assigner(object, source, customizer); - } - } - return object; - }); + function isString(value) { + return typeof value == 'string' || + (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag); } - module.exports = createAssigner; + module.e = isString; /***/ }, -/* 64 */ +/* 143 */ /***/ function(module, exports, __webpack_require__) { - var identity = __webpack_require__(65); + var baseFlatten = __webpack_require__(93), + basePick = __webpack_require__(101), + rest = __webpack_require__(47); /** - * A specialized version of `baseCallback` which only supports `this` binding - * and specifying the number of arguments to provide to `func`. + * Creates an object composed of the picked `object` properties. * - * @private - * @param {Function} func The function to bind. - * @param {*} thisArg The `this` binding of `func`. - * @param {number} [argCount] The number of arguments to provide to `func`. - * @returns {Function} Returns the callback. + * @static + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [props] The property names to pick, specified + * individually or in arrays. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.pick(object, ['a', 'c']); + * // => { 'a': 1, 'c': 3 } */ - function bindCallback(func, thisArg, argCount) { - if (typeof func != 'function') { - return identity; - } - if (thisArg === undefined) { - return func; - } - switch (argCount) { - case 1: return function(value) { - return func.call(thisArg, value); - }; - case 3: return function(value, index, collection) { - return func.call(thisArg, value, index, collection); - }; - case 4: return function(accumulator, value, index, collection) { - return func.call(thisArg, accumulator, value, index, collection); - }; - case 5: return function(value, other, key, object, source) { - return func.call(thisArg, value, other, key, object, source); - }; - } - return function() { - return func.apply(thisArg, arguments); - }; - } + var pick = rest(function(object, props) { + return object == null ? {} : basePick(object, baseFlatten(props, 1)); + }); - module.exports = bindCallback; + module.e = pick; /***/ }, -/* 65 */ -/***/ function(module, exports) { +/* 144 */ +/***/ function(module, exports, __webpack_require__) { + var toNumber = __webpack_require__(145); + + /** Used as references for various `Number` constants. */ + var INFINITY = 1 / 0, + MAX_INTEGER = 1.7976931348623157e+308; + /** - * This method returns the first argument provided to it. + * Converts `value` to an integer. + * + * **Note:** This function is loosely based on [`ToInteger`](http://www.ecma-international.org/ecma-262/6.0/#sec-tointeger). * * @static * @memberOf _ - * @category Utility - * @param {*} value Any value. - * @returns {*} Returns `value`. + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. * @example * - * var object = { 'user': 'fred' }; + * _.toInteger(3); + * // => 3 * - * _.identity(object) === object; - * // => true + * _.toInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toInteger(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toInteger('3'); + * // => 3 */ - function identity(value) { - return value; + function toInteger(value) { + if (!value) { + return value === 0 ? value : 0; + } + value = toNumber(value); + if (value === INFINITY || value === -INFINITY) { + var sign = (value < 0 ? -1 : 1); + return sign * MAX_INTEGER; + } + var remainder = value % 1; + return value === value ? (remainder ? value - remainder : value) : 0; } - module.exports = identity; + module.e = toInteger; /***/ }, -/* 66 */ +/* 145 */ /***/ function(module, exports, __webpack_require__) { - var isArrayLike = __webpack_require__(41), - isIndex = __webpack_require__(57), - isObject = __webpack_require__(50); + var isFunction = __webpack_require__(16), + isObject = __webpack_require__(2); + + /** Used as references for various `Number` constants. */ + var NAN = 0 / 0; + + /** Used to match leading and trailing whitespace. */ + var reTrim = /^\s+|\s+$/g; + + /** Used to detect bad signed hexadecimal string values. */ + var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + + /** Used to detect binary string values. */ + var reIsBinary = /^0b[01]+$/i; + + /** Used to detect octal string values. */ + var reIsOctal = /^0o[0-7]+$/i; + + /** Built-in method references without a dependency on `root`. */ + var freeParseInt = parseInt; /** - * Checks if the provided arguments are from an iteratee call. + * Converts `value` to a number. * - * @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`. + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to process. + * @returns {number} Returns the number. + * @example + * + * _.toNumber(3); + * // => 3 + * + * _.toNumber(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toNumber(Infinity); + * // => Infinity + * + * _.toNumber('3'); + * // => 3 */ - function isIterateeCall(value, index, object) { - if (!isObject(object)) { - return false; + function toNumber(value) { + if (isObject(value)) { + var other = isFunction(value.valueOf) ? value.valueOf() : value; + value = isObject(other) ? (other + '') : other; } - var type = typeof index; - if (type == 'number' - ? (isArrayLike(object) && isIndex(index, object.length)) - : (type == 'string' && index in object)) { - var other = object[index]; - return value === value ? (value === other) : (other !== other); + if (typeof value != 'string') { + return value === 0 ? value : +value; } - return false; + value = value.replace(reTrim, ''); + var isBinary = reIsBinary.test(value); + return (isBinary || reIsOctal.test(value)) + ? freeParseInt(value.slice(2), isBinary ? 2 : 8) + : (reIsBadHex.test(value) ? NAN : +value); } - module.exports = isIterateeCall; + module.e = toNumber; /***/ }, -/* 67 */ -/***/ function(module, exports) { +/* 146 */ +/***/ function(module, exports, __webpack_require__) { - /** Used as the `TypeError` message for "Functions" methods. */ - var FUNC_ERROR_TEXT = 'Expected a function'; - - /* Native method references for those with the same name as other `lodash` methods. */ - var nativeMax = Math.max; + var copyObject = __webpack_require__(20), + keysIn = __webpack_require__(46); /** - * Creates a function that invokes `func` with the `this` binding of the - * created function and arguments from `start` and beyond provided as an array. - * - * **Note:** This method is based on the [rest parameter](https://developer.mozilla.org/Web/JavaScript/Reference/Functions/rest_parameters). + * Converts `value` to a plain object flattening inherited enumerable + * properties of `value` to own properties of the plain object. * * @static * @memberOf _ - * @category Function - * @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. + * @category Lang + * @param {*} value The value to convert. + * @returns {Object} Returns the converted plain object. * @example * - * var say = _.restParam(function(what, names) { - * return what + ' ' + _.initial(names).join(', ') + - * (_.size(names) > 1 ? ', & ' : '') + _.last(names); - * }); + * function Foo() { + * this.b = 2; + * } * - * say('hello', 'fred', 'barney', 'pebbles'); - * // => 'hello fred, barney, & pebbles' + * 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 restParam(func, start) { - if (typeof func != 'function') { - throw new TypeError(FUNC_ERROR_TEXT); - } - start = nativeMax(start === undefined ? (func.length - 1) : (+start || 0), 0); - return function() { - var args = arguments, - index = -1, - length = nativeMax(args.length - start, 0), - rest = Array(length); - - while (++index < length) { - rest[index] = args[start + index]; - } - switch (start) { - case 0: return func.call(this, rest); - case 1: return func.call(this, args[0], rest); - case 2: return func.call(this, args[0], args[1], rest); - } - var otherArgs = Array(start + 1); - index = -1; - while (++index < start) { - otherArgs[index] = args[index]; - } - otherArgs[start] = rest; - return func.apply(this, otherArgs); - }; + function toPlainObject(value) { + return copyObject(value, keysIn(value)); } - module.exports = restParam; + module.e = toPlainObject; /***/ }, -/* 68 */ -/***/ function(module, exports) { +/* 147 */ +/***/ function(module, exports, __webpack_require__) { - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: 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; + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ + 'use strict'; - event.subscribers = subscribers.filter(function (subscriber) { - publishSubscription(subscriber, data); - return !subscriber.once; - }); - }, - once: function once(event, callback, async) { - _subscribe(event, { - callback: callback, - async: async, - once: true - }); - }, - unsubscribe: function unsubscribe(eventName, callback) { - var event; + // Shimming starts here. + (function() { + // Utils. + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; + // Export to the adapter global object visible in the browser. + module.e.browserDetails = browserDetails; + module.e.extractVersion = __webpack_require__(0).extractVersion; + module.e.disableLog = __webpack_require__(0).disableLog; + + // Uncomment if you do not want any logging at all including the switch + // statement below. Can also be turned off in the browser via + // adapter.disableLog(true) but then logging from the switch statement below + // will still appear. + //require('./utils').disableLog(true); + + // Browser shims. + var chromeShim = __webpack_require__(148) || null; + var edgeShim = __webpack_require__(151) || null; + var firefoxShim = __webpack_require__(152) || null; + + // Shim browser if found. + switch (browserDetails.browser) { + case 'chrome': + if (!chromeShim || !chromeShim.shimPeerConnection) { + logging('Chrome shim is not included in this adapter release.'); + return; + } + logging('adapter.js shimming chrome!'); + // Export to the adapter global object visible in the browser. + module.e.browserShim = chromeShim; + + chromeShim.shimGetUserMedia(); + chromeShim.shimSourceObject(); + chromeShim.shimPeerConnection(); + chromeShim.shimOnTrack(); + break; + case 'edge': + if (!edgeShim || !edgeShim.shimPeerConnection) { + logging('MS edge shim is not included in this adapter release.'); + return; + } + logging('adapter.js shimming edge!'); + // Export to the adapter global object visible in the browser. + module.e.browserShim = edgeShim; - if (eventName) { - event = getEvent(eventName); - if (event && callback) { - event.subscribers = event.subscribers.filter(function (subscriber) { - return subscriber.callback !== callback; - }); - } else { - event.subscribers = []; - } - } else { - clearEvents(); - } - } - }; + edgeShim.shimPeerConnection(); + break; + case 'firefox': + if (!firefoxShim || !firefoxShim.shimPeerConnection) { + logging('Firefox shim is not included in this adapter release.'); + return; + } + logging('adapter.js shimming firefox!'); + // Export to the adapter global object visible in the browser. + module.e.browserShim = firefoxShim; + + firefoxShim.shimGetUserMedia(); + firefoxShim.shimSourceObject(); + firefoxShim.shimPeerConnection(); + firefoxShim.shimOnTrack(); + break; + default: + logging('Unsupported browser!'); + } })(); - - module.exports = exports["default"]; + /***/ }, -/* 69 */ +/* 148 */ /***/ function(module, exports, __webpack_require__) { + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ 'use strict'; + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; + + var chromeShim = { + shimOnTrack: function() { + if (typeof window === 'object' && window.RTCPeerConnection && !('ontrack' in + window.RTCPeerConnection.prototype)) { + Object.defineProperty(window.RTCPeerConnection.prototype, 'ontrack', { + get: function() { return this._ontrack; }, + set: function(f) { + var self = this; + if (this._ontrack) { + this.removeEventListener('track', this._ontrack); + this.removeEventListener('addstream', this._ontrackpoly); + } + this.addEventListener('track', this._ontrack = f); + this.addEventListener('addstream', this._ontrackpoly = function(e) { + // onaddstream does not fire when a track is added to an existing stream. + // but stream.onaddtrack is implemented so we use that + e.stream.addEventListener('addtrack', function(te) { + var event = new Event('track'); + event.track = te.track; + event.receiver = {track: te.track}; + event.streams = [e.stream]; + self.dispatchEvent(event); + }); + e.stream.getTracks().forEach(function(track) { + var event = new Event('track'); + event.track = track; + event.receiver = {track: track}; + event.streams = [e.stream]; + this.dispatchEvent(event); + }.bind(this)); + }.bind(this)); + } + }); + } + }, + + shimSourceObject: function() { + if (typeof window === 'object') { + if (window.HTMLMediaElement && + !('srcObject' in window.HTMLMediaElement.prototype)) { + // Shim the srcObject property, once, when HTMLMediaElement is found. + Object.defineProperty(window.HTMLMediaElement.prototype, 'srcObject', { + get: function() { + return this._srcObject; + }, + set: function(stream) { + var self = this; + // Use _srcObject as a private property for this shim + this._srcObject = stream; + if (this.src) { + URL.revokeObjectURL(this.src); + } - Object.defineProperty(exports, '__esModule', { - value: true - }); - var merge = __webpack_require__(35); + if (!stream) { + this.src = ''; + return; + } + this.src = URL.createObjectURL(stream); + // We need to recreate the blob url when a track is added or removed. + // Doing it manually since we want to avoid a recursion. + stream.addEventListener('addtrack', function() { + if (self.src) { + URL.revokeObjectURL(self.src); + } + self.src = URL.createObjectURL(stream); + }); + stream.addEventListener('removetrack', function() { + if (self.src) { + URL.revokeObjectURL(self.src); + } + self.src = URL.createObjectURL(stream); + }); + } + }); + } + } + }, - var streamRef, loadedDataHandler; + shimPeerConnection: function() { + // The RTCPeerConnection object. + window.RTCPeerConnection = function(pcConfig, pcConstraints) { + // Translate iceTransportPolicy to iceTransports, + // see https://code.google.com/p/webrtc/issues/detail?id=4869 + logging('PeerConnection'); + if (pcConfig && pcConfig.iceTransportPolicy) { + pcConfig.iceTransports = pcConfig.iceTransportPolicy; + } - /** - * Wraps browser-specific getUserMedia - * @param {Object} constraints - * @param {Object} success Callback - * @param {Object} failure Callback - */ - function getUserMedia(constraints, success, failure) { - if (typeof navigator.getUserMedia !== 'undefined') { - navigator.getUserMedia(constraints, function (stream) { - streamRef = stream; - var videoSrc = window.URL && window.URL.createObjectURL(stream) || stream; - success.apply(null, [videoSrc]); - }, failure); - } else { - failure(new TypeError("getUserMedia not available")); - } - } + var pc = new webkitRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors + var origGetStats = pc.getStats.bind(pc); + pc.getStats = function(selector, successCallback, errorCallback) { // jshint ignore: line + var self = this; + var args = arguments; + + // If selector is a function then we are in the old style stats so just + // pass back the original getStats format to avoid breaking old users. + if (arguments.length > 0 && typeof selector === 'function') { + return origGetStats(selector, successCallback); + } + + var fixChromeStats_ = function(response) { + var standardReport = {}; + var reports = response.result(); + reports.forEach(function(report) { + var standardStats = { + id: report.id, + timestamp: report.timestamp, + type: report.type + }; + report.names().forEach(function(name) { + standardStats[name] = report.stat(name); + }); + standardReport[standardStats.id] = standardStats; + }); - function loadedData(video, callback) { - var attempts = 10; + return standardReport; + }; - function checkVideo() { - if (attempts > 0) { - if (video.videoWidth > 0 && video.videoHeight > 0) { - if (true) { - console.log(video.videoWidth + "px x " + video.videoHeight + "px"); - } - callback(); - } else { - window.setTimeout(checkVideo, 500); - } - } else { - callback('Unable to play video stream. Is webcam working?'); + if (arguments.length >= 2) { + var successCallbackWrapper_ = function(response) { + args[1](fixChromeStats_(response)); + }; + + return origGetStats.apply(this, [successCallbackWrapper_, arguments[0]]); } - 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 - * @param {Object} callback - */ - function initCamera(constraints, video, callback) { - getUserMedia(constraints, function (src) { - video.src = src; - if (loadedDataHandler) { - video.removeEventListener("loadeddata", loadedDataHandler, false); + // promise-support + return new Promise(function(resolve, reject) { + if (args.length === 1 && selector === null) { + origGetStats.apply(self, [ + function(response) { + resolve.apply(null, [fixChromeStats_(response)]); + }, reject]); + } else { + origGetStats.apply(self, [resolve, reject]); + } + }); + }; + + return pc; + }; + window.RTCPeerConnection.prototype = webkitRTCPeerConnection.prototype; + + // wrap static methods. Currently just generateCertificate. + if (webkitRTCPeerConnection.generateCertificate) { + Object.defineProperty(window.RTCPeerConnection, 'generateCertificate', { + get: function() { + if (arguments.length) { + return webkitRTCPeerConnection.generateCertificate.apply(null, + arguments); + } else { + return webkitRTCPeerConnection.generateCertificate; + } + } + }); + } + + // add promise support + ['createOffer', 'createAnswer'].forEach(function(method) { + var nativeMethod = webkitRTCPeerConnection.prototype[method]; + webkitRTCPeerConnection.prototype[method] = function() { + var self = this; + if (arguments.length < 1 || (arguments.length === 1 && + typeof(arguments[0]) === 'object')) { + var opts = arguments.length === 1 ? arguments[0] : undefined; + return new Promise(function(resolve, reject) { + nativeMethod.apply(self, [resolve, reject, opts]); + }); + } else { + return nativeMethod.apply(this, arguments); } - loadedDataHandler = loadedData.bind(null, video, callback); - video.addEventListener('loadeddata', loadedDataHandler, false); - video.play(); - }, function (e) { - callback(e); + }; }); - } - - /** - * Normalizes the incoming constraints to satisfy the current browser - * @param config - * @param cb Callback which is called whenever constraints are created - * @returns {*} - */ - function normalizeConstraints(config, cb) { - var constraints = { - audio: false, - video: true - }, - videoConstraints = merge({ - width: 640, - height: 480, - minAspectRatio: 0, - maxAspectRatio: 100, - facing: "environment" - }, config); - if (typeof MediaStreamTrack !== 'undefined' && typeof MediaStreamTrack.getSources !== 'undefined') { - MediaStreamTrack.getSources(function (sourceInfos) { - var videoSourceId; - for (var i = 0; i < sourceInfos.length; ++i) { - var sourceInfo = sourceInfos[i]; - if (sourceInfo.kind === "video" && sourceInfo.facing === videoConstraints.facing) { - videoSourceId = sourceInfo.id; + ['setLocalDescription', 'setRemoteDescription', + 'addIceCandidate'].forEach(function(method) { + var nativeMethod = webkitRTCPeerConnection.prototype[method]; + webkitRTCPeerConnection.prototype[method] = function() { + var args = arguments; + var self = this; + return new Promise(function(resolve, reject) { + nativeMethod.apply(self, [args[0], + function() { + resolve(); + if (args.length >= 2) { + args[1].apply(null, []); } - } - constraints.video = { - mandatory: { - minWidth: videoConstraints.width, - minHeight: videoConstraints.height, - minAspectRatio: videoConstraints.minAspectRatio, - maxAspectRatio: videoConstraints.maxAspectRatio - }, - optional: [{ - sourceId: videoSourceId - }] - }; - return cb(constraints); + }, + function(err) { + reject(err); + if (args.length >= 3) { + args[2].apply(null, [err]); + } + }] + ); }); + }; + }); + }, + + // Attach a media stream to an element. + attachMediaStream: function(element, stream) { + logging('DEPRECATED, attachMediaStream will soon be removed.'); + if (browserDetails.version >= 43) { + element.srcObject = stream; + } else if (typeof element.src !== 'undefined') { + element.src = URL.createObjectURL(stream); } else { - constraints.video = { - mediaSource: "camera", - width: { min: videoConstraints.width, max: videoConstraints.width }, - height: { min: videoConstraints.height, max: videoConstraints.height }, - require: ["width", "height"] - }; - return cb(constraints); + logging('Error attaching stream to element.'); } - } + }, - /** - * Requests the back-facing camera of the user. The callback is called - * whenever the stream is ready to be consumed, or if an error occures. - * @param {Object} video - * @param {Object} callback - */ - function _request(video, videoConstraints, callback) { - normalizeConstraints(videoConstraints, function (constraints) { - initCamera(constraints, video, callback); - }); + reattachMediaStream: function(to, from) { + logging('DEPRECATED, reattachMediaStream will soon be removed.'); + if (browserDetails.version >= 43) { + to.srcObject = from.srcObject; + } else { + to.src = from.src; + } + } } - exports['default'] = { - request: function request(video, constraints, callback) { - _request(video, constraints, callback); - }, - release: function release() { - var tracks = streamRef && streamRef.getVideoTracks(); - if (tracks && tracks.length) { - tracks[0].stop(); - } - streamRef = null; - } + + // Expose public methods. + module.e = { + shimOnTrack: chromeShim.shimOnTrack, + shimSourceObject: chromeShim.shimSourceObject, + shimPeerConnection: chromeShim.shimPeerConnection, + shimGetUserMedia: __webpack_require__(149), + attachMediaStream: chromeShim.attachMediaStream, + reattachMediaStream: chromeShim.reattachMediaStream }; - module.exports = exports['default']; + /***/ }, -/* 70 */ +/* 149 */ /***/ function(module, exports, __webpack_require__) { + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ 'use strict'; + var logging = __webpack_require__(0).log; - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _commonImage_debug = __webpack_require__(19); - - var _commonImage_debug2 = _interopRequireDefault(_commonImage_debug); - - function contains(codeResult, list) { - if (list) { - return list.some(function (item) { - return Object.keys(item).every(function (key) { - return item[key] === codeResult[key]; - }); + // Expose public methods. + module.e = function() { + var constraintsToChrome_ = function(c) { + if (typeof c !== 'object' || c.mandatory || c.optional) { + return c; + } + var cc = {}; + Object.keys(c).forEach(function(key) { + if (key === 'require' || key === 'advanced' || key === 'mediaSource') { + return; + } + var r = (typeof c[key] === 'object') ? c[key] : {ideal: c[key]}; + if (r.exact !== undefined && typeof r.exact === 'number') { + r.min = r.max = r.exact; + } + var oldname_ = function(prefix, name) { + if (prefix) { + return prefix + name.charAt(0).toUpperCase() + name.slice(1); + } + return (name === 'deviceId') ? 'sourceId' : name; + }; + if (r.ideal !== undefined) { + cc.optional = cc.optional || []; + var oc = {}; + if (typeof r.ideal === 'number') { + oc[oldname_('min', key)] = r.ideal; + cc.optional.push(oc); + oc = {}; + oc[oldname_('max', key)] = r.ideal; + cc.optional.push(oc); + } else { + oc[oldname_('', key)] = r.ideal; + cc.optional.push(oc); + } + } + if (r.exact !== undefined && typeof r.exact !== 'number') { + cc.mandatory = cc.mandatory || {}; + cc.mandatory[oldname_('', key)] = r.exact; + } else { + ['min', 'max'].forEach(function(mix) { + if (r[mix] !== undefined) { + cc.mandatory = cc.mandatory || {}; + cc.mandatory[oldname_(mix, key)] = r[mix]; + } }); + } + }); + if (c.advanced) { + cc.optional = (cc.optional || []).concat(c.advanced); } - return false; - } + return cc; + }; - function passesFilter(codeResult, filter) { - if (typeof filter === 'function') { - return filter(codeResult); + var getUserMedia_ = function(constraints, onSuccess, onError) { + if (constraints.audio) { + constraints.audio = constraintsToChrome_(constraints.audio); } - return true; - } + if (constraints.video) { + constraints.video = constraintsToChrome_(constraints.video); + } + logging('chrome: ' + JSON.stringify(constraints)); + return navigator.webkitGetUserMedia(constraints, onSuccess, onError); + }; + navigator.getUserMedia = getUserMedia_; - exports['default'] = { - create: function create(config) { - var canvas = document.createElement("canvas"), - ctx = canvas.getContext("2d"), - results = [], - capacity = config.capacity || 20, - capture = config.capture === true; + // Returns the result of getUserMedia as a Promise. + var getUserMediaPromise_ = function(constraints) { + return new Promise(function(resolve, reject) { + navigator.getUserMedia(constraints, resolve, reject); + }); + } - function matchesConstraints(codeResult) { - return capacity && codeResult && !contains(codeResult, config.blacklist) && passesFilter(codeResult, config.filter); - } + if (!navigator.mediaDevices) { + navigator.mediaDevices = {getUserMedia: getUserMediaPromise_, + enumerateDevices: function() { + return new Promise(function(resolve) { + var kinds = {audio: 'audioinput', video: 'videoinput'}; + return MediaStreamTrack.getSources(function(devices) { + resolve(devices.map(function(device) { + return {label: device.label, + kind: kinds[device.kind], + deviceId: device.id, + groupId: ''}; + })); + }); + }); + }}; + } - return { - addResult: function addResult(data, imageSize, codeResult) { - var result = {}; + // A shim for getUserMedia method on the mediaDevices object. + // TODO(KaptenJansson) remove once implemented in Chrome stable. + if (!navigator.mediaDevices.getUserMedia) { + navigator.mediaDevices.getUserMedia = function(constraints) { + return getUserMediaPromise_(constraints); + }; + } else { + // Even though Chrome 45 has navigator.mediaDevices and a getUserMedia + // function which returns a Promise, it does not accept spec-style + // constraints. + var origGetUserMedia = navigator.mediaDevices.getUserMedia. + bind(navigator.mediaDevices); + navigator.mediaDevices.getUserMedia = function(c) { + if (c) { + logging('spec: ' + JSON.stringify(c)); // whitespace for alignment + c.audio = constraintsToChrome_(c.audio); + c.video = constraintsToChrome_(c.video); + logging('chrome: ' + JSON.stringify(c)); + } + return origGetUserMedia(c); + }.bind(this); + } - if (matchesConstraints(codeResult)) { - capacity--; - result.codeResult = codeResult; - if (capture) { - canvas.width = imageSize.x; - canvas.height = imageSize.y; - _commonImage_debug2['default'].drawImage(data, imageSize, ctx); - result.frame = canvas.toDataURL(); - } - results.push(result); - } - }, - getResults: function getResults() { - return results; - } - }; - } + // Dummy devicechange event methods. + // TODO(KaptenJansson) remove once implemented in Chrome stable. + if (typeof navigator.mediaDevices.addEventListener === 'undefined') { + navigator.mediaDevices.addEventListener = function() { + logging('Dummy mediaDevices.addEventListener called.'); + }; + } + if (typeof navigator.mediaDevices.removeEventListener === 'undefined') { + navigator.mediaDevices.removeEventListener = function() { + logging('Dummy mediaDevices.removeEventListener called.'); + }; + } }; - module.exports = exports['default']; + /***/ }, -/* 71 */ +/* 150 */ /***/ function(module, exports, __webpack_require__) { + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ 'use strict'; - Object.defineProperty(exports, '__esModule', { - value: true - }); - var config = undefined; + // SDP helpers. + var SDPUtils = {}; - if (true) { - config = __webpack_require__(72); - } else if (ENV.node) { - config = require('./config.node.js'); - } else { - config = require('./config.prod.js'); - } + // Generate an alphanumeric identifier for cname or mids. + // TODO: use UUIDs instead? https://gist.github.com/jed/982883 + SDPUtils.generateIdentifier = function() { + return Math.random().toString(36).substr(2, 10); + }; - exports['default'] = config; - module.exports = exports['default']; - -/***/ }, -/* 72 */ -/***/ function(module, exports) { - - "use strict"; + // The RTCP CNAME used by all peerconnections from the same JS. + SDPUtils.localCName = SDPUtils.generateIdentifier(); - module.exports = { - inputStream: { - name: "Live", - type: "LiveStream", - constraints: { - width: 640, - height: 480, - minAspectRatio: 0, - maxAspectRatio: 100, - facing: "environment" // or user - }, - 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'], - debug: { - drawBoundingBox: false, - showFrequency: false, - drawScanline: false, - showPattern: false - } - }, - locator: { - halfSample: true, - patchSize: "medium", // x-small, small, medium, large, x-large - debug: { - showCanvas: false, - showPatches: false, - showFoundPatches: false, - showSkeleton: false, - showLabels: false, - showPatchLabels: false, - showRemainingPatchLabels: false, - boxFromPatches: { - showTransformed: false, - showTransformedBox: false, - showBB: false - } - } + + // Splits SDP into lines, dealing with both CRLF and LF. + SDPUtils.splitLines = function(blob) { + return blob.trim().split('\n').map(function(line) { + return line.trim(); + }); + }; + // Splits SDP into sessionpart and mediasections. Ensures CRLF. + SDPUtils.splitSections = function(blob) { + var parts = blob.split('\r\nm='); + return parts.map(function(part, index) { + return (index > 0 ? 'm=' + part : part).trim() + '\r\n'; + }); + }; + + // Returns lines that start with a certain prefix. + SDPUtils.matchPrefix = function(blob, prefix) { + return SDPUtils.splitLines(blob).filter(function(line) { + return line.indexOf(prefix) === 0; + }); + }; + + // Parses an ICE candidate line. Sample input: + // candidate:702786350 2 udp 41819902 8.8.8.8 60769 typ relay raddr 8.8.8.8 rport 55996" + SDPUtils.parseCandidate = function(line) { + var parts; + // Parse both variants. + if (line.indexOf('a=candidate:') === 0) { + parts = line.substring(12).split(' '); + } else { + parts = line.substring(10).split(' '); + } + + var candidate = { + foundation: parts[0], + component: parts[1], + protocol: parts[2].toLowerCase(), + priority: parseInt(parts[3], 10), + ip: parts[4], + port: parseInt(parts[5], 10), + // skip parts[6] == 'typ' + type: parts[7] + }; + + for (var i = 8; i < parts.length; i += 2) { + switch (parts[i]) { + case 'raddr': + candidate.relatedAddress = parts[i + 1]; + break; + case 'rport': + candidate.relatedPort = parseInt(parts[i + 1], 10); + break; + case 'tcptype': + candidate.tcpType = parts[i + 1]; + break; + default: // Unknown extensions are silently ignored. + break; } + } + return candidate; + }; + + // Translates a candidate object into SDP candidate attribute. + SDPUtils.writeCandidate = function(candidate) { + var sdp = []; + sdp.push(candidate.foundation); + sdp.push(candidate.component); + sdp.push(candidate.protocol.toUpperCase()); + sdp.push(candidate.priority); + sdp.push(candidate.ip); + sdp.push(candidate.port); + + var type = candidate.type; + sdp.push('typ'); + sdp.push(type); + if (type !== 'host' && candidate.relatedAddress && + candidate.relatedPort) { + sdp.push('raddr'); + sdp.push(candidate.relatedAddress); // was: relAddr + sdp.push('rport'); + sdp.push(candidate.relatedPort); // was: relPort + } + if (candidate.tcpType && candidate.protocol.toLowerCase() === 'tcp') { + sdp.push('tcptype'); + sdp.push(candidate.tcpType); + } + return 'candidate:' + sdp.join(' '); }; - -/***/ }, -/* 73 */ -/***/ function(module, exports, __webpack_require__) { - - 'use strict'; - Object.defineProperty(exports, '__esModule', { - value: true - }); + // Parses an rtpmap line, returns RTCRtpCoddecParameters. Sample input: + // a=rtpmap:111 opus/48000/2 + SDPUtils.parseRtpMap = function(line) { + var parts = line.substr(9).split(' '); + var parsed = { + payloadType: parseInt(parts.shift(), 10) // was: id + }; + + parts = parts[0].split('/'); + + parsed.name = parts[0]; + parsed.clockRate = parseInt(parts[1], 10); // was: clockrate + parsed.numChannels = parts.length === 3 ? parseInt(parts[2], 10) : 1; // was: channels + return parsed; + }; - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + // Generate an a=rtpmap line from RTCRtpCodecCapability or RTCRtpCodecParameters. + SDPUtils.writeRtpMap = function(codec) { + var pt = codec.payloadType; + if (codec.preferredPayloadType !== undefined) { + pt = codec.preferredPayloadType; + } + return 'a=rtpmap:' + pt + ' ' + codec.name + '/' + codec.clockRate + + (codec.numChannels !== 1 ? '/' + codec.numChannels : '') + '\r\n'; + }; + + // Parses an ftmp line, returns dictionary. Sample input: + // a=fmtp:96 vbr=on;cng=on + // Also deals with vbr=on; cng=on + SDPUtils.parseFmtp = function(line) { + var parsed = {}; + var kv; + var parts = line.substr(line.indexOf(' ') + 1).split(';'); + for (var j = 0; j < parts.length; j++) { + kv = parts[j].trim().split('='); + parsed[kv[0].trim()] = kv[1]; + } + return parsed; + }; + + // Generates an a=ftmp line from RTCRtpCodecCapability or RTCRtpCodecParameters. + SDPUtils.writeFtmp = function(codec) { + var line = ''; + var pt = codec.payloadType; + if (codec.preferredPayloadType !== undefined) { + pt = codec.preferredPayloadType; + } + if (codec.parameters && codec.parameters.length) { + var params = []; + Object.keys(codec.parameters).forEach(function(param) { + params.push(param + '=' + codec.parameters[param]); + }); + line += 'a=fmtp:' + pt + ' ' + params.join(';') + '\r\n'; + } + return line; + }; - var _image_loader = __webpack_require__(74); + // Parses an rtcp-fb line, returns RTCPRtcpFeedback object. Sample input: + // a=rtcp-fb:98 nack rpsi + SDPUtils.parseRtcpFb = function(line) { + var parts = line.substr(line.indexOf(' ') + 1).split(' '); + return { + type: parts.shift(), + parameter: parts.join(' ') + }; + }; + // Generate a=rtcp-fb lines from RTCRtpCodecCapability or RTCRtpCodecParameters. + SDPUtils.writeRtcpFb = function(codec) { + var lines = ''; + var pt = codec.payloadType; + if (codec.preferredPayloadType !== undefined) { + pt = codec.preferredPayloadType; + } + if (codec.rtcpFeedback && codec.rtcpFeedback.length) { + // FIXME: special handling for trr-int? + codec.rtcpFeedback.forEach(function(fb) { + lines += 'a=rtcp-fb:' + pt + ' ' + fb.type + ' ' + fb.parameter + + '\r\n'; + }); + } + return lines; + }; + + // Parses an RFC 5576 ssrc media attribute. Sample input: + // a=ssrc:3735928559 cname:something + SDPUtils.parseSsrcMedia = function(line) { + var sp = line.indexOf(' '); + var parts = { + ssrc: line.substr(7, sp - 7), + }; + var colon = line.indexOf(':', sp); + if (colon > -1) { + parts.attribute = line.substr(sp + 1, colon - sp - 1); + parts.value = line.substr(colon + 1); + } else { + parts.attribute = line.substr(sp + 1); + } + return parts; + }; + + // Extracts DTLS parameters from SDP media section or sessionpart. + // FIXME: for consistency with other functions this should only + // get the fingerprint line as input. See also getIceParameters. + SDPUtils.getDtlsParameters = function(mediaSection, sessionpart) { + var lines = SDPUtils.splitLines(mediaSection); + lines = lines.concat(SDPUtils.splitLines(sessionpart)); // Search in session part, too. + var fpLine = lines.filter(function(line) { + return line.indexOf('a=fingerprint:') === 0; + })[0].substr(14); + // Note: a=setup line is ignored since we use the 'auto' role. + var dtlsParameters = { + role: 'auto', + fingerprints: [{ + algorithm: fpLine.split(' ')[0], + value: fpLine.split(' ')[1] + }] + }; + return dtlsParameters; + }; - var _image_loader2 = _interopRequireDefault(_image_loader); + // Serializes DTLS parameters to SDP. + SDPUtils.writeDtlsParameters = function(params, setupType) { + var sdp = 'a=setup:' + setupType + '\r\n'; + params.fingerprints.forEach(function(fp) { + sdp += 'a=fingerprint:' + fp.algorithm + ' ' + fp.value + '\r\n'; + }); + return sdp; + }; + // Parses ICE information from SDP media section or sessionpart. + // FIXME: for consistency with other functions this should only + // get the ice-ufrag and ice-pwd lines as input. + SDPUtils.getIceParameters = function(mediaSection, sessionpart) { + var lines = SDPUtils.splitLines(mediaSection); + lines = lines.concat(SDPUtils.splitLines(sessionpart)); // Search in session part, too. + var iceParameters = { + usernameFragment: lines.filter(function(line) { + return line.indexOf('a=ice-ufrag:') === 0; + })[0].substr(12), + password: lines.filter(function(line) { + return line.indexOf('a=ice-pwd:') === 0; + })[0].substr(10) + }; + return iceParameters; + }; - var InputStream = {}; - InputStream.createVideoStream = function (video) { - var that = {}, - _config = null, - _eventNames = ['canrecord', 'ended'], - _eventHandlers = {}, - _calculatedWidth, - _calculatedHeight, - _topRight = { x: 0, y: 0 }, - _canvasSize = { x: 0, y: 0 }; + // Serializes ICE parameters to SDP. + SDPUtils.writeIceParameters = function(params) { + return 'a=ice-ufrag:' + params.usernameFragment + '\r\n' + + 'a=ice-pwd:' + params.password + '\r\n'; + }; - function initSize() { - var width = video.videoWidth, - height = video.videoHeight; + // Parses the SDP media section and returns RTCRtpParameters. + SDPUtils.parseRtpParameters = function(mediaSection) { + var description = { + codecs: [], + headerExtensions: [], + fecMechanisms: [], + rtcp: [] + }; + var lines = SDPUtils.splitLines(mediaSection); + var mline = lines[0].split(' '); + for (var i = 3; i < mline.length; i++) { // find all codecs from mline[3..] + var pt = mline[i]; + var rtpmapline = SDPUtils.matchPrefix( + mediaSection, 'a=rtpmap:' + pt + ' ')[0]; + if (rtpmapline) { + var codec = SDPUtils.parseRtpMap(rtpmapline); + var fmtps = SDPUtils.matchPrefix( + mediaSection, 'a=fmtp:' + pt + ' '); + // Only the first a=fmtp: is considered. + codec.parameters = fmtps.length ? SDPUtils.parseFmtp(fmtps[0]) : {}; + codec.rtcpFeedback = SDPUtils.matchPrefix( + mediaSection, 'a=rtcp-fb:' + pt + ' ') + .map(SDPUtils.parseRtcpFb); + description.codecs.push(codec); + } + } + // FIXME: parse headerExtensions, fecMechanisms and rtcp. + return description; + }; - _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; + // Generates parts of the SDP media section describing the capabilities / parameters. + SDPUtils.writeRtpDescription = function(kind, caps) { + var sdp = ''; - _canvasSize.x = _calculatedWidth; - _canvasSize.y = _calculatedHeight; + // Build the mline. + sdp += 'm=' + kind + ' '; + sdp += caps.codecs.length > 0 ? '9' : '0'; // reject if no codecs. + sdp += ' UDP/TLS/RTP/SAVPF '; + sdp += caps.codecs.map(function(codec) { + if (codec.preferredPayloadType !== undefined) { + return codec.preferredPayloadType; } + return codec.payloadType; + }).join(' ') + '\r\n'; - that.getRealWidth = function () { - return video.videoWidth; - }; - - that.getRealHeight = function () { - return video.videoHeight; - }; + sdp += 'c=IN IP4 0.0.0.0\r\n'; + sdp += 'a=rtcp:9 IN IP4 0.0.0.0\r\n'; - that.getWidth = function () { - return _calculatedWidth; - }; + // Add a=rtpmap lines for each codec. Also fmtp and rtcp-fb. + caps.codecs.forEach(function(codec) { + sdp += SDPUtils.writeRtpMap(codec); + sdp += SDPUtils.writeFtmp(codec); + sdp += SDPUtils.writeRtcpFb(codec); + }); + // FIXME: add headerExtensions, fecMechanismş and rtcp. + sdp += 'a=rtcp-mux\r\n'; + return sdp; + }; - that.getHeight = function () { - return _calculatedHeight; - }; + SDPUtils.writeSessionBoilerplate = function() { + // FIXME: sess-id should be an NTP timestamp. + return 'v=0\r\n' + + 'o=thisisadapterortc 8169639915646943137 2 IN IP4 127.0.0.1\r\n' + + 's=-\r\n' + + 't=0 0\r\n'; + }; - that.setWidth = function (width) { - _calculatedWidth = width; - }; + SDPUtils.writeMediaSection = function(transceiver, caps, type, stream) { + var sdp = SDPUtils.writeRtpDescription(transceiver.kind, caps); - that.setHeight = function (height) { - _calculatedHeight = height; - }; + // Map ICE parameters (ufrag, pwd) to SDP. + sdp += SDPUtils.writeIceParameters( + transceiver.iceGatherer.getLocalParameters()); - that.setInputStream = function (config) { - _config = config; - video.src = typeof config.src !== 'undefined' ? config.src : ''; - }; + // Map DTLS parameters to SDP. + sdp += SDPUtils.writeDtlsParameters( + transceiver.dtlsTransport.getLocalParameters(), + type === 'offer' ? 'actpass' : 'active'); - that.ended = function () { - return video.ended; - }; + sdp += 'a=mid:' + transceiver.mid + '\r\n'; - that.getConfig = function () { - return _config; - }; + if (transceiver.rtpSender && transceiver.rtpReceiver) { + sdp += 'a=sendrecv\r\n'; + } else if (transceiver.rtpSender) { + sdp += 'a=sendonly\r\n'; + } else if (transceiver.rtpReceiver) { + sdp += 'a=recvonly\r\n'; + } else { + sdp += 'a=inactive\r\n'; + } - that.setAttribute = function (name, value) { - video.setAttribute(name, value); - }; + // FIXME: for RTX there might be multiple SSRCs. Not implemented in Edge yet. + if (transceiver.rtpSender) { + var msid = 'msid:' + stream.id + ' ' + + transceiver.rtpSender.track.id + '\r\n'; + sdp += 'a=' + msid; + sdp += 'a=ssrc:' + transceiver.sendSsrc + ' ' + msid; + } + // FIXME: this should be written by writeRtpDescription. + sdp += 'a=ssrc:' + transceiver.sendSsrc + ' cname:' + + SDPUtils.localCName + '\r\n'; + return sdp; + }; + + // Gets the direction from the mediaSection or the sessionpart. + SDPUtils.getDirection = function(mediaSection, sessionpart) { + // Look for sendrecv, sendonly, recvonly, inactive, default to sendrecv. + var lines = SDPUtils.splitLines(mediaSection); + for (var i = 0; i < lines.length; i++) { + switch (lines[i]) { + case 'a=sendrecv': + case 'a=sendonly': + case 'a=recvonly': + case 'a=inactive': + return lines[i].substr(2); + } + } + if (sessionpart) { + return SDPUtils.getDirection(sessionpart); + } + return 'sendrecv'; + }; - that.pause = function () { - video.pause(); - }; + // Expose public methods. + module.e = SDPUtils; + + +/***/ }, +/* 151 */ +/***/ function(module, exports, __webpack_require__) { + + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ + 'use strict'; - that.play = function () { - video.play(); - }; + var SDPUtils = __webpack_require__(150); + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; + + var edgeShim = { + shimPeerConnection: function() { + if (window.RTCIceGatherer) { + // ORTC defines an RTCIceCandidate object but no constructor. + // Not implemented in Edge. + if (!window.RTCIceCandidate) { + window.RTCIceCandidate = function(args) { + return args; + }; + } + // ORTC does not have a session description object but + // other browsers (i.e. Chrome) that will support both PC and ORTC + // in the future might have this defined already. + if (!window.RTCSessionDescription) { + window.RTCSessionDescription = function(args) { + return args; + }; + } + } - that.setCurrentTime = function (time) { - if (_config.type !== "LiveStream") { - video.currentTime = time; + window.RTCPeerConnection = function(config) { + var self = this; + + var _eventTarget = document.createDocumentFragment(); + ['addEventListener', 'removeEventListener', 'dispatchEvent'].forEach( + function(method) { + self[method] = _eventTarget[method].bind(_eventTarget); + }); + + this.onicecandidate = null; + this.onaddstream = null; + this.ontrack = null; + this.onremovestream = null; + this.onsignalingstatechange = null; + this.oniceconnectionstatechange = null; + this.onnegotiationneeded = null; + this.ondatachannel = null; + + this.localStreams = []; + this.remoteStreams = []; + this.getLocalStreams = function() { return self.localStreams; }; + this.getRemoteStreams = function() { return self.remoteStreams; }; + + this.localDescription = new RTCSessionDescription({ + type: '', + sdp: '' + }); + this.remoteDescription = new RTCSessionDescription({ + type: '', + sdp: '' + }); + this.signalingState = 'stable'; + this.iceConnectionState = 'new'; + this.iceGatheringState = 'new'; + + this.iceOptions = { + gatherPolicy: 'all', + iceServers: [] + }; + if (config && config.iceTransportPolicy) { + switch (config.iceTransportPolicy) { + case 'all': + case 'relay': + this.iceOptions.gatherPolicy = config.iceTransportPolicy; + break; + case 'none': + // FIXME: remove once implementation and spec have added this. + throw new TypeError('iceTransportPolicy "none" not supported'); } - }; + } + if (config && config.iceServers) { + // Edge does not like + // 1) stun: + // 2) turn: that does not have all of turn:host:port?transport=udp + this.iceOptions.iceServers = config.iceServers.filter(function(server) { + if (server && server.urls) { + server.urls = server.urls.filter(function(url) { + return url.indexOf('transport=udp') !== -1; + })[0]; + return true; + } + return false; + }); + } - that.addEventListener = function (event, f, bool) { - if (_eventNames.indexOf(event) !== -1) { - if (!_eventHandlers[event]) { - _eventHandlers[event] = []; - } - _eventHandlers[event].push(f); - } else { - video.addEventListener(event, f, bool); - } - }; + // per-track iceGathers, iceTransports, dtlsTransports, rtpSenders, ... + // everything that is needed to describe a SDP m-line. + this.transceivers = []; - that.clearEventHandlers = function () { - _eventNames.forEach(function (eventName) { - var handlers = _eventHandlers[eventName]; - if (handlers && handlers.length > 0) { - handlers.forEach(function (handler) { - video.removeEventListener(eventName, handler); - }); - } - }); + // since the iceGatherer is currently created in createOffer but we + // must not emit candidates until after setLocalDescription we buffer + // them in this array. + this._localIceCandidatesBuffer = []; }; - that.trigger = function (eventName, args) { - var j, - handlers = _eventHandlers[eventName]; - - if (eventName === 'canrecord') { - initSize(); + window.RTCPeerConnection.prototype._emitBufferedCandidates = function() { + var self = this; + var sections = SDPUtils.splitSections(self.localDescription.sdp); + // FIXME: need to apply ice candidates in a way which is async but in-order + this._localIceCandidatesBuffer.forEach(function(event) { + var end = !event.candidate || Object.keys(event.candidate).length == 0; + if (end) { + for (var j = 1; j < sections.length; j++) { + sections[j] += 'a=end-of-candidates\r\n'; + } + } else { + sections[event.candidate.sdpMLineIndex + 1] += + 'a=' + event.candidate.candidate + '\r\n'; } - if (handlers && handlers.length > 0) { - for (j = 0; j < handlers.length; j++) { - handlers[j].apply(that, args); - } + self.dispatchEvent(event); + if (self.onicecandidate !== null) { + self.onicecandidate(event); } + if (!event.candidate) { + self.iceGatheringState = 'complete'; + } + }); + this._localIceCandidatesBuffer = []; + this.localDescription.sdp = sections.join(''); }; - 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; + window.RTCPeerConnection.prototype.addStream = function(stream) { + // Clone is necessary for local demos mostly, attaching directly + // to two different senders does not work (build 10547). + this.localStreams.push(stream.clone()); + this._maybeFireNegotiationNeeded(); }; - that.getFrame = function () { - return video; + window.RTCPeerConnection.prototype.removeStream = function(stream) { + var idx = this.localStreams.indexOf(stream); + if (idx > -1) { + this.localStreams.splice(idx, 1); + this._maybeFireNegotiationNeeded(); + } }; - return that; - }; + // Determines the intersection of local and remote capabilities. + window.RTCPeerConnection.prototype._getCommonCapabilities = + function(localCapabilities, remoteCapabilities) { + var commonCapabilities = { + codecs: [], + headerExtensions: [], + fecMechanisms: [] + }; + localCapabilities.codecs.forEach(function(lCodec) { + for (var i = 0; i < remoteCapabilities.codecs.length; i++) { + var rCodec = remoteCapabilities.codecs[i]; + if (lCodec.name.toLowerCase() === rCodec.name.toLowerCase() && + lCodec.clockRate === rCodec.clockRate && + lCodec.numChannels === rCodec.numChannels) { + // push rCodec so we reply with offerer payload type + commonCapabilities.codecs.push(rCodec); + + // FIXME: also need to determine intersection between + // .rtcpFeedback and .parameters + break; + } + } + }); - InputStream.createLiveStream = function (video) { - video.setAttribute("autoplay", true); - var that = InputStream.createVideoStream(video); + localCapabilities.headerExtensions.forEach(function(lHeaderExtension) { + for (var i = 0; i < remoteCapabilities.headerExtensions.length; i++) { + var rHeaderExtension = remoteCapabilities.headerExtensions[i]; + if (lHeaderExtension.uri === rHeaderExtension.uri) { + commonCapabilities.headerExtensions.push(rHeaderExtension); + break; + } + } + }); - that.ended = function () { - return false; + // FIXME: fecMechanisms + return commonCapabilities; }; - return that; - }; - - InputStream.createImageStream = function () { - var that = {}; - var _config = null; - - var width = 0, - height = 0, - frameIdx = 0, - paused = true, - loaded = false, - imgArray = null, - size = 0, - offset = 1, - baseUrl = null, - ended = false, - calculatedWidth, - calculatedHeight, - _eventNames = ['canrecord', 'ended'], - _eventHandlers = {}, - _topRight = { x: 0, y: 0 }, - _canvasSize = { x: 0, y: 0 }; - - function loadImages() { - loaded = false; - _image_loader2['default'].load(baseUrl, function (imgs) { - imgArray = imgs; - width = imgs[0].width; - height = imgs[0].height; - 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; - loaded = true; - frameIdx = 0; - setTimeout(function () { - publishEvent("canrecord", []); - }, 0); - }, offset, size, _config.sequence); - } - - 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); - } + // Create ICE gatherer, ICE transport and DTLS transport. + window.RTCPeerConnection.prototype._createIceAndDtlsTransports = + function(mid, sdpMLineIndex) { + var self = this; + var iceGatherer = new RTCIceGatherer(self.iceOptions); + var iceTransport = new RTCIceTransport(iceGatherer); + iceGatherer.onlocalcandidate = function(evt) { + var event = new Event('icecandidate'); + event.candidate = {sdpMid: mid, sdpMLineIndex: sdpMLineIndex}; + + var cand = evt.candidate; + var end = !cand || Object.keys(cand).length === 0; + // Edge emits an empty object for RTCIceCandidateComplete‥ + if (end) { + // polyfill since RTCIceGatherer.state is not implemented in Edge 10547 yet. + if (iceGatherer.state === undefined) { + iceGatherer.state = 'completed'; + } + + // Emit a candidate with type endOfCandidates to make the samples work. + // Edge requires addIceCandidate with this empty candidate to start checking. + // The real solution is to signal end-of-candidates to the other side when + // getting the null candidate but some apps (like the samples) don't do that. + event.candidate.candidate = + 'candidate:1 1 udp 1 0.0.0.0 9 typ endOfCandidates'; + } else { + // RTCIceCandidate doesn't have a component, needs to be added + cand.component = iceTransport.component === 'RTCP' ? 2 : 1; + event.candidate.candidate = SDPUtils.writeCandidate(cand); } - } - - that.trigger = publishEvent; - - that.getWidth = function () { - return calculatedWidth; - }; - that.getHeight = function () { - return calculatedHeight; + var complete = self.transceivers.every(function(transceiver) { + return transceiver.iceGatherer && + transceiver.iceGatherer.state === 'completed'; + }); + // update .localDescription with candidate and (potentially) end-of-candidates. + // To make this harder, the gatherer might emit candidates before localdescription + // is set. To make things worse, gather.getLocalCandidates still errors in + // Edge 10547 when no candidates have been gathered yet. + if (self.localDescription && self.localDescription.type !== '') { + var sections = SDPUtils.splitSections(self.localDescription.sdp); + sections[sdpMLineIndex + 1] += (!end ? 'a=' + event.candidate.candidate : + 'a=end-of-candidates') + '\r\n'; + self.localDescription.sdp = sections.join(''); + } + + // Emit candidate if localDescription is set. + // Also emits null candidate when all gatherers are complete. + switch(self.iceGatheringState) { + case 'new': + self._localIceCandidatesBuffer.push(event); + if (complete) { + self._localIceCandidatesBuffer.push(new Event('icecandidate')); + } + break; + case 'gathering': + self._emitBufferedCandidates(); + self.dispatchEvent(event); + if (self.onicecandidate !== null) { + self.onicecandidate(event); + } + if (complete) { + self.dispatchEvent(new Event('icecandidate')); + if (self.onicecandidate !== null) { + self.onicecandidate(new Event('icecandidate')); + } + self.iceGatheringState = 'complete'; + } + break; + case 'complete': + // should not happen... currently! + break; + } + }; + iceTransport.onicestatechange = function() { + self._updateConnectionState(); + }; + + var dtlsTransport = new RTCDtlsTransport(iceTransport); + dtlsTransport.ondtlsstatechange = function() { + self._updateConnectionState(); + }; + dtlsTransport.onerror = function() { + // onerror does not set state to failed by itself. + dtlsTransport.state = 'failed'; + self._updateConnectionState(); + }; + + return { + iceGatherer: iceGatherer, + iceTransport: iceTransport, + dtlsTransport: dtlsTransport + }; }; - that.setWidth = function (newWidth) { - calculatedWidth = newWidth; + // Start the RTP Sender and Receiver for a transceiver. + window.RTCPeerConnection.prototype._transceive = function(transceiver, + send, recv) { + var params = this._getCommonCapabilities(transceiver.localCapabilities, + transceiver.remoteCapabilities); + if (send && transceiver.rtpSender) { + params.encodings = [{ + ssrc: transceiver.sendSsrc + }]; + params.rtcp = { + cname: SDPUtils.localCName, + ssrc: transceiver.recvSsrc + }; + transceiver.rtpSender.send(params); + } + if (recv && transceiver.rtpReceiver) { + params.encodings = [{ + ssrc: transceiver.recvSsrc + }]; + params.rtcp = { + cname: transceiver.cname, + ssrc: transceiver.sendSsrc + }; + transceiver.rtpReceiver.receive(params); + } }; - that.setHeight = function (newHeight) { - calculatedHeight = newHeight; - }; + window.RTCPeerConnection.prototype.setLocalDescription = + function(description) { + var self = this; + if (description.type === 'offer') { + if (!this._pendingOffer) { + } else { + this.transceivers = this._pendingOffer; + delete this._pendingOffer; + } + } else if (description.type === 'answer') { + var sections = SDPUtils.splitSections(self.remoteDescription.sdp); + var sessionpart = sections.shift(); + sections.forEach(function(mediaSection, sdpMLineIndex) { + var transceiver = self.transceivers[sdpMLineIndex]; + var iceGatherer = transceiver.iceGatherer; + var iceTransport = transceiver.iceTransport; + var dtlsTransport = transceiver.dtlsTransport; + var localCapabilities = transceiver.localCapabilities; + var remoteCapabilities = transceiver.remoteCapabilities; + var rejected = mediaSection.split('\n', 1)[0] + .split(' ', 2)[1] === '0'; + + if (!rejected) { + var remoteIceParameters = SDPUtils.getIceParameters(mediaSection, + sessionpart); + iceTransport.start(iceGatherer, remoteIceParameters, 'controlled'); + + var remoteDtlsParameters = SDPUtils.getDtlsParameters(mediaSection, + sessionpart); + dtlsTransport.start(remoteDtlsParameters); + + // Calculate intersection of capabilities. + var params = self._getCommonCapabilities(localCapabilities, + remoteCapabilities); + + // Start the RTCRtpSender. The RTCRtpReceiver for this transceiver + // has already been started in setRemoteDescription. + self._transceive(transceiver, + params.codecs.length > 0, + false); + } + }); + } - that.getRealWidth = function () { - return width; - }; + this.localDescription = { + type: description.type, + sdp: description.sdp + }; + switch (description.type) { + case 'offer': + this._updateSignalingState('have-local-offer'); + break; + case 'answer': + this._updateSignalingState('stable'); + break; + default: + throw new TypeError('unsupported type "' + description.type + '"'); + } - that.getRealHeight = function () { - return height; + // If a success callback was provided, emit ICE candidates after it has been + // executed. Otherwise, emit callback after the Promise is resolved. + var hasCallback = arguments.length > 1 && + typeof arguments[1] === 'function'; + if (hasCallback) { + var cb = arguments[1]; + window.setTimeout(function() { + cb(); + if (self.iceGatheringState === 'new') { + self.iceGatheringState = 'gathering'; + } + self._emitBufferedCandidates(); + }, 0); + } + var p = Promise.resolve(); + p.then(function() { + if (!hasCallback) { + if (self.iceGatheringState === 'new') { + self.iceGatheringState = 'gathering'; + } + // Usually candidates will be emitted earlier. + window.setTimeout(self._emitBufferedCandidates.bind(self), 500); + } + }); + return p; }; - that.setInputStream = function (stream) { - _config = stream; - if (stream.sequence === false) { - baseUrl = stream.src; - size = 1; - } else { - baseUrl = stream.src; - size = stream.length; - } - loadImages(); + window.RTCPeerConnection.prototype.setRemoteDescription = + function(description) { + var self = this; + var stream = new MediaStream(); + var receiverList = []; + var sections = SDPUtils.splitSections(description.sdp); + var sessionpart = sections.shift(); + sections.forEach(function(mediaSection, sdpMLineIndex) { + var lines = SDPUtils.splitLines(mediaSection); + var mline = lines[0].substr(2).split(' '); + var kind = mline[0]; + var rejected = mline[1] === '0'; + var direction = SDPUtils.getDirection(mediaSection, sessionpart); + + var transceiver; + var iceGatherer; + var iceTransport; + var dtlsTransport; + var rtpSender; + var rtpReceiver; + var sendSsrc; + var recvSsrc; + var localCapabilities; + + var track; + // FIXME: ensure the mediaSection has rtcp-mux set. + var remoteCapabilities = SDPUtils.parseRtpParameters(mediaSection); + var remoteIceParameters; + var remoteDtlsParameters; + if (!rejected) { + remoteIceParameters = SDPUtils.getIceParameters(mediaSection, + sessionpart); + remoteDtlsParameters = SDPUtils.getDtlsParameters(mediaSection, + sessionpart); + } + var mid = SDPUtils.matchPrefix(mediaSection, 'a=mid:')[0].substr(6); + + var cname; + // Gets the first SSRC. Note that with RTX there might be multiple SSRCs. + var remoteSsrc = SDPUtils.matchPrefix(mediaSection, 'a=ssrc:') + .map(function(line) { + return SDPUtils.parseSsrcMedia(line); + }) + .filter(function(obj) { + return obj.attribute === 'cname'; + })[0]; + if (remoteSsrc) { + recvSsrc = parseInt(remoteSsrc.ssrc, 10); + cname = remoteSsrc.value; + } + + if (description.type === 'offer') { + var transports = self._createIceAndDtlsTransports(mid, sdpMLineIndex); + + localCapabilities = RTCRtpReceiver.getCapabilities(kind); + sendSsrc = (2 * sdpMLineIndex + 2) * 1001; + + rtpReceiver = new RTCRtpReceiver(transports.dtlsTransport, kind); + + track = rtpReceiver.track; + receiverList.push([track, rtpReceiver]); + // FIXME: not correct when there are multiple streams but that is + // not currently supported in this shim. + stream.addTrack(track); + + // FIXME: look at direction. + if (self.localStreams.length > 0 && + self.localStreams[0].getTracks().length >= sdpMLineIndex) { + // FIXME: actually more complicated, needs to match types etc + var localtrack = self.localStreams[0].getTracks()[sdpMLineIndex]; + rtpSender = new RTCRtpSender(localtrack, transports.dtlsTransport); + } + + self.transceivers[sdpMLineIndex] = { + iceGatherer: transports.iceGatherer, + iceTransport: transports.iceTransport, + dtlsTransport: transports.dtlsTransport, + localCapabilities: localCapabilities, + remoteCapabilities: remoteCapabilities, + rtpSender: rtpSender, + rtpReceiver: rtpReceiver, + kind: kind, + mid: mid, + cname: cname, + sendSsrc: sendSsrc, + recvSsrc: recvSsrc + }; + // Start the RTCRtpReceiver now. The RTPSender is started in setLocalDescription. + self._transceive(self.transceivers[sdpMLineIndex], + false, + direction === 'sendrecv' || direction === 'sendonly'); + } else if (description.type === 'answer' && !rejected) { + transceiver = self.transceivers[sdpMLineIndex]; + iceGatherer = transceiver.iceGatherer; + iceTransport = transceiver.iceTransport; + dtlsTransport = transceiver.dtlsTransport; + rtpSender = transceiver.rtpSender; + rtpReceiver = transceiver.rtpReceiver; + sendSsrc = transceiver.sendSsrc; + //recvSsrc = transceiver.recvSsrc; + localCapabilities = transceiver.localCapabilities; + + self.transceivers[sdpMLineIndex].recvSsrc = recvSsrc; + self.transceivers[sdpMLineIndex].remoteCapabilities = + remoteCapabilities; + self.transceivers[sdpMLineIndex].cname = cname; + + iceTransport.start(iceGatherer, remoteIceParameters, 'controlling'); + dtlsTransport.start(remoteDtlsParameters); + + self._transceive(transceiver, + direction === 'sendrecv' || direction === 'recvonly', + direction === 'sendrecv' || direction === 'sendonly'); + + if (rtpReceiver && + (direction === 'sendrecv' || direction === 'sendonly')) { + track = rtpReceiver.track; + receiverList.push([track, rtpReceiver]); + stream.addTrack(track); + } else { + // FIXME: actually the receiver should be created later. + delete transceiver.rtpReceiver; + } + } + }); + + this.remoteDescription = { + type: description.type, + sdp: description.sdp + }; + switch (description.type) { + case 'offer': + this._updateSignalingState('have-remote-offer'); + break; + case 'answer': + this._updateSignalingState('stable'); + break; + default: + throw new TypeError('unsupported type "' + description.type + '"'); + } + if (stream.getTracks().length) { + self.remoteStreams.push(stream); + window.setTimeout(function() { + var event = new Event('addstream'); + event.stream = stream; + self.dispatchEvent(event); + if (self.onaddstream !== null) { + window.setTimeout(function() { + self.onaddstream(event); + }, 0); + } + + receiverList.forEach(function(item) { + var track = item[0]; + var receiver = item[1]; + var event = new Event('track'); + event.track = track; + event.receiver = receiver; + event.streams = [stream]; + self.dispatchEvent(event); + if (self.ontrack !== null) { + window.setTimeout(function() { + self.ontrack(event); + }, 0); + } + }); + }, 0); + } + if (arguments.length > 1 && typeof arguments[1] === 'function') { + window.setTimeout(arguments[1], 0); + } + return Promise.resolve(); }; - that.ended = function () { - return ended; + window.RTCPeerConnection.prototype.close = function() { + this.transceivers.forEach(function(transceiver) { + /* not yet + if (transceiver.iceGatherer) { + transceiver.iceGatherer.close(); + } + */ + if (transceiver.iceTransport) { + transceiver.iceTransport.stop(); + } + if (transceiver.dtlsTransport) { + transceiver.dtlsTransport.stop(); + } + if (transceiver.rtpSender) { + transceiver.rtpSender.stop(); + } + if (transceiver.rtpReceiver) { + transceiver.rtpReceiver.stop(); + } + }); + // FIXME: clean up tracks, local streams, remote streams, etc + this._updateSignalingState('closed'); }; - that.setAttribute = function () {}; - - that.getConfig = function () { - return _config; + // Update the signaling state. + window.RTCPeerConnection.prototype._updateSignalingState = + function(newState) { + this.signalingState = newState; + var event = new Event('signalingstatechange'); + this.dispatchEvent(event); + if (this.onsignalingstatechange !== null) { + this.onsignalingstatechange(event); + } }; - that.pause = function () { - paused = true; + // Determine whether to fire the negotiationneeded event. + window.RTCPeerConnection.prototype._maybeFireNegotiationNeeded = + function() { + // Fire away (for now). + var event = new Event('negotiationneeded'); + this.dispatchEvent(event); + if (this.onnegotiationneeded !== null) { + this.onnegotiationneeded(event); + } }; - that.play = function () { - paused = false; - }; + // Update the connection state. + window.RTCPeerConnection.prototype._updateConnectionState = + function() { + var self = this; + var newState; + var states = { + 'new': 0, + closed: 0, + connecting: 0, + checking: 0, + connected: 0, + completed: 0, + failed: 0 + }; + this.transceivers.forEach(function(transceiver) { + states[transceiver.iceTransport.state]++; + states[transceiver.dtlsTransport.state]++; + }); + // ICETransport.completed and connected are the same for this purpose. + states['connected'] += states['completed']; + + newState = 'new'; + if (states['failed'] > 0) { + newState = 'failed'; + } else if (states['connecting'] > 0 || states['checking'] > 0) { + newState = 'connecting'; + } else if (states['disconnected'] > 0) { + newState = 'disconnected'; + } else if (states['new'] > 0) { + newState = 'new'; + } else if (states['connecting'] > 0 || states['completed'] > 0) { + newState = 'connected'; + } - that.setCurrentTime = function (time) { - frameIdx = time; + if (newState !== self.iceConnectionState) { + self.iceConnectionState = newState; + var event = new Event('iceconnectionstatechange'); + this.dispatchEvent(event); + if (this.oniceconnectionstatechange !== null) { + this.oniceconnectionstatechange(event); + } + } }; - that.addEventListener = function (event, f) { - if (_eventNames.indexOf(event) !== -1) { - if (!_eventHandlers[event]) { - _eventHandlers[event] = []; - } - _eventHandlers[event].push(f); + window.RTCPeerConnection.prototype.createOffer = function() { + var self = this; + if (this._pendingOffer) { + throw new Error('createOffer called while there is a pending offer.'); + } + var offerOptions; + if (arguments.length === 1 && typeof arguments[0] !== 'function') { + offerOptions = arguments[0]; + } else if (arguments.length === 3) { + offerOptions = arguments[2]; + } + + var tracks = []; + var numAudioTracks = 0; + var numVideoTracks = 0; + // Default to sendrecv. + if (this.localStreams.length) { + numAudioTracks = this.localStreams[0].getAudioTracks().length; + numVideoTracks = this.localStreams[0].getVideoTracks().length; + } + // Determine number of audio and video tracks we need to send/recv. + if (offerOptions) { + // Reject Chrome legacy constraints. + if (offerOptions.mandatory || offerOptions.optional) { + throw new TypeError( + 'Legacy mandatory/optional constraints not supported.'); } - }; + if (offerOptions.offerToReceiveAudio !== undefined) { + numAudioTracks = offerOptions.offerToReceiveAudio; + } + if (offerOptions.offerToReceiveVideo !== undefined) { + numVideoTracks = offerOptions.offerToReceiveVideo; + } + } + if (this.localStreams.length) { + // Push local streams. + this.localStreams[0].getTracks().forEach(function(track) { + tracks.push({ + kind: track.kind, + track: track, + wantReceive: track.kind === 'audio' ? + numAudioTracks > 0 : numVideoTracks > 0 + }); + if (track.kind === 'audio') { + numAudioTracks--; + } else if (track.kind === 'video') { + numVideoTracks--; + } + }); + } + // Create M-lines for recvonly streams. + while (numAudioTracks > 0 || numVideoTracks > 0) { + if (numAudioTracks > 0) { + tracks.push({ + kind: 'audio', + wantReceive: true + }); + numAudioTracks--; + } + if (numVideoTracks > 0) { + tracks.push({ + kind: 'video', + wantReceive: true + }); + numVideoTracks--; + } + } - that.setTopRight = function (topRight) { - _topRight.x = topRight.x; - _topRight.y = topRight.y; + var sdp = SDPUtils.writeSessionBoilerplate(); + var transceivers = []; + tracks.forEach(function(mline, sdpMLineIndex) { + // For each track, create an ice gatherer, ice transport, dtls transport, + // potentially rtpsender and rtpreceiver. + var track = mline.track; + var kind = mline.kind; + var mid = SDPUtils.generateIdentifier(); + + var transports = self._createIceAndDtlsTransports(mid, sdpMLineIndex); + + var localCapabilities = RTCRtpSender.getCapabilities(kind); + var rtpSender; + var rtpReceiver; + + // generate an ssrc now, to be used later in rtpSender.send + var sendSsrc = (2 * sdpMLineIndex + 1) * 1001; + if (track) { + rtpSender = new RTCRtpSender(track, transports.dtlsTransport); + } + + if (mline.wantReceive) { + rtpReceiver = new RTCRtpReceiver(transports.dtlsTransport, kind); + } + + transceivers[sdpMLineIndex] = { + iceGatherer: transports.iceGatherer, + iceTransport: transports.iceTransport, + dtlsTransport: transports.dtlsTransport, + localCapabilities: localCapabilities, + remoteCapabilities: null, + rtpSender: rtpSender, + rtpReceiver: rtpReceiver, + kind: kind, + mid: mid, + sendSsrc: sendSsrc, + recvSsrc: null + }; + var transceiver = transceivers[sdpMLineIndex]; + sdp += SDPUtils.writeMediaSection(transceiver, + transceiver.localCapabilities, 'offer', self.localStreams[0]); + }); + + this._pendingOffer = transceivers; + var desc = new RTCSessionDescription({ + type: 'offer', + sdp: sdp + }); + if (arguments.length && typeof arguments[0] === 'function') { + window.setTimeout(arguments[0], 0, desc); + } + return Promise.resolve(desc); }; - that.getTopRight = function () { - return _topRight; + window.RTCPeerConnection.prototype.createAnswer = function() { + var self = this; + var answerOptions; + if (arguments.length === 1 && typeof arguments[0] !== 'function') { + answerOptions = arguments[0]; + } else if (arguments.length === 3) { + answerOptions = arguments[2]; + } + + var sdp = SDPUtils.writeSessionBoilerplate(); + this.transceivers.forEach(function(transceiver) { + // Calculate intersection of capabilities. + var commonCapabilities = self._getCommonCapabilities( + transceiver.localCapabilities, + transceiver.remoteCapabilities); + + sdp += SDPUtils.writeMediaSection(transceiver, commonCapabilities, + 'answer', self.localStreams[0]); + }); + + var desc = new RTCSessionDescription({ + type: 'answer', + sdp: sdp + }); + if (arguments.length && typeof arguments[0] === 'function') { + window.setTimeout(arguments[0], 0, desc); + } + return Promise.resolve(desc); }; - that.setCanvasSize = function (canvasSize) { - _canvasSize.x = canvasSize.x; - _canvasSize.y = canvasSize.y; + window.RTCPeerConnection.prototype.addIceCandidate = function(candidate) { + var mLineIndex = candidate.sdpMLineIndex; + if (candidate.sdpMid) { + for (var i = 0; i < this.transceivers.length; i++) { + if (this.transceivers[i].mid === candidate.sdpMid) { + mLineIndex = i; + break; + } + } + } + var transceiver = this.transceivers[mLineIndex]; + if (transceiver) { + var cand = Object.keys(candidate.candidate).length > 0 ? + SDPUtils.parseCandidate(candidate.candidate) : {}; + // Ignore Chrome's invalid candidates since Edge does not like them. + if (cand.protocol === 'tcp' && cand.port === 0) { + return; + } + // Ignore RTCP candidates, we assume RTCP-MUX. + if (cand.component !== '1') { + return; + } + // A dirty hack to make samples work. + if (cand.type === 'endOfCandidates') { + cand = {}; + } + transceiver.iceTransport.addRemoteCandidate(cand); + + // update the remoteDescription. + var sections = SDPUtils.splitSections(this.remoteDescription.sdp); + sections[mLineIndex + 1] += (cand.type ? candidate.candidate.trim() + : 'a=end-of-candidates') + '\r\n'; + this.remoteDescription.sdp = sections.join(''); + } + if (arguments.length > 1 && typeof arguments[1] === 'function') { + window.setTimeout(arguments[1], 0); + } + return Promise.resolve(); }; - that.getCanvasSize = function () { - return _canvasSize; + window.RTCPeerConnection.prototype.getStats = function() { + var promises = []; + this.transceivers.forEach(function(transceiver) { + ['rtpSender', 'rtpReceiver', 'iceGatherer', 'iceTransport', + 'dtlsTransport'].forEach(function(method) { + if (transceiver[method]) { + promises.push(transceiver[method].getStats()); + } + }); + }); + var cb = arguments.length > 1 && typeof arguments[1] === 'function' && + arguments[1]; + return new Promise(function(resolve) { + var results = {}; + Promise.all(promises).then(function(res) { + res.forEach(function(result) { + Object.keys(result).forEach(function(id) { + results[id] = result[id]; + }); + }); + if (cb) { + window.setTimeout(cb, 0, results); + } + resolve(results); + }); + }); }; + }, - that.getFrame = function () { - var frame; + // Attach a media stream to an element. + attachMediaStream: function(element, stream) { + logging('DEPRECATED, attachMediaStream will soon be removed.'); + element.srcObject = stream; + }, - if (!loaded) { - return null; - } - if (!paused) { - frame = imgArray[frameIdx]; - if (frameIdx < size - 1) { - frameIdx++; - } else { - setTimeout(function () { - ended = true; - publishEvent("ended", []); - }, 0); - } - } - return frame; - }; + reattachMediaStream: function(to, from) { + logging('DEPRECATED, reattachMediaStream will soon be removed.'); + to.srcObject = from.srcObject; + } + } - return that; - }; + // Expose public methods. + module.e = { + shimPeerConnection: edgeShim.shimPeerConnection, + attachMediaStream: edgeShim.attachMediaStream, + reattachMediaStream: edgeShim.reattachMediaStream + } - exports['default'] = InputStream; - module.exports = exports['default']; + /***/ }, -/* 74 */ +/* 152 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - var ImageLoader = {}; - ImageLoader.load = function (directory, callback, offset, size, sequence) { - var htmlImagesSrcArray = new Array(size), - htmlImagesArray = new Array(htmlImagesSrcArray.length), - i, - img, - num; + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ + 'use strict'; - if (sequence === false) { - htmlImagesSrcArray[0] = directory; - } else { - for (i = 0; i < htmlImagesSrcArray.length; i++) { - num = offset + i; - htmlImagesSrcArray[i] = directory + "image-" + ("00" + num).slice(-3) + ".jpg"; - } + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; + + var firefoxShim = { + shimOnTrack: function() { + if (typeof window === 'object' && window.RTCPeerConnection && !('ontrack' in + window.RTCPeerConnection.prototype)) { + Object.defineProperty(window.RTCPeerConnection.prototype, 'ontrack', { + get: function() { return this._ontrack; }, + set: function(f) { + var self = this; + if (this._ontrack) { + this.removeEventListener('track', this._ontrack); + this.removeEventListener('addstream', this._ontrackpoly); + } + this.addEventListener('track', this._ontrack = f); + this.addEventListener('addstream', this._ontrackpoly = function(e) { + e.stream.getTracks().forEach(function(track) { + var event = new Event('track'); + event.track = track; + event.receiver = {track: track}; + event.streams = [e.stream]; + this.dispatchEvent(event); + }.bind(this)); + }.bind(this)); + } + }); + } + }, + + shimSourceObject: function() { + // Firefox has supported mozSrcObject since FF22, unprefixed in 42. + if (typeof window === 'object') { + if (window.HTMLMediaElement && + !('srcObject' in window.HTMLMediaElement.prototype)) { + // Shim the srcObject property, once, when HTMLMediaElement is found. + Object.defineProperty(window.HTMLMediaElement.prototype, 'srcObject', { + get: function() { + return this.mozSrcObject; + }, + set: function(stream) { + this.mozSrcObject = stream; + } + }); + } } - htmlImagesArray.notLoaded = []; - htmlImagesArray.addImage = function (image) { - htmlImagesArray.notLoaded.push(image); - }; - htmlImagesArray.loaded = function (loadedImg) { - var notloadedImgs = htmlImagesArray.notLoaded; - for (var x = 0; x < notloadedImgs.length; x++) { - if (notloadedImgs[x] === loadedImg) { - notloadedImgs.splice(x, 1); - for (var y = 0; y < htmlImagesSrcArray.length; y++) { - var imgName = htmlImagesSrcArray[y].substr(htmlImagesSrcArray[y].lastIndexOf("/")); - if (loadedImg.src.lastIndexOf(imgName) !== -1) { - htmlImagesArray[y] = loadedImg; - break; - } + }, + + shimPeerConnection: function() { + // The RTCPeerConnection object. + if (!window.RTCPeerConnection) { + window.RTCPeerConnection = function(pcConfig, pcConstraints) { + if (browserDetails.version < 38) { + // .urls is not supported in FF < 38. + // create RTCIceServers with a single url. + if (pcConfig && pcConfig.iceServers) { + var newIceServers = []; + for (var i = 0; i < pcConfig.iceServers.length; i++) { + var server = pcConfig.iceServers[i]; + if (server.hasOwnProperty('urls')) { + for (var j = 0; j < server.urls.length; j++) { + var newServer = { + url: server.urls[j] + }; + if (server.urls[j].indexOf('turn') === 0) { + newServer.username = server.username; + newServer.credential = server.credential; + } + newIceServers.push(newServer); } - break; + } else { + newIceServers.push(pcConfig.iceServers[i]); + } + } + pcConfig.iceServers = newIceServers; + } + } + return new mozRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors + }; + window.RTCPeerConnection.prototype = mozRTCPeerConnection.prototype; + + // wrap static methods. Currently just generateCertificate. + if (mozRTCPeerConnection.generateCertificate) { + Object.defineProperty(window.RTCPeerConnection, 'generateCertificate', { + get: function() { + if (arguments.length) { + return mozRTCPeerConnection.generateCertificate.apply(null, + arguments); + } else { + return mozRTCPeerConnection.generateCertificate; } + } + }); + } + + window.RTCSessionDescription = mozRTCSessionDescription; + window.RTCIceCandidate = mozRTCIceCandidate; + } + }, + + shimGetUserMedia: function() { + // getUserMedia constraints shim. + var getUserMedia_ = function(constraints, onSuccess, onError) { + var constraintsToFF37_ = function(c) { + if (typeof c !== 'object' || c.require) { + return c; } - if (notloadedImgs.length === 0) { - if (true) { - console.log("Images loaded"); + var require = []; + Object.keys(c).forEach(function(key) { + if (key === 'require' || key === 'advanced' || key === 'mediaSource') { + return; + } + var r = c[key] = (typeof c[key] === 'object') ? + c[key] : {ideal: c[key]}; + if (r.min !== undefined || + r.max !== undefined || r.exact !== undefined) { + require.push(key); + } + if (r.exact !== undefined) { + if (typeof r.exact === 'number') { + r. min = r.max = r.exact; + } else { + c[key] = r.exact; } - callback.apply(null, [htmlImagesArray]); + delete r.exact; + } + if (r.ideal !== undefined) { + c.advanced = c.advanced || []; + var oc = {}; + if (typeof r.ideal === 'number') { + oc[key] = {min: r.ideal, max: r.ideal}; + } else { + oc[key] = r.ideal; + } + c.advanced.push(oc); + delete r.ideal; + if (!Object.keys(r).length) { + delete c[key]; + } + } + }); + if (require.length) { + c.require = require; + } + return c; + }; + if (browserDetails.version < 38) { + logging('spec: ' + JSON.stringify(constraints)); + if (constraints.audio) { + constraints.audio = constraintsToFF37_(constraints.audio); } + if (constraints.video) { + constraints.video = constraintsToFF37_(constraints.video); + } + logging('ff37: ' + JSON.stringify(constraints)); + } + return navigator.mozGetUserMedia(constraints, onSuccess, onError); }; - for (i = 0; i < htmlImagesSrcArray.length; i++) { - img = new Image(); - htmlImagesArray.addImage(img); - addOnloadHandler(img, htmlImagesArray); - img.src = htmlImagesSrcArray[i]; + navigator.getUserMedia = getUserMedia_; + + // Returns the result of getUserMedia as a Promise. + var getUserMediaPromise_ = function(constraints) { + return new Promise(function(resolve, reject) { + navigator.getUserMedia(constraints, resolve, reject); + }); + } + + // Shim for mediaDevices on older versions. + if (!navigator.mediaDevices) { + navigator.mediaDevices = {getUserMedia: getUserMediaPromise_, + addEventListener: function() { }, + removeEventListener: function() { } + }; + } + navigator.mediaDevices.enumerateDevices = + navigator.mediaDevices.enumerateDevices || function() { + return new Promise(function(resolve) { + var infos = [ + {kind: 'audioinput', deviceId: 'default', label: '', groupId: ''}, + {kind: 'videoinput', deviceId: 'default', label: '', groupId: ''} + ]; + resolve(infos); + }); + }; + + if (browserDetails.version < 41) { + // Work around http://bugzil.la/1169665 + var orgEnumerateDevices = + navigator.mediaDevices.enumerateDevices.bind(navigator.mediaDevices); + navigator.mediaDevices.enumerateDevices = function() { + return orgEnumerateDevices().then(undefined, function(e) { + if (e.name === 'NotFoundError') { + return []; + } + throw e; + }); + }; } - }; + }, - function addOnloadHandler(img, htmlImagesArray) { - img.onload = function () { - htmlImagesArray.loaded(this); - }; + // Attach a media stream to an element. + attachMediaStream: function(element, stream) { + logging('DEPRECATED, attachMediaStream will soon be removed.'); + element.srcObject = stream; + }, + + reattachMediaStream: function(to, from) { + logging('DEPRECATED, reattachMediaStream will soon be removed.'); + to.srcObject = from.srcObject; + } } - exports["default"] = ImageLoader; - module.exports = exports["default"]; + // Expose public methods. + module.e = { + shimOnTrack: firefoxShim.shimOnTrack, + shimSourceObject: firefoxShim.shimSourceObject, + shimPeerConnection: firefoxShim.shimPeerConnection, + shimGetUserMedia: __webpack_require__(153), + attachMediaStream: firefoxShim.attachMediaStream, + reattachMediaStream: firefoxShim.reattachMediaStream + } + /***/ }, -/* 75 */ +/* 153 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } - - var _commonCv_utils = __webpack_require__(5); - - var _commonCv_utils2 = _interopRequireDefault(_commonCv_utils); - - var FrameGrabber = {}; + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ + 'use strict'; - FrameGrabber.create = function (inputStream, canvas) { - var _that = {}, - _streamConfig = inputStream.getConfig(), - _video_size = _commonCv_utils2["default"].imageRef(inputStream.getRealWidth(), inputStream.getRealHeight()), - _canvasSize = inputStream.getCanvasSize(), - _size = _commonCv_utils2["default"].imageRef(inputStream.getWidth(), inputStream.getHeight()), - topRight = inputStream.getTopRight(), - _sx = topRight.x, - _sy = topRight.y, - _canvas, - _ctx = null, - _data = null; + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; - _canvas = canvas ? canvas : document.createElement("canvas"); - _canvas.width = _canvasSize.x; - _canvas.height = _canvasSize.y; - _ctx = _canvas.getContext("2d"); - _data = new Uint8Array(_size.x * _size.y); - if (true) { - console.log("FrameGrabber", JSON.stringify({ - size: _size, - topRight: topRight, - videoSize: _video_size, - canvasSize: _canvasSize - })); + // Expose public methods. + module.e = function() { + // getUserMedia constraints shim. + var getUserMedia_ = function(constraints, onSuccess, onError) { + var constraintsToFF37_ = function(c) { + if (typeof c !== 'object' || c.require) { + return c; + } + var require = []; + Object.keys(c).forEach(function(key) { + if (key === 'require' || key === 'advanced' || key === 'mediaSource') { + return; + } + var r = c[key] = (typeof c[key] === 'object') ? + c[key] : {ideal: c[key]}; + if (r.min !== undefined || + r.max !== undefined || r.exact !== undefined) { + require.push(key); + } + if (r.exact !== undefined) { + if (typeof r.exact === 'number') { + r. min = r.max = r.exact; + } else { + c[key] = r.exact; + } + delete r.exact; + } + if (r.ideal !== undefined) { + c.advanced = c.advanced || []; + var oc = {}; + if (typeof r.ideal === 'number') { + oc[key] = {min: r.ideal, max: r.ideal}; + } else { + oc[key] = r.ideal; + } + c.advanced.push(oc); + delete r.ideal; + if (!Object.keys(r).length) { + delete c[key]; + } + } + }); + if (require.length) { + c.require = require; + } + return c; + }; + if (browserDetails.version < 38) { + logging('spec: ' + JSON.stringify(constraints)); + if (constraints.audio) { + constraints.audio = constraintsToFF37_(constraints.audio); + } + if (constraints.video) { + constraints.video = constraintsToFF37_(constraints.video); + } + logging('ff37: ' + JSON.stringify(constraints)); } + return navigator.mozGetUserMedia(constraints, onSuccess, onError); + }; - /** - * Uses the given array as frame-buffer - */ - _that.attachData = function (data) { - _data = data; - }; + navigator.getUserMedia = getUserMedia_; - /** - * Returns the used frame-buffer - */ - _that.getData = function () { - return _data; - }; + // Returns the result of getUserMedia as a Promise. + var getUserMediaPromise_ = function(constraints) { + return new Promise(function(resolve, reject) { + navigator.getUserMedia(constraints, resolve, reject); + }); + } - /** - * Fetches a frame from the input-stream and puts into the frame-buffer. - * The image-data is converted to gray-scale and then half-sampled if configured. - */ - _that.grab = function () { - var doHalfSample = _streamConfig.halfSample, - frame = inputStream.getFrame(), - ctxData; - if (frame) { - _ctx.drawImage(frame, 0, 0, _canvasSize.x, _canvasSize.y); - ctxData = _ctx.getImageData(_sx, _sy, _size.x, _size.y).data; - if (doHalfSample) { - _commonCv_utils2["default"].grayAndHalfSampleFromCanvasData(ctxData, _size, _data); - } else { - _commonCv_utils2["default"].computeGray(ctxData, _data, _streamConfig); - } - return true; - } else { - return false; - } + // Shim for mediaDevices on older versions. + if (!navigator.mediaDevices) { + navigator.mediaDevices = {getUserMedia: getUserMediaPromise_, + addEventListener: function() { }, + removeEventListener: function() { } }; + } + navigator.mediaDevices.enumerateDevices = + navigator.mediaDevices.enumerateDevices || function() { + return new Promise(function(resolve) { + var infos = [ + {kind: 'audioinput', deviceId: 'default', label: '', groupId: ''}, + {kind: 'videoinput', deviceId: 'default', label: '', groupId: ''} + ]; + resolve(infos); + }); + }; - _that.getSize = function () { - return _size; + if (browserDetails.version < 41) { + // Work around http://bugzil.la/1169665 + var orgEnumerateDevices = + navigator.mediaDevices.enumerateDevices.bind(navigator.mediaDevices); + navigator.mediaDevices.enumerateDevices = function() { + return orgEnumerateDevices().then(undefined, function(e) { + if (e.name === 'NotFoundError') { + return []; + } + throw e; + }); }; - - return _that; - }; - - exports["default"] = FrameGrabber; - module.exports = exports["default"]; + } + } + + +/***/ }, +/* 154 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = __webpack_require__(49); + /***/ } /******/ ]) }); ; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///webpack/myModuleDefinition","webpack:///webpack/bootstrap e5b729d508479e63bf1d","webpack:///D:/work/quaggaJS/src/quagga.js","webpack:///D:/work/quaggaJS/src/common/typedefs.js","webpack:///D:/work/quaggaJS/src/common/image_wrapper.js","webpack:///D:/work/quaggaJS/src/common/subImage.js","webpack:///D:/work/quaggaJS/src/common/cv_utils.js","webpack:///D:/work/quaggaJS/src/common/cluster.js","webpack:///./~/gl-matrix/src/gl-matrix.js","webpack:///./~/gl-matrix/src/gl-matrix/common.js","webpack:///./~/gl-matrix/src/gl-matrix/mat2.js","webpack:///./~/gl-matrix/src/gl-matrix/mat2d.js","webpack:///./~/gl-matrix/src/gl-matrix/mat3.js","webpack:///./~/gl-matrix/src/gl-matrix/mat4.js","webpack:///./~/gl-matrix/src/gl-matrix/quat.js","webpack:///./~/gl-matrix/src/gl-matrix/vec3.js","webpack:///./~/gl-matrix/src/gl-matrix/vec4.js","webpack:///./~/gl-matrix/src/gl-matrix/vec2.js","webpack:///D:/work/quaggaJS/src/common/array_helper.js","webpack:///D:/work/quaggaJS/src/locator/barcode_locator.js","webpack:///D:/work/quaggaJS/src/common/image_debug.js","webpack:///D:/work/quaggaJS/src/locator/rasterizer.js","webpack:///D:/work/quaggaJS/src/locator/tracer.js","webpack:///D:/work/quaggaJS/src/locator/skeletonizer.js","webpack:///D:/work/quaggaJS/src/decoder/barcode_decoder.js","webpack:///D:/work/quaggaJS/src/decoder/bresenham.js","webpack:///D:/work/quaggaJS/src/reader/code_128_reader.js","webpack:///D:/work/quaggaJS/src/reader/barcode_reader.js","webpack:///D:/work/quaggaJS/src/reader/ean_reader.js","webpack:///D:/work/quaggaJS/src/reader/code_39_reader.js","webpack:///D:/work/quaggaJS/src/reader/code_39_vin_reader.js","webpack:///D:/work/quaggaJS/src/reader/codabar_reader.js","webpack:///D:/work/quaggaJS/src/reader/upc_reader.js","webpack:///D:/work/quaggaJS/src/reader/ean_8_reader.js","webpack:///D:/work/quaggaJS/src/reader/upc_e_reader.js","webpack:///D:/work/quaggaJS/src/reader/i2of5_reader.js","webpack:///./~/lodash/object/merge.js","webpack:///./~/lodash/internal/baseMerge.js","webpack:///./~/lodash/internal/arrayEach.js","webpack:///./~/lodash/internal/baseMergeDeep.js","webpack:///./~/lodash/internal/arrayCopy.js","webpack:///./~/lodash/lang/isArguments.js","webpack:///./~/lodash/internal/isArrayLike.js","webpack:///./~/lodash/internal/getLength.js","webpack:///./~/lodash/internal/baseProperty.js","webpack:///./~/lodash/internal/isLength.js","webpack:///./~/lodash/internal/isObjectLike.js","webpack:///./~/lodash/lang/isArray.js","webpack:///./~/lodash/internal/getNative.js","webpack:///./~/lodash/lang/isNative.js","webpack:///./~/lodash/lang/isFunction.js","webpack:///./~/lodash/lang/isObject.js","webpack:///./~/lodash/lang/isPlainObject.js","webpack:///./~/lodash/internal/baseForIn.js","webpack:///./~/lodash/internal/baseFor.js","webpack:///./~/lodash/internal/createBaseFor.js","webpack:///./~/lodash/internal/toObject.js","webpack:///./~/lodash/object/keysIn.js","webpack:///./~/lodash/internal/isIndex.js","webpack:///./~/lodash/lang/isTypedArray.js","webpack:///./~/lodash/lang/toPlainObject.js","webpack:///./~/lodash/internal/baseCopy.js","webpack:///./~/lodash/object/keys.js","webpack:///./~/lodash/internal/shimKeys.js","webpack:///./~/lodash/internal/createAssigner.js","webpack:///./~/lodash/internal/bindCallback.js","webpack:///./~/lodash/utility/identity.js","webpack:///./~/lodash/internal/isIterateeCall.js","webpack:///./~/lodash/function/restParam.js","webpack:///D:/work/quaggaJS/src/common/events.js","webpack:///D:/work/quaggaJS/src/input/camera_access.js","webpack:///D:/work/quaggaJS/src/analytics/result_collector.js","webpack:///D:/work/quaggaJS/src/config/config.js","webpack:///D:/work/quaggaJS/src/config/config.dev.js","webpack:///D:/work/quaggaJS/src/input/input_stream.js","webpack:///D:/work/quaggaJS/src/input/image_loader.js","webpack:///D:/work/quaggaJS/src/input/frame_grabber.js"],"names":[],"mappings":"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AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB;;AAEA,mC;AACA,sB;AACA,iB;AACA,iB;AACA,+B;AACA,sB;AACA,G;;;AAGA;;;;;;;AC7SA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,YAAW,KAAK;AAChB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,YAAW,KAAK;AAChB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,KAAK;AAChB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,KAAK;AAChB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,cAAa,OAAO;AACpB;AACA,4B;AACA;AACA,G;;AAEA;;;;;;;AC5TA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,gB;AACA,qB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,MAAM;AACjB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAU,KAAK;AACf,WAAU,KAAK;AACf;AACA,aAAY,KAAK;AACjB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,WAAU,KAAK;AACf,WAAU,KAAK;AACf;AACA,aAAY,KAAK;AACjB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,gB;AACA,qB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;;AAGA;;;;;;;ACpjBA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,gB;AACA,qB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qD;AACA;AACA;AACA;AACA;;AAEA,eAAc,WAAW,WAAW;AACpC;AACA;AACA;AACA;;AAEA,eAAc,WAAW,YAAY;AACrC;AACA;AACA;AACA;;AAEA,gBAAe,YAAY,YAAY;AACvC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL,oBAAmB,YAAY,YAAY;AAC3C,oBAAmB,YAAY,YAAY;AAC3C,oBAAmB,YAAY,aAAa;;AAE5C,sBAAqB,cAAc,cAAc;AACjD,sBAAqB,cAAc,cAAc;AACjD,sBAAqB,cAAc,eAAe;;AAElD;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,4CAA2C,aAAa;;AAExD;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,gBAAe,YAAY,YAAY;AACvC,gBAAe,YAAY,YAAY;AACvC,gBAAe,YAAY,aAAa;;AAExC;AACA,yBAAwB,yBAAyB;AACjD,6BAA4B,qBAAqB;AACjD,6BAA4B,yBAAyB;;AAErD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qBAAoB;AACpB;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,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;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,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;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,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA,4CAA2C,aAAa;;AAExD;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;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,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;;AAEA;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,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;;AAEA;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,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;;AAEA;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;AACA,YAAW,KAAK;AAChB,YAAW,MAAM;AACjB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,MAAM;AACjB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;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;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,MAAM;AACjB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;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,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;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,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;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,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;;AAGA;;;;;;;AClwCA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA,gB;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA,gB;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA,gB;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK,O;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,yCAAwC;AACxC;AACA,2BAA0B;AAC1B;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACxiBA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAS;AACT;AACA;;AAEA,wBAAuB,OAAO;AAC9B,2BAA0B,iBAAiB;AAC3C;AACA,2BAA0B,iBAAiB;AAC3C;;AAEA;AACA;AACA,EAAC;;AAED;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,MAAK;AACL;AACA,M;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACpsBA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAS;AACT;AACA;;AAEA,wBAAuB,OAAO;AAC9B,2BAA0B,iBAAiB,iBAAiB;AAC5D;AACA,2BAA0B,iBAAiB,iBAAiB;AAC5D;;AAEA;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACxhBA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,eAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,MAAM;AACjB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;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ClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CACxB,EAAC;AACF,sBAAi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C,CAAC;AAC3B,YAAO;AACH,aAAI,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;AACrB,cAAK,EAAE,SAAS,CAAC,KAAK;AACtB,YAAG,EAAE,OAAO,CAAC,GAAG;AAChB,kBAAS,EAAE,SAAS;AACpB,qBAAY,EAAE,YAAY;MAC7B,CAAC;EACL,CAAC;;AAEF,YAAW,CAAC,WAAW,GAAG;AACtB,2BAAsB,EAAE;AACpB,eAAM,EAAE,SAAS;AACjB,kBAAS,EAAE,KAAK;AAChB,sBAAa,EAAE,4CAA4C,GAC3D,0CAA0C;MAC7C;EACJ,CAAC;;sBAEa,WAAW;;;;;;;AC7U1B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,UAAU;AACrB,YAAW,SAAS;AACpB,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA,gBAAe,mBAAmB,GAAG,iBAAiB;AACtD;AACA;AACA;AACA,gBAAe,YAAY,GAAG,YAAY;AAC1C;AACA;AACA;AACA,WAAU,WAAW,8BAA8B,GAAG,4BAA4B;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAI;AACJ,WAAU;AACV;AACA;;AAEA;;;;;;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;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,IAAG;AACH;AACA;;AAEA;;;;;;;ACvDA;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,SAAS;AACpB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,SAAS;AACpB,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA4C;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;;;;;;;AClEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA,8BAA6B,kBAAkB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjCA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACXA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA,0BAAyB,kBAAkB,EAAE;AAC7C;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvCA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,4DAA2D;AAC3D;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/CA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA,iBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;;;;;;;ACtEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;;AAEA;;;;;;;AChBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,QAAQ;AACnB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/DA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvBA;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa,SAAS;AACtB,WAAU;AACV;AACA,cAAa,SAAS;AACtB,WAAU;AACV;AACA;AACA;AACA;;AAEA;;;;;;;AC9BA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,YAAW,OAAO,WAAW;AAC7B,cAAa,OAAO;AACpB;AACA;AACA,yBAAwB;;AAExB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5CA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxCA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;ACxCA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,YAAW,EAAE;AACb,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;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;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,EAAE;AACf;AACA;AACA,kBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,YAAW,EAAE;AACb,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA,KAAI;AACJ;AACA;AACA;AACA;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;AACA;AACA;;AAEA;;;;;;;;;;;;;sBCzDe,CAAC,YAAW;AACvB,SAAI,MAAM,GAAG,EAAE,CAAC;;AAEhB,cAAS,QAAQ,CAAC,SAAS,EAAE;AACzB,aAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE;AACpB,mBAAM,CAA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","file":"quagga.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(factory.toString());\n\telse if(typeof exports === 'object')\n\t\texports[\"Quagga\"] = factory(factory.toString());\n\telse\n\t\troot[\"Quagga\"] = factory(factory.toString());\n})(this, function(__factorySource__) {\nreturn \n\n\n/** WEBPACK FOOTER **\n ** webpack/myModuleDefinition\n **/"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\texports: {},\n \t\t\tid: moduleId,\n \t\t\tloaded: false\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.loaded = 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// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(0);\n\n\n\n/** WEBPACK FOOTER **\n ** webpack/bootstrap e5b729d508479e63bf1d\n **/","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 {vec2} from 'gl-matrix';\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\n\r\nconst merge = require('lodash/object/merge');\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, function(err) {\r\n            if (!err) {\r\n                _inputStream.trigger(\"canrecord\");\r\n            } else {\r\n                return cb(err);\r\n            }\r\n        });\r\n    }\r\n\r\n    _inputStream.setAttribute(\"preload\", \"auto\");\r\n    _inputStream.setAttribute(\"autoplay\", true);\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    const resultToPublish = result && (result.barcodes || result);\r\n\r\n    if (result && _onUIThread) {\r\n        transformResult(result);\r\n        addResult(result, imageData);\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: _config\r\n    }, [workerThread.imageData.buffer]);\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();\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, function() {\r\n            Events.once(\"processed\", function(result) {\r\n                _stopped = true;\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};\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/quagga.js\n **/","/*\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\n    navigator.getUserMedia = navigator.getUserMedia ||\r\n        navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;\r\n    window.URL = window.URL || window.webkitURL || window.mozURL || window.msURL;\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\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/common/typedefs.js\n **/","import SubImage from './subImage';\r\nimport CVUtils from '../common/cv_utils';\r\nimport ArrayHelper from '../common/array_helper';\r\nimport {vec2} from 'gl-matrix';\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 : CVUtils.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 ** D:/work/quaggaJS/src/common/image_wrapper.js\n **/","/**\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 ** D:/work/quaggaJS/src/common/subImage.js\n **/","import Cluster2 from './cluster';\r\nimport ArrayHelper from './array_helper';\r\nimport {vec2, vec3} from 'gl-matrix';\r\n\r\nvar CVUtils = {};\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\nCVUtils.imageRef = function(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\nCVUtils.computeIntegralImage2 = function(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\nCVUtils.computeIntegralImage = function(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\nCVUtils.thresholdImage = function(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\nCVUtils.computeHistogram = function(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\nCVUtils.sharpenLine = function(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\nCVUtils.determineOtsuThreshold = function(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 = CVUtils.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\nCVUtils.otsuThreshold = function(imageWrapper, targetWrapper) {\r\n    var threshold = CVUtils.determineOtsuThreshold(imageWrapper);\r\n\r\n    CVUtils.thresholdImage(imageWrapper, threshold, targetWrapper);\r\n    return threshold;\r\n};\r\n\r\n// local thresholding\r\nCVUtils.computeBinaryImage = function(imageWrapper, integralWrapper, targetWrapper) {\r\n    CVUtils.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\nCVUtils.cluster = function(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\nCVUtils.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\nCVUtils.DILATE = 1;\r\nCVUtils.ERODE = 2;\r\n\r\nCVUtils.dilate = function(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\nCVUtils.erode = function(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\nCVUtils.subtract = function(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\nCVUtils.bitwiseOr = function(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\nCVUtils.countNonZero = function(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\nCVUtils.topGeneric = function(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\nCVUtils.grayArrayFromImage = function(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    CVUtils.computeGray(ctxData, array);\r\n};\r\n\r\nCVUtils.grayArrayFromContext = function(ctx, size, offset, array) {\r\n    var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data;\r\n    CVUtils.computeGray(ctxData, array);\r\n};\r\n\r\nCVUtils.grayAndHalfSampleFromCanvasData = function(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] = Math.floor((\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\nCVUtils.computeGray = function(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] = Math.floor(\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\nCVUtils.loadImageArray = function(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        CVUtils.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\nCVUtils.halfSample = function(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\nCVUtils.hsv2rgb = function(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\nCVUtils._computeDivisors = function(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\nCVUtils._computeIntersection = function(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\nCVUtils.calculatePatchSize = function(patchSize, imgSize) {\r\n    var divisorsX = this._computeDivisors(imgSize.x),\r\n        divisorsY = this._computeDivisors(imgSize.y),\r\n        wideSide = Math.max(imgSize.x, imgSize.y),\r\n        common = this._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(this._computeDivisors(wideSide));\r\n        if (!optimalPatchSize) {\r\n            optimalPatchSize = findPatchSizeForDivisors((this._computeDivisors(desiredPatchSize * nrOfPatches)));\r\n        }\r\n    }\r\n    return optimalPatchSize;\r\n};\r\n\r\nCVUtils._parseCSSDimensionValues = function(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\nCVUtils._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\nCVUtils.computeImageArea = function(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 = CVUtils._parseCSSDimensionValues(value),\r\n            calculated = CVUtils._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\r\nexport default CVUtils;\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/common/cv_utils.js\n **/","import {vec2} from 'gl-matrix';\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 ** D:/work/quaggaJS/src/common/cluster.js\n **/","/**\n * @fileoverview gl-matrix - High performance matrix and vector operations\n * @author Brandon Jones\n * @author Colin MacKenzie IV\n * @version 2.3.0\n */\n\n/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n// END HEADER\n\nexports.glMatrix = require(\"./gl-matrix/common.js\");\nexports.mat2 = require(\"./gl-matrix/mat2.js\");\nexports.mat2d = require(\"./gl-matrix/mat2d.js\");\nexports.mat3 = require(\"./gl-matrix/mat3.js\");\nexports.mat4 = require(\"./gl-matrix/mat4.js\");\nexports.quat = require(\"./gl-matrix/quat.js\");\nexports.vec2 = require(\"./gl-matrix/vec2.js\");\nexports.vec3 = require(\"./gl-matrix/vec3.js\");\nexports.vec4 = require(\"./gl-matrix/vec4.js\");\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix.js\n ** module id = 7\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\n/**\n * @class Common utilities\n * @name glMatrix\n */\nvar glMatrix = {};\n\n// Constants\nglMatrix.EPSILON = 0.000001;\nglMatrix.ARRAY_TYPE = (typeof Float32Array !== 'undefined') ? Float32Array : Array;\nglMatrix.RANDOM = Math.random;\n\n/**\n * Sets the type of array used when creating new vectors and matrices\n *\n * @param {Type} type Array type, such as Float32Array or Array\n */\nglMatrix.setMatrixArrayType = function(type) {\n    GLMAT_ARRAY_TYPE = type;\n}\n\nvar degree = Math.PI / 180;\n\n/**\n* Convert Degree To Radian\n*\n* @param {Number} Angle in Degrees\n*/\nglMatrix.toRadian = function(a){\n     return a * degree;\n}\n\nmodule.exports = glMatrix;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/common.js\n ** module id = 8\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\nvar glMatrix = require(\"./common.js\");\n\n/**\n * @class 2x2 Matrix\n * @name mat2\n */\nvar mat2 = {};\n\n/**\n * Creates a new identity mat2\n *\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.create = function() {\n    var out = new glMatrix.ARRAY_TYPE(4);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat2 initialized with values from an existing matrix\n *\n * @param {mat2} a matrix to clone\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.clone = function(a) {\n    var out = new glMatrix.ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Copy the values from one mat2 to another\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set a mat2 to the identity matrix\n *\n * @param {mat2} out the receiving matrix\n * @returns {mat2} out\n */\nmat2.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a1 = a[1];\n        out[1] = a[2];\n        out[2] = a1;\n    } else {\n        out[0] = a[0];\n        out[1] = a[2];\n        out[2] = a[1];\n        out[3] = a[3];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n\n        // Calculate the determinant\n        det = a0 * a3 - a2 * a1;\n\n    if (!det) {\n        return null;\n    }\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 * Calculates the adjugate of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.adjoint = function(out, a) {\n    // Caching this value is nessecary if out == a\n    var a0 = a[0];\n    out[0] =  a[3];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] =  a0;\n\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2\n *\n * @param {mat2} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2.determinant = function (a) {\n    return a[0] * a[3] - a[2] * a[1];\n};\n\n/**\n * Multiplies two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the first operand\n * @param {mat2} b the second operand\n * @returns {mat2} out\n */\nmat2.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];\n    var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    return out;\n};\n\n/**\n * Alias for {@link mat2.multiply}\n * @function\n */\nmat2.mul = mat2.multiply;\n\n/**\n * Rotates a mat2 by the given angle\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\nmat2.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    return out;\n};\n\n/**\n * Scales the mat2 by the dimensions in the given vec2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2} out\n **/\nmat2.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    return out;\n};\n\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n *     mat2.identity(dest);\n *     mat2.rotate(dest, dest, rad);\n *\n * @param {mat2} out mat2 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\nmat2.fromRotation = function(out, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = c;\n    out[1] = s;\n    out[2] = -s;\n    out[3] = c;\n    return out;\n}\n\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n *     mat2.identity(dest);\n *     mat2.scale(dest, dest, vec);\n *\n * @param {mat2} out mat2 receiving operation result\n * @param {vec2} v Scaling vector\n * @returns {mat2} out\n */\nmat2.fromScaling = function(out, v) {\n    out[0] = v[0];\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = v[1];\n    return out;\n}\n\n/**\n * Returns a string representation of a mat2\n *\n * @param {mat2} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2.str = function (a) {\n    return 'mat2(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2\n *\n * @param {mat2} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2)))\n};\n\n/**\n * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix\n * @param {mat2} L the lower triangular matrix \n * @param {mat2} D the diagonal matrix \n * @param {mat2} U the upper triangular matrix \n * @param {mat2} a the input matrix to factorize\n */\n\nmat2.LDU = function (L, D, U, a) { \n    L[2] = a[2]/a[0]; \n    U[0] = a[0]; \n    U[1] = a[1]; \n    U[3] = a[3] - L[2] * U[1]; \n    return [L, D, U];       \n}; \n\n\nmodule.exports = mat2;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/mat2.js\n ** module id = 9\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\nvar glMatrix = require(\"./common.js\");\n\n/**\n * @class 2x3 Matrix\n * @name mat2d\n * \n * @description \n * A mat2d contains six elements defined as:\n * <pre>\n * [a, c, tx,\n *  b, d, ty]\n * </pre>\n * This is a short form for the 3x3 matrix:\n * <pre>\n * [a, c, tx,\n *  b, d, ty,\n *  0, 0, 1]\n * </pre>\n * The last row is ignored so the array is shorter and operations are faster.\n */\nvar mat2d = {};\n\n/**\n * Creates a new identity mat2d\n *\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.create = function() {\n    var out = new glMatrix.ARRAY_TYPE(6);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Creates a new mat2d initialized with values from an existing matrix\n *\n * @param {mat2d} a matrix to clone\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.clone = function(a) {\n    var out = new glMatrix.ARRAY_TYPE(6);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Copy the values from one mat2d to another\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Set a mat2d to the identity matrix\n *\n * @param {mat2d} out the receiving matrix\n * @returns {mat2d} out\n */\nmat2d.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Inverts a mat2d\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.invert = function(out, a) {\n    var aa = a[0], ab = a[1], ac = a[2], ad = a[3],\n        atx = a[4], aty = a[5];\n\n    var det = aa * ad - ab * ac;\n    if(!det){\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = ad * det;\n    out[1] = -ab * det;\n    out[2] = -ac * det;\n    out[3] = aa * det;\n    out[4] = (ac * aty - ad * atx) * det;\n    out[5] = (ab * atx - aa * aty) * det;\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2d\n *\n * @param {mat2d} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2d.determinant = function (a) {\n    return a[0] * a[3] - a[1] * a[2];\n};\n\n/**\n * Multiplies two mat2d's\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the first operand\n * @param {mat2d} b the second operand\n * @returns {mat2d} out\n */\nmat2d.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3], b4 = b[4], b5 = b[5];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    out[4] = a0 * b4 + a2 * b5 + a4;\n    out[5] = a1 * b4 + a3 * b5 + a5;\n    return out;\n};\n\n/**\n * Alias for {@link mat2d.multiply}\n * @function\n */\nmat2d.mul = mat2d.multiply;\n\n/**\n * Rotates a mat2d by the given angle\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2d} out\n */\nmat2d.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Scales the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2d} out\n **/\nmat2d.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Translates the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to translate the matrix by\n * @returns {mat2d} out\n **/\nmat2d.translate = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0;\n    out[1] = a1;\n    out[2] = a2;\n    out[3] = a3;\n    out[4] = a0 * v0 + a2 * v1 + a4;\n    out[5] = a1 * v0 + a3 * v1 + a5;\n    return out;\n};\n\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n *     mat2d.identity(dest);\n *     mat2d.rotate(dest, dest, rad);\n *\n * @param {mat2d} out mat2d receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2d} out\n */\nmat2d.fromRotation = function(out, rad) {\n    var s = Math.sin(rad), c = Math.cos(rad);\n    out[0] = c;\n    out[1] = s;\n    out[2] = -s;\n    out[3] = c;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n}\n\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n *     mat2d.identity(dest);\n *     mat2d.scale(dest, dest, vec);\n *\n * @param {mat2d} out mat2d receiving operation result\n * @param {vec2} v Scaling vector\n * @returns {mat2d} out\n */\nmat2d.fromScaling = function(out, v) {\n    out[0] = v[0];\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = v[1];\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n}\n\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n *     mat2d.identity(dest);\n *     mat2d.translate(dest, dest, vec);\n *\n * @param {mat2d} out mat2d receiving operation result\n * @param {vec2} v Translation vector\n * @returns {mat2d} out\n */\nmat2d.fromTranslation = function(out, v) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = v[0];\n    out[5] = v[1];\n    return out;\n}\n\n/**\n * Returns a string representation of a mat2d\n *\n * @param {mat2d} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2d.str = function (a) {\n    return 'mat2d(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + \n                    a[3] + ', ' + a[4] + ', ' + a[5] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2d\n *\n * @param {mat2d} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2d.frob = function (a) { \n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + 1))\n}; \n\nmodule.exports = mat2d;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/mat2d.js\n ** module id = 10\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\nvar glMatrix = require(\"./common.js\");\n\n/**\n * @class 3x3 Matrix\n * @name mat3\n */\nvar mat3 = {};\n\n/**\n * Creates a new identity mat3\n *\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.create = function() {\n    var out = new glMatrix.ARRAY_TYPE(9);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Copies the upper-left 3x3 values into the given mat3.\n *\n * @param {mat3} out the receiving 3x3 matrix\n * @param {mat4} a   the source 4x4 matrix\n * @returns {mat3} out\n */\nmat3.fromMat4 = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[4];\n    out[4] = a[5];\n    out[5] = a[6];\n    out[6] = a[8];\n    out[7] = a[9];\n    out[8] = a[10];\n    return out;\n};\n\n/**\n * Creates a new mat3 initialized with values from an existing matrix\n *\n * @param {mat3} a matrix to clone\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.clone = function(a) {\n    var out = new glMatrix.ARRAY_TYPE(9);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copy the values from one mat3 to another\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Set a mat3 to the identity matrix\n *\n * @param {mat3} out the receiving matrix\n * @returns {mat3} out\n */\nmat3.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a12 = a[5];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a01;\n        out[5] = a[7];\n        out[6] = a02;\n        out[7] = a12;\n    } else {\n        out[0] = a[0];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a[1];\n        out[4] = a[4];\n        out[5] = a[7];\n        out[6] = a[2];\n        out[7] = a[5];\n        out[8] = a[8];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b01 = a22 * a11 - a12 * a21,\n        b11 = -a22 * a10 + a12 * a20,\n        b21 = a21 * a10 - a11 * a20,\n\n        // Calculate the determinant\n        det = a00 * b01 + a01 * b11 + a02 * b21;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = b01 * det;\n    out[1] = (-a22 * a01 + a02 * a21) * det;\n    out[2] = (a12 * a01 - a02 * a11) * det;\n    out[3] = b11 * det;\n    out[4] = (a22 * a00 - a02 * a20) * det;\n    out[5] = (-a12 * a00 + a02 * a10) * det;\n    out[6] = b21 * det;\n    out[7] = (-a21 * a00 + a01 * a20) * det;\n    out[8] = (a11 * a00 - a01 * a10) * det;\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    out[0] = (a11 * a22 - a12 * a21);\n    out[1] = (a02 * a21 - a01 * a22);\n    out[2] = (a01 * a12 - a02 * a11);\n    out[3] = (a12 * a20 - a10 * a22);\n    out[4] = (a00 * a22 - a02 * a20);\n    out[5] = (a02 * a10 - a00 * a12);\n    out[6] = (a10 * a21 - a11 * a20);\n    out[7] = (a01 * a20 - a00 * a21);\n    out[8] = (a00 * a11 - a01 * a10);\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat3\n *\n * @param {mat3} a the source matrix\n * @returns {Number} determinant of a\n */\nmat3.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n};\n\n/**\n * Multiplies two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the first operand\n * @param {mat3} b the second operand\n * @returns {mat3} out\n */\nmat3.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b00 = b[0], b01 = b[1], b02 = b[2],\n        b10 = b[3], b11 = b[4], b12 = b[5],\n        b20 = b[6], b21 = b[7], b22 = b[8];\n\n    out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n    out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n    out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n\n    out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n    out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n    out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n\n    out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n    out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n    out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n    return out;\n};\n\n/**\n * Alias for {@link mat3.multiply}\n * @function\n */\nmat3.mul = mat3.multiply;\n\n/**\n * Translate a mat3 by the given vector\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to translate\n * @param {vec2} v vector to translate by\n * @returns {mat3} out\n */\nmat3.translate = function(out, a, v) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n        x = v[0], y = v[1];\n\n    out[0] = a00;\n    out[1] = a01;\n    out[2] = a02;\n\n    out[3] = a10;\n    out[4] = a11;\n    out[5] = a12;\n\n    out[6] = x * a00 + y * a10 + a20;\n    out[7] = x * a01 + y * a11 + a21;\n    out[8] = x * a02 + y * a12 + a22;\n    return out;\n};\n\n/**\n * Rotates a mat3 by the given angle\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\nmat3.rotate = function (out, a, rad) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n\n    out[0] = c * a00 + s * a10;\n    out[1] = c * a01 + s * a11;\n    out[2] = c * a02 + s * a12;\n\n    out[3] = c * a10 - s * a00;\n    out[4] = c * a11 - s * a01;\n    out[5] = c * a12 - s * a02;\n\n    out[6] = a20;\n    out[7] = a21;\n    out[8] = a22;\n    return out;\n};\n\n/**\n * Scales the mat3 by the dimensions in the given vec2\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat3} out\n **/\nmat3.scale = function(out, a, v) {\n    var x = v[0], y = v[1];\n\n    out[0] = x * a[0];\n    out[1] = x * a[1];\n    out[2] = x * a[2];\n\n    out[3] = y * a[3];\n    out[4] = y * a[4];\n    out[5] = y * a[5];\n\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n *     mat3.identity(dest);\n *     mat3.translate(dest, dest, vec);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {vec2} v Translation vector\n * @returns {mat3} out\n */\nmat3.fromTranslation = function(out, v) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = v[0];\n    out[7] = v[1];\n    out[8] = 1;\n    return out;\n}\n\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n *     mat3.identity(dest);\n *     mat3.rotate(dest, dest, rad);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\nmat3.fromRotation = function(out, rad) {\n    var s = Math.sin(rad), c = Math.cos(rad);\n\n    out[0] = c;\n    out[1] = s;\n    out[2] = 0;\n\n    out[3] = -s;\n    out[4] = c;\n    out[5] = 0;\n\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n}\n\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n *     mat3.identity(dest);\n *     mat3.scale(dest, dest, vec);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {vec2} v Scaling vector\n * @returns {mat3} out\n */\nmat3.fromScaling = function(out, v) {\n    out[0] = v[0];\n    out[1] = 0;\n    out[2] = 0;\n\n    out[3] = 0;\n    out[4] = v[1];\n    out[5] = 0;\n\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n}\n\n/**\n * Copies the values from a mat2d into a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat2d} a the matrix to copy\n * @returns {mat3} out\n **/\nmat3.fromMat2d = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = 0;\n\n    out[3] = a[2];\n    out[4] = a[3];\n    out[5] = 0;\n\n    out[6] = a[4];\n    out[7] = a[5];\n    out[8] = 1;\n    return out;\n};\n\n/**\n* Calculates a 3x3 matrix from the given quaternion\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {quat} q Quaternion to create matrix from\n*\n* @returns {mat3} out\n*/\nmat3.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[3] = yx - wz;\n    out[6] = zx + wy;\n\n    out[1] = yx + wz;\n    out[4] = 1 - xx - zz;\n    out[7] = zy - wx;\n\n    out[2] = zx - wy;\n    out[5] = zy + wx;\n    out[8] = 1 - xx - yy;\n\n    return out;\n};\n\n/**\n* Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {mat4} a Mat4 to derive the normal matrix from\n*\n* @returns {mat3} out\n*/\nmat3.normalFromMat4 = function (out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n\n    out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n\n    out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat3\n *\n * @param {mat3} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat3.str = function (a) {\n    return 'mat3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + \n                    a[3] + ', ' + a[4] + ', ' + a[5] + ', ' + \n                    a[6] + ', ' + a[7] + ', ' + a[8] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat3\n *\n * @param {mat3} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat3.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2)))\n};\n\n\nmodule.exports = mat3;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/mat3.js\n ** module id = 11\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\nvar glMatrix = require(\"./common.js\");\n\n/**\n * @class 4x4 Matrix\n * @name mat4\n */\nvar mat4 = {};\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.create = function() {\n    var out = new glMatrix.ARRAY_TYPE(16);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {mat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.clone = function(a) {\n    var out = new glMatrix.ARRAY_TYPE(16);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Copy the values from one mat4 to another\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nmat4.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a03 = a[3],\n            a12 = a[6], a13 = a[7],\n            a23 = a[11];\n\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a01;\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a02;\n        out[9] = a12;\n        out[11] = a[14];\n        out[12] = a03;\n        out[13] = a13;\n        out[14] = a23;\n    } else {\n        out[0] = a[0];\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a[1];\n        out[5] = a[5];\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a[2];\n        out[9] = a[6];\n        out[10] = a[10];\n        out[11] = a[14];\n        out[12] = a[3];\n        out[13] = a[7];\n        out[14] = a[11];\n        out[15] = a[15];\n    }\n    \n    return out;\n};\n\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) { \n        return null; \n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n    out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n    out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n    out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n    out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n    out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n    out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n    out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n    out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n    out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    out[0]  =  (a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22));\n    out[1]  = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n    out[2]  =  (a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12));\n    out[3]  = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n    out[4]  = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n    out[5]  =  (a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22));\n    out[6]  = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n    out[7]  =  (a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12));\n    out[8]  =  (a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21));\n    out[9]  = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n    out[10] =  (a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11));\n    out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n    out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n    out[13] =  (a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21));\n    out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n    out[15] =  (a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11));\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat4\n *\n * @param {mat4} a the source matrix\n * @returns {Number} determinant of a\n */\nmat4.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32;\n\n    // Calculate the determinant\n    return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n};\n\n/**\n * Multiplies two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nmat4.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    // Cache only the current line of the second matrix\n    var b0  = b[0], b1 = b[1], b2 = b[2], b3 = b[3];  \n    out[0] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[1] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[2] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[3] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[4]; b1 = b[5]; b2 = b[6]; b3 = b[7];\n    out[4] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[5] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[6] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[7] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[8]; b1 = b[9]; b2 = b[10]; b3 = b[11];\n    out[8] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[9] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[10] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[11] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[12]; b1 = b[13]; b2 = b[14]; b3 = b[15];\n    out[12] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[13] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[14] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[15] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n    return out;\n};\n\n/**\n * Alias for {@link mat4.multiply}\n * @function\n */\nmat4.mul = mat4.multiply;\n\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to translate\n * @param {vec3} v vector to translate by\n * @returns {mat4} out\n */\nmat4.translate = function (out, a, v) {\n    var x = v[0], y = v[1], z = v[2],\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23;\n\n    if (a === out) {\n        out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n        out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n        out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n        out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n    } else {\n        a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n        a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n        a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n        out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a03;\n        out[4] = a10; out[5] = a11; out[6] = a12; out[7] = a13;\n        out[8] = a20; out[9] = a21; out[10] = a22; out[11] = a23;\n\n        out[12] = a00 * x + a10 * y + a20 * z + a[12];\n        out[13] = a01 * x + a11 * y + a21 * z + a[13];\n        out[14] = a02 * x + a12 * y + a22 * z + a[14];\n        out[15] = a03 * x + a13 * y + a23 * z + a[15];\n    }\n\n    return out;\n};\n\n/**\n * Scales the mat4 by the dimensions in the given vec3\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to scale\n * @param {vec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\nmat4.scale = function(out, a, v) {\n    var x = v[0], y = v[1], z = v[2];\n\n    out[0] = a[0] * x;\n    out[1] = a[1] * x;\n    out[2] = a[2] * x;\n    out[3] = a[3] * x;\n    out[4] = a[4] * y;\n    out[5] = a[5] * y;\n    out[6] = a[6] * y;\n    out[7] = a[7] * y;\n    out[8] = a[8] * z;\n    out[9] = a[9] * z;\n    out[10] = a[10] * z;\n    out[11] = a[11] * z;\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Rotates a mat4 by the given angle around the given axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nmat4.rotate = function (out, a, rad, axis) {\n    var x = axis[0], y = axis[1], z = axis[2],\n        len = Math.sqrt(x * x + y * y + z * z),\n        s, c, t,\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23,\n        b00, b01, b02,\n        b10, b11, b12,\n        b20, b21, b22;\n\n    if (Math.abs(len) < glMatrix.EPSILON) { return null; }\n    \n    len = 1 / len;\n    x *= len;\n    y *= len;\n    z *= len;\n\n    s = Math.sin(rad);\n    c = Math.cos(rad);\n    t = 1 - c;\n\n    a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n    a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n    a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n    // Construct the elements of the rotation matrix\n    b00 = x * x * t + c; b01 = y * x * t + z * s; b02 = z * x * t - y * s;\n    b10 = x * y * t - z * s; b11 = y * y * t + c; b12 = z * y * t + x * s;\n    b20 = x * z * t + y * s; b21 = y * z * t - x * s; b22 = z * z * t + c;\n\n    // Perform rotation-specific matrix multiplication\n    out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n    out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n    out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n    out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n    out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n    out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n    out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n    out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n    out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n    out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n    out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n    out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateX = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[0]  = a[0];\n        out[1]  = a[1];\n        out[2]  = a[2];\n        out[3]  = a[3];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[4] = a10 * c + a20 * s;\n    out[5] = a11 * c + a21 * s;\n    out[6] = a12 * c + a22 * s;\n    out[7] = a13 * c + a23 * s;\n    out[8] = a20 * c - a10 * s;\n    out[9] = a21 * c - a11 * s;\n    out[10] = a22 * c - a12 * s;\n    out[11] = a23 * c - a13 * s;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateY = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[4]  = a[4];\n        out[5]  = a[5];\n        out[6]  = a[6];\n        out[7]  = a[7];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c - a20 * s;\n    out[1] = a01 * c - a21 * s;\n    out[2] = a02 * c - a22 * s;\n    out[3] = a03 * c - a23 * s;\n    out[8] = a00 * s + a20 * c;\n    out[9] = a01 * s + a21 * c;\n    out[10] = a02 * s + a22 * c;\n    out[11] = a03 * s + a23 * c;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateZ = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[8]  = a[8];\n        out[9]  = a[9];\n        out[10] = a[10];\n        out[11] = a[11];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c + a10 * s;\n    out[1] = a01 * c + a11 * s;\n    out[2] = a02 * c + a12 * s;\n    out[3] = a03 * c + a13 * s;\n    out[4] = a10 * c - a00 * s;\n    out[5] = a11 * c - a01 * s;\n    out[6] = a12 * c - a02 * s;\n    out[7] = a13 * c - a03 * s;\n    return out;\n};\n\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.translate(dest, dest, vec);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nmat4.fromTranslation = function(out, v) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = v[0];\n    out[13] = v[1];\n    out[14] = v[2];\n    out[15] = 1;\n    return out;\n}\n\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.scale(dest, dest, vec);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {vec3} v Scaling vector\n * @returns {mat4} out\n */\nmat4.fromScaling = function(out, v) {\n    out[0] = v[0];\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = v[1];\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = v[2];\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n}\n\n/**\n * Creates a matrix from a given angle around a given axis\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.rotate(dest, dest, rad, axis);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nmat4.fromRotation = function(out, rad, axis) {\n    var x = axis[0], y = axis[1], z = axis[2],\n        len = Math.sqrt(x * x + y * y + z * z),\n        s, c, t;\n    \n    if (Math.abs(len) < glMatrix.EPSILON) { return null; }\n    \n    len = 1 / len;\n    x *= len;\n    y *= len;\n    z *= len;\n    \n    s = Math.sin(rad);\n    c = Math.cos(rad);\n    t = 1 - c;\n    \n    // Perform rotation-specific matrix multiplication\n    out[0] = x * x * t + c;\n    out[1] = y * x * t + z * s;\n    out[2] = z * x * t - y * s;\n    out[3] = 0;\n    out[4] = x * y * t - z * s;\n    out[5] = y * y * t + c;\n    out[6] = z * y * t + x * s;\n    out[7] = 0;\n    out[8] = x * z * t + y * s;\n    out[9] = y * z * t - x * s;\n    out[10] = z * z * t + c;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n}\n\n/**\n * Creates a matrix from the given angle around the X axis\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.rotateX(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.fromXRotation = function(out, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad);\n    \n    // Perform axis-specific matrix multiplication\n    out[0]  = 1;\n    out[1]  = 0;\n    out[2]  = 0;\n    out[3]  = 0;\n    out[4] = 0;\n    out[5] = c;\n    out[6] = s;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = -s;\n    out[10] = c;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n}\n\n/**\n * Creates a matrix from the given angle around the Y axis\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.rotateY(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.fromYRotation = function(out, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad);\n    \n    // Perform axis-specific matrix multiplication\n    out[0]  = c;\n    out[1]  = 0;\n    out[2]  = -s;\n    out[3]  = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = s;\n    out[9] = 0;\n    out[10] = c;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n}\n\n/**\n * Creates a matrix from the given angle around the Z axis\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.rotateZ(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.fromZRotation = function(out, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad);\n    \n    // Perform axis-specific matrix multiplication\n    out[0]  = c;\n    out[1]  = s;\n    out[2]  = 0;\n    out[3]  = 0;\n    out[4] = -s;\n    out[5] = c;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n}\n\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.translate(dest, vec);\n *     var quatMat = mat4.create();\n *     quat4.toMat4(quat, quatMat);\n *     mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nmat4.fromRotationTranslation = function (out, q, v) {\n    // Quaternion math\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        xy = x * y2,\n        xz = x * z2,\n        yy = y * y2,\n        yz = y * z2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - (yy + zz);\n    out[1] = xy + wz;\n    out[2] = xz - wy;\n    out[3] = 0;\n    out[4] = xy - wz;\n    out[5] = 1 - (xx + zz);\n    out[6] = yz + wx;\n    out[7] = 0;\n    out[8] = xz + wy;\n    out[9] = yz - wx;\n    out[10] = 1 - (xx + yy);\n    out[11] = 0;\n    out[12] = v[0];\n    out[13] = v[1];\n    out[14] = v[2];\n    out[15] = 1;\n    \n    return out;\n};\n\n/**\n * Creates a matrix from a quaternion rotation, vector translation and vector scale\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.translate(dest, vec);\n *     var quatMat = mat4.create();\n *     quat4.toMat4(quat, quatMat);\n *     mat4.multiply(dest, quatMat);\n *     mat4.scale(dest, scale)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @param {vec3} s Scaling vector\n * @returns {mat4} out\n */\nmat4.fromRotationTranslationScale = function (out, q, v, s) {\n    // Quaternion math\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        xy = x * y2,\n        xz = x * z2,\n        yy = y * y2,\n        yz = y * z2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2,\n        sx = s[0],\n        sy = s[1],\n        sz = s[2];\n\n    out[0] = (1 - (yy + zz)) * sx;\n    out[1] = (xy + wz) * sx;\n    out[2] = (xz - wy) * sx;\n    out[3] = 0;\n    out[4] = (xy - wz) * sy;\n    out[5] = (1 - (xx + zz)) * sy;\n    out[6] = (yz + wx) * sy;\n    out[7] = 0;\n    out[8] = (xz + wy) * sz;\n    out[9] = (yz - wx) * sz;\n    out[10] = (1 - (xx + yy)) * sz;\n    out[11] = 0;\n    out[12] = v[0];\n    out[13] = v[1];\n    out[14] = v[2];\n    out[15] = 1;\n    \n    return out;\n};\n\n/**\n * Creates a matrix from a quaternion rotation, vector translation and vector scale, rotating and scaling around the given origin\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.translate(dest, vec);\n *     mat4.translate(dest, origin);\n *     var quatMat = mat4.create();\n *     quat4.toMat4(quat, quatMat);\n *     mat4.multiply(dest, quatMat);\n *     mat4.scale(dest, scale)\n *     mat4.translate(dest, negativeOrigin);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @param {vec3} s Scaling vector\n * @param {vec3} o The origin vector around which to scale and rotate\n * @returns {mat4} out\n */\nmat4.fromRotationTranslationScaleOrigin = function (out, q, v, s, o) {\n  // Quaternion math\n  var x = q[0], y = q[1], z = q[2], w = q[3],\n      x2 = x + x,\n      y2 = y + y,\n      z2 = z + z,\n\n      xx = x * x2,\n      xy = x * y2,\n      xz = x * z2,\n      yy = y * y2,\n      yz = y * z2,\n      zz = z * z2,\n      wx = w * x2,\n      wy = w * y2,\n      wz = w * z2,\n      \n      sx = s[0],\n      sy = s[1],\n      sz = s[2],\n\n      ox = o[0],\n      oy = o[1],\n      oz = o[2];\n      \n  out[0] = (1 - (yy + zz)) * sx;\n  out[1] = (xy + wz) * sx;\n  out[2] = (xz - wy) * sx;\n  out[3] = 0;\n  out[4] = (xy - wz) * sy;\n  out[5] = (1 - (xx + zz)) * sy;\n  out[6] = (yz + wx) * sy;\n  out[7] = 0;\n  out[8] = (xz + wy) * sz;\n  out[9] = (yz - wx) * sz;\n  out[10] = (1 - (xx + yy)) * sz;\n  out[11] = 0;\n  out[12] = v[0] + ox - (out[0] * ox + out[4] * oy + out[8] * oz);\n  out[13] = v[1] + oy - (out[1] * ox + out[5] * oy + out[9] * oz);\n  out[14] = v[2] + oz - (out[2] * ox + out[6] * oy + out[10] * oz);\n  out[15] = 1;\n        \n  return out;\n};\n\nmat4.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[1] = yx + wz;\n    out[2] = zx - wy;\n    out[3] = 0;\n\n    out[4] = yx - wz;\n    out[5] = 1 - xx - zz;\n    out[6] = zy + wx;\n    out[7] = 0;\n\n    out[8] = zx + wy;\n    out[9] = zy - wx;\n    out[10] = 1 - xx - yy;\n    out[11] = 0;\n\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Generates a frustum matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Number} left Left bound of the frustum\n * @param {Number} right Right bound of the frustum\n * @param {Number} bottom Bottom bound of the frustum\n * @param {Number} top Top bound of the frustum\n * @param {Number} near Near bound of the frustum\n * @param {Number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.frustum = function (out, left, right, bottom, top, near, far) {\n    var rl = 1 / (right - left),\n        tb = 1 / (top - bottom),\n        nf = 1 / (near - far);\n    out[0] = (near * 2) * rl;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = (near * 2) * tb;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = (right + left) * rl;\n    out[9] = (top + bottom) * tb;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (far * near * 2) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a perspective projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.perspective = function (out, fovy, aspect, near, far) {\n    var f = 1.0 / Math.tan(fovy / 2),\n        nf = 1 / (near - far);\n    out[0] = f / aspect;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = f;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (2 * far * near) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a perspective projection matrix with the given field of view.\n * This is primarily useful for generating projection matrices to be used\n * with the still experiemental WebVR API.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fov Object containing the following values: upDegrees, downDegrees, leftDegrees, rightDegrees\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.perspectiveFromFieldOfView = function (out, fov, near, far) {\n    var upTan = Math.tan(fov.upDegrees * Math.PI/180.0),\n        downTan = Math.tan(fov.downDegrees * Math.PI/180.0),\n        leftTan = Math.tan(fov.leftDegrees * Math.PI/180.0),\n        rightTan = Math.tan(fov.rightDegrees * Math.PI/180.0),\n        xScale = 2.0 / (leftTan + rightTan),\n        yScale = 2.0 / (upTan + downTan);\n\n    out[0] = xScale;\n    out[1] = 0.0;\n    out[2] = 0.0;\n    out[3] = 0.0;\n    out[4] = 0.0;\n    out[5] = yScale;\n    out[6] = 0.0;\n    out[7] = 0.0;\n    out[8] = -((leftTan - rightTan) * xScale * 0.5);\n    out[9] = ((upTan - downTan) * yScale * 0.5);\n    out[10] = far / (near - far);\n    out[11] = -1.0;\n    out[12] = 0.0;\n    out[13] = 0.0;\n    out[14] = (far * near) / (near - far);\n    out[15] = 0.0;\n    return out;\n}\n\n/**\n * Generates a orthogonal projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.ortho = function (out, left, right, bottom, top, near, far) {\n    var lr = 1 / (left - right),\n        bt = 1 / (bottom - top),\n        nf = 1 / (near - far);\n    out[0] = -2 * lr;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = -2 * bt;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 2 * nf;\n    out[11] = 0;\n    out[12] = (left + right) * lr;\n    out[13] = (top + bottom) * bt;\n    out[14] = (far + near) * nf;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {vec3} eye Position of the viewer\n * @param {vec3} center Point the viewer is looking at\n * @param {vec3} up vec3 pointing up\n * @returns {mat4} out\n */\nmat4.lookAt = function (out, eye, center, up) {\n    var x0, x1, x2, y0, y1, y2, z0, z1, z2, len,\n        eyex = eye[0],\n        eyey = eye[1],\n        eyez = eye[2],\n        upx = up[0],\n        upy = up[1],\n        upz = up[2],\n        centerx = center[0],\n        centery = center[1],\n        centerz = center[2];\n\n    if (Math.abs(eyex - centerx) < glMatrix.EPSILON &&\n        Math.abs(eyey - centery) < glMatrix.EPSILON &&\n        Math.abs(eyez - centerz) < glMatrix.EPSILON) {\n        return mat4.identity(out);\n    }\n\n    z0 = eyex - centerx;\n    z1 = eyey - centery;\n    z2 = eyez - centerz;\n\n    len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2);\n    z0 *= len;\n    z1 *= len;\n    z2 *= len;\n\n    x0 = upy * z2 - upz * z1;\n    x1 = upz * z0 - upx * z2;\n    x2 = upx * z1 - upy * z0;\n    len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2);\n    if (!len) {\n        x0 = 0;\n        x1 = 0;\n        x2 = 0;\n    } else {\n        len = 1 / len;\n        x0 *= len;\n        x1 *= len;\n        x2 *= len;\n    }\n\n    y0 = z1 * x2 - z2 * x1;\n    y1 = z2 * x0 - z0 * x2;\n    y2 = z0 * x1 - z1 * x0;\n\n    len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2);\n    if (!len) {\n        y0 = 0;\n        y1 = 0;\n        y2 = 0;\n    } else {\n        len = 1 / len;\n        y0 *= len;\n        y1 *= len;\n        y2 *= len;\n    }\n\n    out[0] = x0;\n    out[1] = y0;\n    out[2] = z0;\n    out[3] = 0;\n    out[4] = x1;\n    out[5] = y1;\n    out[6] = z1;\n    out[7] = 0;\n    out[8] = x2;\n    out[9] = y2;\n    out[10] = z2;\n    out[11] = 0;\n    out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n    out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n    out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat4\n *\n * @param {mat4} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat4.str = function (a) {\n    return 'mat4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ', ' +\n                    a[4] + ', ' + a[5] + ', ' + a[6] + ', ' + a[7] + ', ' +\n                    a[8] + ', ' + a[9] + ', ' + a[10] + ', ' + a[11] + ', ' + \n                    a[12] + ', ' + a[13] + ', ' + a[14] + ', ' + a[15] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat4\n *\n * @param {mat4} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat4.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2) + Math.pow(a[9], 2) + Math.pow(a[10], 2) + Math.pow(a[11], 2) + Math.pow(a[12], 2) + Math.pow(a[13], 2) + Math.pow(a[14], 2) + Math.pow(a[15], 2) ))\n};\n\n\nmodule.exports = mat4;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/mat4.js\n ** module id = 12\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\nvar glMatrix = require(\"./common.js\");\nvar mat3 = require(\"./mat3.js\");\nvar vec3 = require(\"./vec3.js\");\nvar vec4 = require(\"./vec4.js\");\n\n/**\n * @class Quaternion\n * @name quat\n */\nvar quat = {};\n\n/**\n * Creates a new identity quat\n *\n * @returns {quat} a new quaternion\n */\nquat.create = function() {\n    var out = new glMatrix.ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quaternion to represent the shortest rotation from one\n * vector to another.\n *\n * Both vectors are assumed to be unit length.\n *\n * @param {quat} out the receiving quaternion.\n * @param {vec3} a the initial vector\n * @param {vec3} b the destination vector\n * @returns {quat} out\n */\nquat.rotationTo = (function() {\n    var tmpvec3 = vec3.create();\n    var xUnitVec3 = vec3.fromValues(1,0,0);\n    var yUnitVec3 = vec3.fromValues(0,1,0);\n\n    return function(out, a, b) {\n        var dot = vec3.dot(a, b);\n        if (dot < -0.999999) {\n            vec3.cross(tmpvec3, xUnitVec3, a);\n            if (vec3.length(tmpvec3) < 0.000001)\n                vec3.cross(tmpvec3, yUnitVec3, a);\n            vec3.normalize(tmpvec3, tmpvec3);\n            quat.setAxisAngle(out, tmpvec3, Math.PI);\n            return out;\n        } else if (dot > 0.999999) {\n            out[0] = 0;\n            out[1] = 0;\n            out[2] = 0;\n            out[3] = 1;\n            return out;\n        } else {\n            vec3.cross(tmpvec3, a, b);\n            out[0] = tmpvec3[0];\n            out[1] = tmpvec3[1];\n            out[2] = tmpvec3[2];\n            out[3] = 1 + dot;\n            return quat.normalize(out, out);\n        }\n    };\n})();\n\n/**\n * Sets the specified quaternion with values corresponding to the given\n * axes. Each axis is a vec3 and is expected to be unit length and\n * perpendicular to all other specified axes.\n *\n * @param {vec3} view  the vector representing the viewing direction\n * @param {vec3} right the vector representing the local \"right\" direction\n * @param {vec3} up    the vector representing the local \"up\" direction\n * @returns {quat} out\n */\nquat.setAxes = (function() {\n    var matr = mat3.create();\n\n    return function(out, view, right, up) {\n        matr[0] = right[0];\n        matr[3] = right[1];\n        matr[6] = right[2];\n\n        matr[1] = up[0];\n        matr[4] = up[1];\n        matr[7] = up[2];\n\n        matr[2] = -view[0];\n        matr[5] = -view[1];\n        matr[8] = -view[2];\n\n        return quat.normalize(out, quat.fromMat3(out, matr));\n    };\n})();\n\n/**\n * Creates a new quat initialized with values from an existing quaternion\n *\n * @param {quat} a quaternion to clone\n * @returns {quat} a new quaternion\n * @function\n */\nquat.clone = vec4.clone;\n\n/**\n * Creates a new quat initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} a new quaternion\n * @function\n */\nquat.fromValues = vec4.fromValues;\n\n/**\n * Copy the values from one quat to another\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the source quaternion\n * @returns {quat} out\n * @function\n */\nquat.copy = vec4.copy;\n\n/**\n * Set the components of a quat to the given values\n *\n * @param {quat} out the receiving quaternion\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} out\n * @function\n */\nquat.set = vec4.set;\n\n/**\n * Set a quat to the identity quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\nquat.identity = function(out) {\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quat from the given angle and rotation axis,\n * then returns it.\n *\n * @param {quat} out the receiving quaternion\n * @param {vec3} axis the axis around which to rotate\n * @param {Number} rad the angle in radians\n * @returns {quat} out\n **/\nquat.setAxisAngle = function(out, axis, rad) {\n    rad = rad * 0.5;\n    var s = Math.sin(rad);\n    out[0] = s * axis[0];\n    out[1] = s * axis[1];\n    out[2] = s * axis[2];\n    out[3] = Math.cos(rad);\n    return out;\n};\n\n/**\n * Adds two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n * @function\n */\nquat.add = vec4.add;\n\n/**\n * Multiplies two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n */\nquat.multiply = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    out[0] = ax * bw + aw * bx + ay * bz - az * by;\n    out[1] = ay * bw + aw * by + az * bx - ax * bz;\n    out[2] = az * bw + aw * bz + ax * by - ay * bx;\n    out[3] = aw * bw - ax * bx - ay * by - az * bz;\n    return out;\n};\n\n/**\n * Alias for {@link quat.multiply}\n * @function\n */\nquat.mul = quat.multiply;\n\n/**\n * Scales a quat by a scalar number\n *\n * @param {quat} out the receiving vector\n * @param {quat} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {quat} out\n * @function\n */\nquat.scale = vec4.scale;\n\n/**\n * Rotates a quaternion by the given angle about the X axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateX = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + aw * bx;\n    out[1] = ay * bw + az * bx;\n    out[2] = az * bw - ay * bx;\n    out[3] = aw * bw - ax * bx;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Y axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateY = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        by = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw - az * by;\n    out[1] = ay * bw + aw * by;\n    out[2] = az * bw + ax * by;\n    out[3] = aw * bw - ay * by;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Z axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateZ = function (out, a, rad) {\n    rad *= 0.5; \n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bz = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + ay * bz;\n    out[1] = ay * bw - ax * bz;\n    out[2] = az * bw + aw * bz;\n    out[3] = aw * bw - az * bz;\n    return out;\n};\n\n/**\n * Calculates the W component of a quat from the X, Y, and Z components.\n * Assumes that quaternion is 1 unit in length.\n * Any existing W component will be ignored.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate W component of\n * @returns {quat} out\n */\nquat.calculateW = function (out, a) {\n    var x = a[0], y = a[1], z = a[2];\n\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n    return out;\n};\n\n/**\n * Calculates the dot product of two quat's\n *\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {Number} dot product of a and b\n * @function\n */\nquat.dot = vec4.dot;\n\n/**\n * Performs a linear interpolation between two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n * @function\n */\nquat.lerp = vec4.lerp;\n\n/**\n * Performs a spherical linear interpolation between two quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n */\nquat.slerp = function (out, a, b, t) {\n    // benchmarks:\n    //    http://jsperf.com/quaternion-slerp-implementations\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    var        omega, cosom, sinom, scale0, scale1;\n\n    // calc cosine\n    cosom = ax * bx + ay * by + az * bz + aw * bw;\n    // adjust signs (if necessary)\n    if ( cosom < 0.0 ) {\n        cosom = -cosom;\n        bx = - bx;\n        by = - by;\n        bz = - bz;\n        bw = - bw;\n    }\n    // calculate coefficients\n    if ( (1.0 - cosom) > 0.000001 ) {\n        // standard case (slerp)\n        omega  = Math.acos(cosom);\n        sinom  = Math.sin(omega);\n        scale0 = Math.sin((1.0 - t) * omega) / sinom;\n        scale1 = Math.sin(t * omega) / sinom;\n    } else {        \n        // \"from\" and \"to\" quaternions are very close \n        //  ... so we can do a linear interpolation\n        scale0 = 1.0 - t;\n        scale1 = t;\n    }\n    // calculate final values\n    out[0] = scale0 * ax + scale1 * bx;\n    out[1] = scale0 * ay + scale1 * by;\n    out[2] = scale0 * az + scale1 * bz;\n    out[3] = scale0 * aw + scale1 * bw;\n    \n    return out;\n};\n\n/**\n * Performs a spherical linear interpolation with two control points\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {quat} c the third operand\n * @param {quat} d the fourth operand\n * @param {Number} t interpolation amount\n * @returns {quat} out\n */\nquat.sqlerp = (function () {\n  var temp1 = quat.create();\n  var temp2 = quat.create();\n  \n  return function (out, a, b, c, d, t) {\n    quat.slerp(temp1, a, d, t);\n    quat.slerp(temp2, b, c, t);\n    quat.slerp(out, temp1, temp2, 2 * t * (1 - t));\n    \n    return out;\n  };\n}());\n\n/**\n * Calculates the inverse of a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate inverse of\n * @returns {quat} out\n */\nquat.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        dot = a0*a0 + a1*a1 + a2*a2 + a3*a3,\n        invDot = dot ? 1.0/dot : 0;\n    \n    // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n\n    out[0] = -a0*invDot;\n    out[1] = -a1*invDot;\n    out[2] = -a2*invDot;\n    out[3] = a3*invDot;\n    return out;\n};\n\n/**\n * Calculates the conjugate of a quat\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate conjugate of\n * @returns {quat} out\n */\nquat.conjugate = function (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 * Calculates the length of a quat\n *\n * @param {quat} a vector to calculate length of\n * @returns {Number} length of a\n * @function\n */\nquat.length = vec4.length;\n\n/**\n * Alias for {@link quat.length}\n * @function\n */\nquat.len = quat.length;\n\n/**\n * Calculates the squared length of a quat\n *\n * @param {quat} a vector to calculate squared length of\n * @returns {Number} squared length of a\n * @function\n */\nquat.squaredLength = vec4.squaredLength;\n\n/**\n * Alias for {@link quat.squaredLength}\n * @function\n */\nquat.sqrLen = quat.squaredLength;\n\n/**\n * Normalize a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quaternion to normalize\n * @returns {quat} out\n * @function\n */\nquat.normalize = vec4.normalize;\n\n/**\n * Creates a quaternion from the given 3x3 rotation matrix.\n *\n * NOTE: The resultant quaternion is not normalized, so you should be sure\n * to renormalize the quaternion yourself where necessary.\n *\n * @param {quat} out the receiving quaternion\n * @param {mat3} m rotation matrix\n * @returns {quat} out\n * @function\n */\nquat.fromMat3 = function(out, m) {\n    // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n    // article \"Quaternion Calculus and Fast Animation\".\n    var fTrace = m[0] + m[4] + m[8];\n    var fRoot;\n\n    if ( fTrace > 0.0 ) {\n        // |w| > 1/2, may as well choose w > 1/2\n        fRoot = Math.sqrt(fTrace + 1.0);  // 2w\n        out[3] = 0.5 * fRoot;\n        fRoot = 0.5/fRoot;  // 1/(4w)\n        out[0] = (m[5]-m[7])*fRoot;\n        out[1] = (m[6]-m[2])*fRoot;\n        out[2] = (m[1]-m[3])*fRoot;\n    } else {\n        // |w| <= 1/2\n        var i = 0;\n        if ( m[4] > m[0] )\n          i = 1;\n        if ( m[8] > m[i*3+i] )\n          i = 2;\n        var j = (i+1)%3;\n        var k = (i+2)%3;\n        \n        fRoot = Math.sqrt(m[i*3+i]-m[j*3+j]-m[k*3+k] + 1.0);\n        out[i] = 0.5 * fRoot;\n        fRoot = 0.5 / fRoot;\n        out[3] = (m[j*3+k] - m[k*3+j]) * fRoot;\n        out[j] = (m[j*3+i] + m[i*3+j]) * fRoot;\n        out[k] = (m[k*3+i] + m[i*3+k]) * fRoot;\n    }\n    \n    return out;\n};\n\n/**\n * Returns a string representation of a quatenion\n *\n * @param {quat} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nquat.str = function (a) {\n    return 'quat(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nmodule.exports = quat;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/quat.js\n ** module id = 13\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\nvar glMatrix = require(\"./common.js\");\n\n/**\n * @class 3 Dimensional Vector\n * @name vec3\n */\nvar vec3 = {};\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\nvec3.create = function() {\n    var out = new glMatrix.ARRAY_TYPE(3);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    return out;\n};\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 */\nvec3.clone = function(a) {\n    var out = new glMatrix.ARRAY_TYPE(3);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\nvec3.fromValues = function(x, y, z) {\n    var out = new glMatrix.ARRAY_TYPE(3);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the source vector\n * @returns {vec3} out\n */\nvec3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\nvec3.set = function(out, x, y, z) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Adds two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.subtract}\n * @function\n */\nvec3.sub = vec3.subtract;\n\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.multiply}\n * @function\n */\nvec3.mul = vec3.multiply;\n\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.divide}\n * @function\n */\nvec3.div = vec3.divide;\n\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    return out;\n};\n\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\nvec3.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    return out;\n};\n\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\nvec3.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} distance between a and b\n */\nvec3.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.distance}\n * @function\n */\nvec3.dist = vec3.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec3.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredDistance}\n * @function\n */\nvec3.sqrDist = vec3.squaredDistance;\n\n/**\n * Calculates the length of a vec3\n *\n * @param {vec3} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec3.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.length}\n * @function\n */\nvec3.len = vec3.length;\n\n/**\n * Calculates the squared length of a vec3\n *\n * @param {vec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec3.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredLength}\n * @function\n */\nvec3.sqrLen = vec3.squaredLength;\n\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to negate\n * @returns {vec3} out\n */\nvec3.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    return out;\n};\n\n/**\n * Returns the inverse of the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to invert\n * @returns {vec3} out\n */\nvec3.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  out[2] = 1.0 / a[2];\n  return out;\n};\n\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to normalize\n * @returns {vec3} out\n */\nvec3.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    var len = x*x + y*y + z*z;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec3.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n};\n\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.cross = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2],\n        bx = b[0], by = b[1], bz = b[2];\n\n    out[0] = ay * bz - az * by;\n    out[1] = az * bx - ax * bz;\n    out[2] = ax * by - ay * bx;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec3} out\n */\nvec3.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    return out;\n};\n\n/**\n * Performs a hermite interpolation with two control points\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {vec3} c the third operand\n * @param {vec3} d the fourth operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec3} out\n */\nvec3.hermite = function (out, a, b, c, d, t) {\n  var factorTimes2 = t * t,\n      factor1 = factorTimes2 * (2 * t - 3) + 1,\n      factor2 = factorTimes2 * (t - 2) + t,\n      factor3 = factorTimes2 * (t - 1),\n      factor4 = factorTimes2 * (3 - 2 * t);\n  \n  out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n  out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n  out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n  \n  return out;\n};\n\n/**\n * Performs a bezier interpolation with two control points\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {vec3} c the third operand\n * @param {vec3} d the fourth operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec3} out\n */\nvec3.bezier = function (out, a, b, c, d, t) {\n  var inverseFactor = 1 - t,\n      inverseFactorTimesTwo = inverseFactor * inverseFactor,\n      factorTimes2 = t * t,\n      factor1 = inverseFactorTimesTwo * inverseFactor,\n      factor2 = 3 * t * inverseFactorTimesTwo,\n      factor3 = 3 * factorTimes2 * inverseFactor,\n      factor4 = factorTimes2 * t;\n  \n  out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n  out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n  out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n  \n  return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec3} out\n */\nvec3.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n    var z = (glMatrix.RANDOM() * 2.0) - 1.0;\n    var zScale = Math.sqrt(1.0-z*z) * scale;\n\n    out[0] = Math.cos(r) * zScale;\n    out[1] = Math.sin(r) * zScale;\n    out[2] = z * scale;\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2],\n        w = m[3] * x + m[7] * y + m[11] * z + m[15];\n    w = w || 1.0;\n    out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w;\n    out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w;\n    out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w;\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat3 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2];\n    out[0] = x * m[0] + y * m[3] + z * m[6];\n    out[1] = x * m[1] + y * m[4] + z * m[7];\n    out[2] = x * m[2] + y * m[5] + z * m[8];\n    return out;\n};\n\n/**\n * Transforms the vec3 with a quat\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec3} out\n */\nvec3.transformQuat = function(out, a, q) {\n    // benchmarks: http://jsperf.com/quaternion-transform-vec3-implementations\n\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/**\n * Rotate a 3D vector around the x-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateX = function(out, a, b, c){\n   var p = [], r=[];\n\t  //Translate point to the origin\n\t  p[0] = a[0] - b[0];\n\t  p[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n\n\t  //perform rotation\n\t  r[0] = p[0];\n\t  r[1] = p[1]*Math.cos(c) - p[2]*Math.sin(c);\n\t  r[2] = p[1]*Math.sin(c) + p[2]*Math.cos(c);\n\n\t  //translate to correct position\n\t  out[0] = r[0] + b[0];\n\t  out[1] = r[1] + b[1];\n\t  out[2] = r[2] + b[2];\n\n  \treturn out;\n};\n\n/**\n * Rotate a 3D vector around the y-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateY = function(out, a, b, c){\n  \tvar p = [], r=[];\n  \t//Translate point to the origin\n  \tp[0] = a[0] - b[0];\n  \tp[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n  \n  \t//perform rotation\n  \tr[0] = p[2]*Math.sin(c) + p[0]*Math.cos(c);\n  \tr[1] = p[1];\n  \tr[2] = p[2]*Math.cos(c) - p[0]*Math.sin(c);\n  \n  \t//translate to correct position\n  \tout[0] = r[0] + b[0];\n  \tout[1] = r[1] + b[1];\n  \tout[2] = r[2] + b[2];\n  \n  \treturn out;\n};\n\n/**\n * Rotate a 3D vector around the z-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateZ = function(out, a, b, c){\n  \tvar p = [], r=[];\n  \t//Translate point to the origin\n  \tp[0] = a[0] - b[0];\n  \tp[1] = a[1] - b[1];\n  \tp[2] = a[2] - b[2];\n  \n  \t//perform rotation\n  \tr[0] = p[0]*Math.cos(c) - p[1]*Math.sin(c);\n  \tr[1] = p[0]*Math.sin(c) + p[1]*Math.cos(c);\n  \tr[2] = p[2];\n  \n  \t//translate to correct position\n  \tout[0] = r[0] + b[0];\n  \tout[1] = r[1] + b[1];\n  \tout[2] = r[2] + b[2];\n  \n  \treturn out;\n};\n\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec3.forEach = (function() {\n    var vec = vec3.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 3;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Get the angle between two 3D vectors\n * @param {vec3} a The first operand\n * @param {vec3} b The second operand\n * @returns {Number} The angle in radians\n */\nvec3.angle = function(a, b) {\n   \n    var tempA = vec3.fromValues(a[0], a[1], a[2]);\n    var tempB = vec3.fromValues(b[0], b[1], b[2]);\n \n    vec3.normalize(tempA, tempA);\n    vec3.normalize(tempB, tempB);\n \n    var cosine = vec3.dot(tempA, tempB);\n\n    if(cosine > 1.0){\n        return 0;\n    } else {\n        return Math.acos(cosine);\n    }     \n};\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec3} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec3.str = function (a) {\n    return 'vec3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ')';\n};\n\nmodule.exports = vec3;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/vec3.js\n ** module id = 14\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\nvar glMatrix = require(\"./common.js\");\n\n/**\n * @class 4 Dimensional Vector\n * @name vec4\n */\nvar vec4 = {};\n\n/**\n * Creates a new, empty vec4\n *\n * @returns {vec4} a new 4D vector\n */\nvec4.create = function() {\n    var out = new glMatrix.ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with values from an existing vector\n *\n * @param {vec4} a vector to clone\n * @returns {vec4} a new 4D vector\n */\nvec4.clone = function(a) {\n    var out = new glMatrix.ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} a new 4D vector\n */\nvec4.fromValues = function(x, y, z, w) {\n    var out = new glMatrix.ARRAY_TYPE(4);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Copy the values from one vec4 to another\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the source vector\n * @returns {vec4} out\n */\nvec4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set the components of a vec4 to the given values\n *\n * @param {vec4} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} out\n */\nvec4.set = function(out, x, y, z, w) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Adds two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    out[3] = a[3] + b[3];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    out[3] = a[3] - b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.subtract}\n * @function\n */\nvec4.sub = vec4.subtract;\n\n/**\n * Multiplies two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    out[3] = a[3] * b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.multiply}\n * @function\n */\nvec4.mul = vec4.multiply;\n\n/**\n * Divides two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    out[3] = a[3] / b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.divide}\n * @function\n */\nvec4.div = vec4.divide;\n\n/**\n * Returns the minimum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    out[3] = Math.min(a[3], b[3]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    out[3] = Math.max(a[3], b[3]);\n    return out;\n};\n\n/**\n * Scales a vec4 by a scalar number\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec4} out\n */\nvec4.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    out[3] = a[3] * b;\n    return out;\n};\n\n/**\n * Adds two vec4's after scaling the second operand by a scalar value\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec4} out\n */\nvec4.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    out[3] = a[3] + (b[3] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} distance between a and b\n */\nvec4.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.distance}\n * @function\n */\nvec4.dist = vec4.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec4.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredDistance}\n * @function\n */\nvec4.sqrDist = vec4.squaredDistance;\n\n/**\n * Calculates the length of a vec4\n *\n * @param {vec4} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec4.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.length}\n * @function\n */\nvec4.len = vec4.length;\n\n/**\n * Calculates the squared length of a vec4\n *\n * @param {vec4} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec4.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredLength}\n * @function\n */\nvec4.sqrLen = vec4.squaredLength;\n\n/**\n * Negates the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to negate\n * @returns {vec4} out\n */\nvec4.negate = function(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 * Returns the inverse of the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to invert\n * @returns {vec4} out\n */\nvec4.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  out[2] = 1.0 / a[2];\n  out[3] = 1.0 / a[3];\n  return out;\n};\n\n/**\n * Normalize a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to normalize\n * @returns {vec4} out\n */\nvec4.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    var len = x*x + y*y + z*z + w*w;\n    if (len > 0) {\n        len = 1 / Math.sqrt(len);\n        out[0] = x * len;\n        out[1] = y * len;\n        out[2] = z * len;\n        out[3] = w * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec4.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n};\n\n/**\n * Performs a linear interpolation between two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec4} out\n */\nvec4.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2],\n        aw = a[3];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    out[3] = aw + t * (b[3] - aw);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec4} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec4} out\n */\nvec4.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    //TODO: This is a pretty awful way of doing this. Find something better.\n    out[0] = glMatrix.RANDOM();\n    out[1] = glMatrix.RANDOM();\n    out[2] = glMatrix.RANDOM();\n    out[3] = glMatrix.RANDOM();\n    vec4.normalize(out, out);\n    vec4.scale(out, out, scale);\n    return out;\n};\n\n/**\n * Transforms the vec4 with a mat4.\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec4} out\n */\nvec4.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2], w = a[3];\n    out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n    out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n    out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n    out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n    return out;\n};\n\n/**\n * Transforms the vec4 with a quat\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec4} out\n */\nvec4.transformQuat = function(out, a, q) {\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec4s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec4s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec4.forEach = (function() {\n    var vec = vec4.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 4;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2]; vec[3] = a[i+3];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2]; a[i+3] = vec[3];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec4} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec4.str = function (a) {\n    return 'vec4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nmodule.exports = vec4;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/vec4.js\n ** module id = 15\n ** module chunks = 0\n **/","/* Copyright (c) 2015, Brandon Jones, Colin MacKenzie IV.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE. */\n\nvar glMatrix = require(\"./common.js\");\n\n/**\n * @class 2 Dimensional Vector\n * @name vec2\n */\nvar vec2 = {};\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\nvec2.create = function() {\n    var out = new glMatrix.ARRAY_TYPE(2);\n    out[0] = 0;\n    out[1] = 0;\n    return out;\n};\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 */\nvec2.clone = function(a) {\n    var out = new glMatrix.ARRAY_TYPE(2);\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\nvec2.fromValues = function(x, y) {\n    var out = new glMatrix.ARRAY_TYPE(2);\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the source vector\n * @returns {vec2} out\n */\nvec2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\nvec2.set = function(out, x, y) {\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.subtract}\n * @function\n */\nvec2.sub = vec2.subtract;\n\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.multiply}\n * @function\n */\nvec2.mul = vec2.multiply;\n\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.divide}\n * @function\n */\nvec2.div = vec2.divide;\n\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    return out;\n};\n\n/**\n * 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 */\nvec2.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    return out;\n};\n\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\nvec2.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} distance between a and b\n */\nvec2.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.distance}\n * @function\n */\nvec2.dist = vec2.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec2.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredDistance}\n * @function\n */\nvec2.sqrDist = vec2.squaredDistance;\n\n/**\n * Calculates the length of a vec2\n *\n * @param {vec2} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec2.length = function (a) {\n    var x = a[0],\n        y = a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.length}\n * @function\n */\nvec2.len = vec2.length;\n\n/**\n * Calculates the squared length of a vec2\n *\n * @param {vec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec2.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredLength}\n * @function\n */\nvec2.sqrLen = vec2.squaredLength;\n\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to negate\n * @returns {vec2} out\n */\nvec2.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    return out;\n};\n\n/**\n * Returns the inverse of the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to invert\n * @returns {vec2} out\n */\nvec2.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  return out;\n};\n\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to normalize\n * @returns {vec2} out\n */\nvec2.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1];\n    var len = x*x + y*y;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n    }\n    return out;\n};\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 */\nvec2.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1];\n};\n\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec3} out\n */\nvec2.cross = function(out, a, b) {\n    var z = a[0] * b[1] - a[1] * b[0];\n    out[0] = out[1] = 0;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec2} out\n */\nvec2.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\nvec2.random = function (out, scale) {\n    scale = scale || 1.0;\n    var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n    out[0] = Math.cos(r) * scale;\n    out[1] = Math.sin(r) * scale;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y;\n    out[1] = m[1] * x + m[3] * y;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2d} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2d = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y + m[4];\n    out[1] = m[1] * x + m[3] * y + m[5];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat3} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat3 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[3] * y + m[6];\n    out[1] = m[1] * x + m[4] * y + m[7];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat4 = function(out, a, m) {\n    var x = a[0], \n        y = a[1];\n    out[0] = m[0] * x + m[4] * y + m[12];\n    out[1] = m[1] * x + m[5] * y + m[13];\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec2.forEach = (function() {\n    var vec = vec2.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 2;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n        \n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1];\n        }\n        \n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec2} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec2.str = function (a) {\n    return 'vec2(' + a[0] + ', ' + a[1] + ')';\n};\n\nmodule.exports = vec2;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gl-matrix/src/gl-matrix/vec2.js\n ** module id = 16\n ** module chunks = 0\n **/","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 ** D:/work/quaggaJS/src/common/array_helper.js\n **/","import ImageWrapper from '../common/image_wrapper';\r\nimport CVUtils 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\nimport {vec2, mat2} from 'gl-matrix';\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 = CVUtils.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.clone([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    CVUtils.otsuThreshold(_currentImageWrapper, _binaryImageWrapper);\r\n    _binaryImageWrapper.zeroBorder();\r\n    if (_config.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                    CVUtils.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 = CVUtils.cluster(moments, 0.90);\r\n    var topCluster = CVUtils.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, CVUtils.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, CVUtils.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                CVUtils.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            CVUtils.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 = CVUtils.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 = CVUtils.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 ** D:/work/quaggaJS/src/locator/barcode_locator.js\n **/","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 ** D:/work/quaggaJS/src/common/image_debug.js\n **/","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 ** D:/work/quaggaJS/src/locator/rasterizer.js\n **/","/**\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 ** D:/work/quaggaJS/src/locator/tracer.js\n **/","/* @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\r\n    return {\r\n        skeletonize: skeletonize\r\n    };\r\n}\r\n\r\nexport default Skeletonizer;\r\n/* eslint-enable eqeqeq*/\r\n/* @preserve ASM END */\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/locator/skeletonizer.js\n **/","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 UPCEReader from '../reader/upc_e_reader';\r\nimport I2of5Reader from '../reader/i2of5_reader';\r\n\r\nconst READERS = {\r\n    code_128_reader: Code128Reader,\r\n    ean_reader: EANReader,\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};\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\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                _barcodeReaders.push(new READERS[reader](configuration));\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 ** D:/work/quaggaJS/src/decoder/barcode_decoder.js\n **/","import CVUtils from '../common/cv_utils';\r\nimport 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\nBresenham.toOtsuBinaryLine = function(result) {\r\n    var line = result.line,\r\n        image = new ImageWrapper({x: line.length - 1, y: 1}, line),\r\n        threshold = CVUtils.determineOtsuThreshold(image, 5);\r\n\r\n    line = CVUtils.sharpenLine(line);\r\n    CVUtils.thresholdImage(image, threshold);\r\n\r\n    return {\r\n        line: line,\r\n        threshold: threshold\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 ** D:/work/quaggaJS/src/decoder/bresenham.js\n **/","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    MODULO: {value: 11},\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: 1},\r\n    AVG_CODE_ERROR: {value: 0.5},\r\n    FORMAT: {value: \"code_128\", writeable: false}\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) {\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        },\r\n        code,\r\n        error,\r\n        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n                        error = self._matchPattern(normalized, 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                    return bestMatch;\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\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        },\r\n        code,\r\n        error,\r\n        j,\r\n        sum,\r\n        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) {\r\n                        error = self._matchPattern(normalized, 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                        return bestMatch;\r\n                    }\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    };\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);\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\nexport default Code128Reader;\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/reader/code_128_reader.js\n **/","function BarcodeReader(config) {\r\n    this._row = [];\r\n    this.config = config || {};\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) {\r\n    var i,\r\n        error = 0,\r\n        singleError = 0,\r\n        modulo = this.MODULO,\r\n        maxSingleError = this.SINGLE_CODE_ERROR || 1;\r\n\r\n    for (i = 0; i < counter.length; i++) {\r\n        singleError = Math.abs(code[i] - counter[i]);\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._normalize = function(counter, modulo) {\r\n    var i,\r\n        self = this,\r\n        sum = 0,\r\n        ratio,\r\n        numOnes = 0,\r\n        normalized = [],\r\n        norm = 0;\r\n\r\n    if (!modulo) {\r\n        modulo = self.MODULO;\r\n    }\r\n    for (i = 0; i < counter.length; i++) {\r\n        if (counter[i] === 1) {\r\n            numOnes++;\r\n        } else {\r\n            sum += counter[i];\r\n        }\r\n    }\r\n    ratio = sum / (modulo - numOnes);\r\n    if (ratio > 1.0) {\r\n        for (i = 0; i < counter.length; i++) {\r\n            norm = counter[i] === 1 ? counter[i] : counter[i] / ratio;\r\n            normalized.push(norm);\r\n        }\r\n    } else {\r\n        ratio = (sum + numOnes) / modulo;\r\n        for (i = 0; i < counter.length; i++) {\r\n            norm = counter[i] / ratio;\r\n            normalized.push(norm);\r\n        }\r\n    }\r\n    return normalized;\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\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 ** D:/work/quaggaJS/src/reader/barcode_reader.js\n **/","import BarcodeReader from './barcode_reader';\r\n\r\nfunction EANReader(opts) {\r\n    BarcodeReader.call(this, opts);\r\n}\r\n\r\nvar properties = {\r\n    CODE_L_START: {value: 0},\r\n    MODULO: {value: 7},\r\n    CODE_G_START: {value: 10},\r\n    START_PATTERN: {value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7]},\r\n    STOP_PATTERN: {value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7]},\r\n    MIDDLE_PATTERN: {value: [1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7]},\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.67},\r\n    AVG_CODE_ERROR: {value: 0.27},\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        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = 0; code < coderange; code++) {\r\n                        error = self._matchPattern(normalized, 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                }\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        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    error = self._matchPattern(normalized, 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                }\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\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    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    };\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\nexport default (EANReader);\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/reader/ean_reader.js\n **/","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._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\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 ** D:/work/quaggaJS/src/reader/code_39_reader.js\n **/","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 ** D:/work/quaggaJS/src/reader/code_39_vin_reader.js\n **/","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 ** D:/work/quaggaJS/src/reader/codabar_reader.js\n **/","import EANReader from './ean_reader';\r\n\r\nfunction UPCReader() {\r\n    EANReader.call(this);\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 ** D:/work/quaggaJS/src/reader/upc_reader.js\n **/","import EANReader from './ean_reader';\r\n\r\nfunction EAN8Reader() {\r\n    EANReader.call(this);\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 ** D:/work/quaggaJS/src/reader/ean_8_reader.js\n **/","import EANReader from './ean_reader';\r\n\r\nfunction UPCEReader() {\r\n    EANReader.call(this);\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 ** D:/work/quaggaJS/src/reader/upc_e_reader.js\n **/","import BarcodeReader from './barcode_reader';\r\nconst merge = require('lodash/object/merge');\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        MODULO: {value: 10},\r\n        START_PATTERN: {value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5]},\r\n        STOP_PATTERN: {value: [N * 2, N * 2, W * 2]},\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    error = self._matchPattern(normalized, 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                }\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    normalized = self._normalize(counter);\r\n    if (normalized) {\r\n        for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n            error = self._matchPattern(normalized, 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    return null;\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 ** D:/work/quaggaJS/src/reader/i2of5_reader.js\n **/","var baseMerge = require('../internal/baseMerge'),\n    createAssigner = require('../internal/createAssigner');\n\n/**\n * Recursively merges own enumerable properties of the source object(s), that\n * don't resolve to `undefined` into the destination object. Subsequent sources\n * overwrite property assignments of previous sources. If `customizer` is\n * provided it's invoked to produce the merged values of the destination and\n * source properties. If `customizer` returns `undefined` merging is handled\n * by the method instead. The `customizer` is bound to `thisArg` and invoked\n * with five arguments: (objectValue, sourceValue, key, object, source).\n *\n * @static\n * @memberOf _\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {*} [thisArg] The `this` binding of `customizer`.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var users = {\n *   'data': [{ 'user': 'barney' }, { 'user': 'fred' }]\n * };\n *\n * var ages = {\n *   'data': [{ 'age': 36 }, { 'age': 40 }]\n * };\n *\n * _.merge(users, ages);\n * // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] }\n *\n * // using a customizer callback\n * var object = {\n *   'fruits': ['apple'],\n *   'vegetables': ['beet']\n * };\n *\n * var other = {\n *   'fruits': ['banana'],\n *   'vegetables': ['carrot']\n * };\n *\n * _.merge(object, other, function(a, b) {\n *   if (_.isArray(a)) {\n *     return a.concat(b);\n *   }\n * });\n * // => { 'fruits': ['apple', 'banana'], 'vegetables': ['beet', 'carrot'] }\n */\nvar merge = createAssigner(baseMerge);\n\nmodule.exports = merge;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/object/merge.js\n ** module id = 35\n ** module chunks = 0\n **/","var arrayEach = require('./arrayEach'),\n    baseMergeDeep = require('./baseMergeDeep'),\n    isArray = require('../lang/isArray'),\n    isArrayLike = require('./isArrayLike'),\n    isObject = require('../lang/isObject'),\n    isObjectLike = require('./isObjectLike'),\n    isTypedArray = require('../lang/isTypedArray'),\n    keys = require('../object/keys');\n\n/**\n * The base implementation of `_.merge` without support for argument juggling,\n * multiple sources, and `this` binding `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Array} [stackA=[]] Tracks traversed source objects.\n * @param {Array} [stackB=[]] Associates values with source counterparts.\n * @returns {Object} Returns `object`.\n */\nfunction baseMerge(object, source, customizer, stackA, stackB) {\n  if (!isObject(object)) {\n    return object;\n  }\n  var isSrcArr = isArrayLike(source) && (isArray(source) || isTypedArray(source)),\n      props = isSrcArr ? undefined : keys(source);\n\n  arrayEach(props || source, function(srcValue, key) {\n    if (props) {\n      key = srcValue;\n      srcValue = source[key];\n    }\n    if (isObjectLike(srcValue)) {\n      stackA || (stackA = []);\n      stackB || (stackB = []);\n      baseMergeDeep(object, source, key, baseMerge, customizer, stackA, stackB);\n    }\n    else {\n      var value = object[key],\n          result = customizer ? customizer(value, srcValue, key, object, source) : undefined,\n          isCommon = result === undefined;\n\n      if (isCommon) {\n        result = srcValue;\n      }\n      if ((result !== undefined || (isSrcArr && !(key in object))) &&\n          (isCommon || (result === result ? (result !== value) : (value === value)))) {\n        object[key] = result;\n      }\n    }\n  });\n  return object;\n}\n\nmodule.exports = baseMerge;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseMerge.js\n ** module id = 36\n ** module chunks = 0\n **/","/**\n * A specialized version of `_.forEach` for arrays without support for callback\n * shorthands and `this` binding.\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 `array`.\n */\nfunction arrayEach(array, iteratee) {\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    if (iteratee(array[index], index, array) === false) {\n      break;\n    }\n  }\n  return array;\n}\n\nmodule.exports = arrayEach;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/arrayEach.js\n ** module id = 37\n ** module chunks = 0\n **/","var arrayCopy = require('./arrayCopy'),\n    isArguments = require('../lang/isArguments'),\n    isArray = require('../lang/isArray'),\n    isArrayLike = require('./isArrayLike'),\n    isPlainObject = require('../lang/isPlainObject'),\n    isTypedArray = require('../lang/isTypedArray'),\n    toPlainObject = require('../lang/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 {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Array} [stackA=[]] Tracks traversed source objects.\n * @param {Array} [stackB=[]] Associates values with source counterparts.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseMergeDeep(object, source, key, mergeFunc, customizer, stackA, stackB) {\n  var length = stackA.length,\n      srcValue = source[key];\n\n  while (length--) {\n    if (stackA[length] == srcValue) {\n      object[key] = stackB[length];\n      return;\n    }\n  }\n  var value = object[key],\n      result = customizer ? customizer(value, srcValue, key, object, source) : undefined,\n      isCommon = result === undefined;\n\n  if (isCommon) {\n    result = srcValue;\n    if (isArrayLike(srcValue) && (isArray(srcValue) || isTypedArray(srcValue))) {\n      result = isArray(value)\n        ? value\n        : (isArrayLike(value) ? arrayCopy(value) : []);\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      result = isArguments(value)\n        ? toPlainObject(value)\n        : (isPlainObject(value) ? value : {});\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  // Add the source value to the stack of traversed objects and associate\n  // it with its merged value.\n  stackA.push(srcValue);\n  stackB.push(result);\n\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    object[key] = mergeFunc(result, srcValue, customizer, stackA, stackB);\n  } else if (result === result ? (result !== value) : (value === value)) {\n    object[key] = result;\n  }\n}\n\nmodule.exports = baseMergeDeep;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseMergeDeep.js\n ** module id = 38\n ** module chunks = 0\n **/","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction arrayCopy(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 = arrayCopy;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/arrayCopy.js\n ** module id = 39\n ** module chunks = 0\n **/","var isArrayLike = require('../internal/isArrayLike'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Native method references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is classified as an `arguments` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nfunction isArguments(value) {\n  return isObjectLike(value) && isArrayLike(value) &&\n    hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee');\n}\n\nmodule.exports = isArguments;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isArguments.js\n ** module id = 40\n ** module chunks = 0\n **/","var getLength = require('./getLength'),\n    isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(getLength(value));\n}\n\nmodule.exports = isArrayLike;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isArrayLike.js\n ** module id = 41\n ** module chunks = 0\n **/","var baseProperty = require('./baseProperty');\n\n/**\n * Gets the \"length\" property value of `object`.\n *\n * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792)\n * that affects Safari on at least iOS 8.1-8.3 ARM64.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {*} Returns the \"length\" value.\n */\nvar getLength = baseProperty('length');\n\nmodule.exports = getLength;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/getLength.js\n ** module id = 42\n ** module chunks = 0\n **/","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new function.\n */\nfunction baseProperty(key) {\n  return function(object) {\n    return object == null ? undefined : object[key];\n  };\n}\n\nmodule.exports = baseProperty;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseProperty.js\n ** module id = 43\n ** module chunks = 0\n **/","/**\n * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer)\n * of an array-like value.\n */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength).\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n */\nfunction isLength(value) {\n  return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isLength.js\n ** module id = 44\n ** module chunks = 0\n **/","/**\n * Checks if `value` is object-like.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isObjectLike.js\n ** module id = 45\n ** module chunks = 0\n **/","var getNative = require('../internal/getNative'),\n    isLength = require('../internal/isLength'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** `Object#toString` result references. */\nvar arrayTag = '[object Array]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeIsArray = getNative(Array, 'isArray');\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(function() { return arguments; }());\n * // => false\n */\nvar isArray = nativeIsArray || function(value) {\n  return isObjectLike(value) && isLength(value.length) && objToString.call(value) == arrayTag;\n};\n\nmodule.exports = isArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isArray.js\n ** module id = 46\n ** module chunks = 0\n **/","var isNative = require('../lang/isNative');\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 = object == null ? undefined : object[key];\n  return isNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/getNative.js\n ** module id = 47\n ** module chunks = 0\n **/","var isFunction = require('./isFunction'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** Used to detect host constructors (Safari > 5). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar fnToString = Function.prototype.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  fnToString.call(hasOwnProperty).replace(/[\\\\^$.*+?()[\\]{}|]/g, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * Checks if `value` is a native function.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function, else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\nfunction isNative(value) {\n  if (value == null) {\n    return false;\n  }\n  if (isFunction(value)) {\n    return reIsNative.test(fnToString.call(value));\n  }\n  return isObjectLike(value) && reIsHostCtor.test(value);\n}\n\nmodule.exports = isNative;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isNative.js\n ** module id = 48\n ** module chunks = 0\n **/","var isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar funcTag = '[object Function]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in older versions of Chrome and Safari which return 'function' for regexes\n  // and Safari 8 which returns 'object' for typed array constructors.\n  return isObject(value) && objToString.call(value) == funcTag;\n}\n\nmodule.exports = isFunction;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isFunction.js\n ** module id = 49\n ** module chunks = 0\n **/","/**\n * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`.\n * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\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(1);\n * // => false\n */\nfunction isObject(value) {\n  // Avoid a V8 JIT bug in Chrome 19-20.\n  // See https://code.google.com/p/v8/issues/detail?id=2291 for more details.\n  var type = typeof value;\n  return !!value && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isObject.js\n ** module id = 50\n ** module chunks = 0\n **/","var baseForIn = require('../internal/baseForIn'),\n    isArguments = require('./isArguments'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for native 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 [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\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 * **Note:** This method assumes objects created by the `Object` constructor\n * have no inherited enumerable properties.\n *\n * @static\n * @memberOf _\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  var Ctor;\n\n  // Exit early for non `Object` objects.\n  if (!(isObjectLike(value) && objToString.call(value) == objectTag && !isArguments(value)) ||\n      (!hasOwnProperty.call(value, 'constructor') && (Ctor = value.constructor, typeof Ctor == 'function' && !(Ctor instanceof Ctor)))) {\n    return false;\n  }\n  // IE < 9 iterates inherited properties before own properties. If the first\n  // iterated property is an object's own property then there are no inherited\n  // enumerable properties.\n  var result;\n  // In most environments an object's own properties are iterated before\n  // its inherited properties. If the last iterated property is an object's\n  // own property then there are no inherited enumerable properties.\n  baseForIn(value, function(subValue, key) {\n    result = key;\n  });\n  return result === undefined || hasOwnProperty.call(value, result);\n}\n\nmodule.exports = isPlainObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isPlainObject.js\n ** module id = 51\n ** module chunks = 0\n **/","var baseFor = require('./baseFor'),\n    keysIn = require('../object/keysIn');\n\n/**\n * The base implementation of `_.forIn` without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForIn(object, iteratee) {\n  return baseFor(object, iteratee, keysIn);\n}\n\nmodule.exports = baseForIn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseForIn.js\n ** module id = 52\n ** module chunks = 0\n **/","var createBaseFor = require('./createBaseFor');\n\n/**\n * The base implementation of `baseForIn` and `baseForOwn` which iterates\n * over `object` properties returned by `keysFunc` invoking `iteratee` for\n * each property. Iteratee functions may exit iteration early by explicitly\n * 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/internal/baseFor.js\n ** module id = 53\n ** module chunks = 0\n **/","var toObject = require('./toObject');\n\n/**\n * Creates a base function for `_.forIn` or `_.forInRight`.\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 iterable = toObject(object),\n        props = keysFunc(object),\n        length = props.length,\n        index = fromRight ? length : -1;\n\n    while ((fromRight ? index-- : ++index < length)) {\n      var key = props[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/internal/createBaseFor.js\n ** module id = 54\n ** module chunks = 0\n **/","var isObject = require('../lang/isObject');\n\n/**\n * Converts `value` to an object if it's not one.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {Object} Returns the object.\n */\nfunction toObject(value) {\n  return isObject(value) ? value : Object(value);\n}\n\nmodule.exports = toObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/toObject.js\n ** module id = 55\n ** module chunks = 0\n **/","var isArguments = require('../lang/isArguments'),\n    isArray = require('../lang/isArray'),\n    isIndex = require('../internal/isIndex'),\n    isLength = require('../internal/isLength'),\n    isObject = require('../lang/isObject');\n\n/** Used for native 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 own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\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  if (object == null) {\n    return [];\n  }\n  if (!isObject(object)) {\n    object = Object(object);\n  }\n  var length = object.length;\n  length = (length && isLength(length) &&\n    (isArray(object) || isArguments(object)) && length) || 0;\n\n  var Ctor = object.constructor,\n      index = -1,\n      isProto = typeof Ctor == 'function' && Ctor.prototype === object,\n      result = Array(length),\n      skipIndexes = length > 0;\n\n  while (++index < length) {\n    result[index] = (index + '');\n  }\n  for (var key in object) {\n    if (!(skipIndexes && isIndex(key, length)) &&\n        !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = keysIn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/object/keysIn.js\n ** module id = 56\n ** module chunks = 0\n **/","/** Used to detect unsigned integer values. */\nvar reIsUint = /^\\d+$/;\n\n/**\n * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer)\n * of an array-like value.\n */\nvar MAX_SAFE_INTEGER = 9007199254740991;\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  value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1;\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return value > -1 && value % 1 == 0 && value < length;\n}\n\nmodule.exports = isIndex;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isIndex.js\n ** module id = 57\n ** module chunks = 0\n **/","var isLength = require('../internal/isLength'),\n    isObjectLike = require('../internal/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    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[dateTag] = typedArrayTags[errorTag] =\ntypedArrayTags[funcTag] = typedArrayTags[mapTag] =\ntypedArrayTags[numberTag] = typedArrayTags[objectTag] =\ntypedArrayTags[regexpTag] = typedArrayTags[setTag] =\ntypedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nfunction isTypedArray(value) {\n  return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objToString.call(value)];\n}\n\nmodule.exports = isTypedArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isTypedArray.js\n ** module id = 58\n ** module chunks = 0\n **/","var baseCopy = require('../internal/baseCopy'),\n    keysIn = require('../object/keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable\n * properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\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 baseCopy(value, keysIn(value));\n}\n\nmodule.exports = toPlainObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/toPlainObject.js\n ** module id = 59\n ** module chunks = 0\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 names to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @returns {Object} Returns `object`.\n */\nfunction baseCopy(source, props, object) {\n  object || (object = {});\n\n  var index = -1,\n      length = props.length;\n\n  while (++index < length) {\n    var key = props[index];\n    object[key] = source[key];\n  }\n  return object;\n}\n\nmodule.exports = baseCopy;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseCopy.js\n ** module id = 60\n ** module chunks = 0\n **/","var getNative = require('../internal/getNative'),\n    isArrayLike = require('../internal/isArrayLike'),\n    isObject = require('../lang/isObject'),\n    shimKeys = require('../internal/shimKeys');\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = getNative(Object, 'keys');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @memberOf _\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 * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nvar keys = !nativeKeys ? shimKeys : function(object) {\n  var Ctor = object == null ? undefined : object.constructor;\n  if ((typeof Ctor == 'function' && Ctor.prototype === object) ||\n      (typeof object != 'function' && isArrayLike(object))) {\n    return shimKeys(object);\n  }\n  return isObject(object) ? nativeKeys(object) : [];\n};\n\nmodule.exports = keys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/object/keys.js\n ** module id = 61\n ** module chunks = 0\n **/","var isArguments = require('../lang/isArguments'),\n    isArray = require('../lang/isArray'),\n    isIndex = require('./isIndex'),\n    isLength = require('./isLength'),\n    keysIn = require('../object/keysIn');\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A fallback implementation of `Object.keys` which creates an array of the\n * own enumerable property names of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction shimKeys(object) {\n  var props = keysIn(object),\n      propsLength = props.length,\n      length = propsLength && object.length;\n\n  var allowIndexes = !!length && isLength(length) &&\n    (isArray(object) || isArguments(object));\n\n  var index = -1,\n      result = [];\n\n  while (++index < propsLength) {\n    var key = props[index];\n    if ((allowIndexes && isIndex(key, length)) || hasOwnProperty.call(object, key)) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = shimKeys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/shimKeys.js\n ** module id = 62\n ** module chunks = 0\n **/","var bindCallback = require('./bindCallback'),\n    isIterateeCall = require('./isIterateeCall'),\n    restParam = require('../function/restParam');\n\n/**\n * Creates a `_.assign`, `_.defaults`, or `_.merge` function.\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 restParam(function(object, sources) {\n    var index = -1,\n        length = object == null ? 0 : sources.length,\n        customizer = length > 2 ? sources[length - 2] : undefined,\n        guard = length > 2 ? sources[2] : undefined,\n        thisArg = length > 1 ? sources[length - 1] : undefined;\n\n    if (typeof customizer == 'function') {\n      customizer = bindCallback(customizer, thisArg, 5);\n      length -= 2;\n    } else {\n      customizer = typeof thisArg == 'function' ? thisArg : undefined;\n      length -= (customizer ? 1 : 0);\n    }\n    if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n      customizer = length < 3 ? undefined : customizer;\n      length = 1;\n    }\n    while (++index < length) {\n      var source = sources[index];\n      if (source) {\n        assigner(object, source, customizer);\n      }\n    }\n    return object;\n  });\n}\n\nmodule.exports = createAssigner;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/createAssigner.js\n ** module id = 63\n ** module chunks = 0\n **/","var identity = require('../utility/identity');\n\n/**\n * A specialized version of `baseCallback` which only supports `this` binding\n * and specifying the number of arguments to provide to `func`.\n *\n * @private\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {number} [argCount] The number of arguments to provide to `func`.\n * @returns {Function} Returns the callback.\n */\nfunction bindCallback(func, thisArg, argCount) {\n  if (typeof func != 'function') {\n    return identity;\n  }\n  if (thisArg === undefined) {\n    return func;\n  }\n  switch (argCount) {\n    case 1: return function(value) {\n      return func.call(thisArg, value);\n    };\n    case 3: return function(value, index, collection) {\n      return func.call(thisArg, value, index, collection);\n    };\n    case 4: return function(accumulator, value, index, collection) {\n      return func.call(thisArg, accumulator, value, index, collection);\n    };\n    case 5: return function(value, other, key, object, source) {\n      return func.call(thisArg, value, other, key, object, source);\n    };\n  }\n  return function() {\n    return func.apply(thisArg, arguments);\n  };\n}\n\nmodule.exports = bindCallback;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/bindCallback.js\n ** module id = 64\n ** module chunks = 0\n **/","/**\n * This method returns the first argument provided to it.\n *\n * @static\n * @memberOf _\n * @category Utility\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'user': 'fred' };\n *\n * _.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/utility/identity.js\n ** module id = 65\n ** module chunks = 0\n **/","var isArrayLike = require('./isArrayLike'),\n    isIndex = require('./isIndex'),\n    isObject = require('../lang/isObject');\n\n/**\n * Checks if the provided 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, 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    var other = object[index];\n    return value === value ? (value === other) : (other !== other);\n  }\n  return false;\n}\n\nmodule.exports = isIterateeCall;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isIterateeCall.js\n ** module id = 66\n ** module chunks = 0\n **/","/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as an array.\n *\n * **Note:** This method is based on the [rest parameter](https://developer.mozilla.org/Web/JavaScript/Reference/Functions/rest_parameters).\n *\n * @static\n * @memberOf _\n * @category Function\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 * @example\n *\n * var say = _.restParam(function(what, names) {\n *   return what + ' ' + _.initial(names).join(', ') +\n *     (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\nfunction restParam(func, start) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  start = nativeMax(start === undefined ? (func.length - 1) : (+start || 0), 0);\n  return function() {\n    var args = arguments,\n        index = -1,\n        length = nativeMax(args.length - start, 0),\n        rest = Array(length);\n\n    while (++index < length) {\n      rest[index] = args[start + index];\n    }\n    switch (start) {\n      case 0: return func.call(this, rest);\n      case 1: return func.call(this, args[0], rest);\n      case 2: return func.call(this, args[0], args[1], rest);\n    }\n    var otherArgs = Array(start + 1);\n    index = -1;\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = rest;\n    return func.apply(this, otherArgs);\n  };\n}\n\nmodule.exports = restParam;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/function/restParam.js\n ** module id = 67\n ** module chunks = 0\n **/","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            event.subscribers = subscribers.filter(function(subscriber) {\r\n                publishSubscription(subscriber, data);\r\n                return !subscriber.once;\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 ** D:/work/quaggaJS/src/common/events.js\n **/","const merge = require('lodash/object/merge');\r\n\r\nvar streamRef,\r\n    loadedDataHandler;\r\n\r\n/**\r\n * Wraps browser-specific getUserMedia\r\n * @param {Object} constraints\r\n * @param {Object} success Callback\r\n * @param {Object} failure Callback\r\n */\r\nfunction getUserMedia(constraints, success, failure) {\r\n    if (typeof navigator.getUserMedia !== 'undefined') {\r\n        navigator.getUserMedia(constraints, function (stream) {\r\n            streamRef = stream;\r\n            var videoSrc = (window.URL && window.URL.createObjectURL(stream)) || stream;\r\n            success.apply(null, [videoSrc]);\r\n        }, failure);\r\n    } else {\r\n        failure(new TypeError(\"getUserMedia not available\"));\r\n    }\r\n}\r\n\r\nfunction loadedData(video, callback) {\r\n    var attempts = 10;\r\n\r\n    function checkVideo() {\r\n        if (attempts > 0) {\r\n            if (video.videoWidth > 0 && video.videoHeight > 0) {\r\n                if (ENV.development) {\r\n                    console.log(video.videoWidth + \"px x \" + video.videoHeight + \"px\");\r\n                }\r\n                callback();\r\n            } else {\r\n                window.setTimeout(checkVideo, 500);\r\n            }\r\n        } else {\r\n            callback('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 * 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 * @param {Object} callback\r\n */\r\nfunction initCamera(constraints, video, callback) {\r\n    getUserMedia(constraints, function(src) {\r\n        video.src = src;\r\n        if (loadedDataHandler) {\r\n            video.removeEventListener(\"loadeddata\", loadedDataHandler, false);\r\n        }\r\n        loadedDataHandler = loadedData.bind(null, video, callback);\r\n        video.addEventListener('loadeddata', loadedDataHandler, false);\r\n        video.play();\r\n    }, function(e) {\r\n        callback(e);\r\n    });\r\n}\r\n\r\n/**\r\n * Normalizes the incoming constraints to satisfy the current browser\r\n * @param config\r\n * @param cb Callback which is called whenever constraints are created\r\n * @returns {*}\r\n */\r\nfunction normalizeConstraints(config, cb) {\r\n    var constraints = {\r\n            audio: false,\r\n            video: true\r\n        },\r\n        videoConstraints = merge({\r\n            width: 640,\r\n            height: 480,\r\n            minAspectRatio: 0,\r\n            maxAspectRatio: 100,\r\n            facing: \"environment\"\r\n        }, config);\r\n\r\n    if ( typeof MediaStreamTrack !== 'undefined' && typeof MediaStreamTrack.getSources !== 'undefined') {\r\n        MediaStreamTrack.getSources(function(sourceInfos) {\r\n            var videoSourceId;\r\n            for (var i = 0; i < sourceInfos.length; ++i) {\r\n                var sourceInfo = sourceInfos[i];\r\n                if (sourceInfo.kind === \"video\" && sourceInfo.facing === videoConstraints.facing) {\r\n                    videoSourceId = sourceInfo.id;\r\n                }\r\n            }\r\n            constraints.video = {\r\n                mandatory: {\r\n                    minWidth: videoConstraints.width,\r\n                    minHeight: videoConstraints.height,\r\n                    minAspectRatio: videoConstraints.minAspectRatio,\r\n                    maxAspectRatio: videoConstraints.maxAspectRatio\r\n                },\r\n                optional: [{\r\n                    sourceId: videoSourceId\r\n                }]\r\n            };\r\n            return cb(constraints);\r\n        });\r\n    } else {\r\n        constraints.video = {\r\n            mediaSource: \"camera\",\r\n            width: { min: videoConstraints.width, max: videoConstraints.width },\r\n            height: { min: videoConstraints.height, max: videoConstraints.height },\r\n            require: [\"width\", \"height\"]\r\n        };\r\n        return cb(constraints);\r\n    }\r\n}\r\n\r\n/**\r\n * Requests the back-facing camera of the user. The callback is called\r\n * whenever the stream is ready to be consumed, or if an error occures.\r\n * @param {Object} video\r\n * @param {Object} callback\r\n */\r\nfunction request(video, videoConstraints, callback) {\r\n    normalizeConstraints(videoConstraints, function(constraints) {\r\n        initCamera(constraints, video, callback);\r\n    });\r\n}\r\n\r\nexport default {\r\n    request: function(video, constraints, callback) {\r\n        request(video, constraints, callback);\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};\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/input/camera_access.js\n **/","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 ** D:/work/quaggaJS/src/analytics/result_collector.js\n **/","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 ** D:/work/quaggaJS/src/config/config.js\n **/","module.exports = {\r\n    inputStream: {\r\n        name: \"Live\",\r\n        type: \"LiveStream\",\r\n        constraints: {\r\n            width: 640,\r\n            height: 480,\r\n            minAspectRatio: 0,\r\n            maxAspectRatio: 100,\r\n            facing: \"environment\" // or user\r\n        },\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        debug: {\r\n            drawBoundingBox: false,\r\n            showFrequency: false,\r\n            drawScanline: false,\r\n            showPattern: false\r\n        }\r\n    },\r\n    locator: {\r\n        halfSample: true,\r\n        patchSize: \"medium\", // x-small, small, medium, large, x-large\r\n        debug: {\r\n            showCanvas: false,\r\n            showPatches: false,\r\n            showFoundPatches: false,\r\n            showSkeleton: false,\r\n            showLabels: false,\r\n            showPatchLabels: false,\r\n            showRemainingPatchLabels: false,\r\n            boxFromPatches: {\r\n                showTransformed: false,\r\n                showTransformedBox: false,\r\n                showBB: false\r\n            }\r\n        }\r\n    }\r\n};\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/config/config.dev.js\n **/","import ImageLoader from './image_loader';\r\n\r\nvar InputStream = {};\r\nInputStream.createVideoStream = function(video) {\r\n    var that = {},\r\n        _config = null,\r\n        _eventNames = ['canrecord', 'ended'],\r\n        _eventHandlers = {},\r\n        _calculatedWidth,\r\n        _calculatedHeight,\r\n        _topRight = {x: 0, y: 0},\r\n        _canvasSize = {x: 0, y: 0};\r\n\r\n    function initSize() {\r\n        var width = video.videoWidth,\r\n            height = video.videoHeight;\r\n\r\n        _calculatedWidth =\r\n            _config.size ? width / height > 1 ? _config.size : Math.floor((width / height) * _config.size) : width;\r\n        _calculatedHeight =\r\n            _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\r\n    that.getRealWidth = function() {\r\n        return video.videoWidth;\r\n    };\r\n\r\n    that.getRealHeight = function() {\r\n        return video.videoHeight;\r\n    };\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.setInputStream = function(config) {\r\n        _config = config;\r\n        video.src = (typeof config.src !== 'undefined') ? config.src : '';\r\n    };\r\n\r\n    that.ended = function() {\r\n        return video.ended;\r\n    };\r\n\r\n    that.getConfig = function() {\r\n        return _config;\r\n    };\r\n\r\n    that.setAttribute = function(name, value) {\r\n        video.setAttribute(name, value);\r\n    };\r\n\r\n    that.pause = function() {\r\n        video.pause();\r\n    };\r\n\r\n    that.play = function() {\r\n        video.play();\r\n    };\r\n\r\n    that.setCurrentTime = function(time) {\r\n        if (_config.type !== \"LiveStream\") {\r\n            video.currentTime = time;\r\n        }\r\n    };\r\n\r\n    that.addEventListener = function(event, f, bool) {\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        } else {\r\n            video.addEventListener(event, f, bool);\r\n        }\r\n    };\r\n\r\n    that.clearEventHandlers = function() {\r\n        _eventNames.forEach(function(eventName) {\r\n            var handlers = _eventHandlers[eventName];\r\n            if (handlers && handlers.length > 0) {\r\n                handlers.forEach(function(handler) {\r\n                    video.removeEventListener(eventName, handler);\r\n                });\r\n            }\r\n        });\r\n    };\r\n\r\n    that.trigger = function(eventName, args) {\r\n        var j,\r\n            handlers = _eventHandlers[eventName];\r\n\r\n        if (eventName === 'canrecord') {\r\n            initSize();\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    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        return video;\r\n    };\r\n\r\n    return that;\r\n};\r\n\r\nInputStream.createLiveStream = function(video) {\r\n    video.setAttribute(\"autoplay\", true);\r\n    var that = InputStream.createVideoStream(video);\r\n\r\n    that.ended = function() {\r\n        return false;\r\n    };\r\n\r\n    return that;\r\n};\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        imgArray = null,\r\n        size = 0,\r\n        offset = 1,\r\n        baseUrl = null,\r\n        ended = false,\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        ImageLoader.load(baseUrl, function(imgs) {\r\n            imgArray = imgs;\r\n            width = imgs[0].width;\r\n            height = imgs[0].height;\r\n            calculatedWidth =\r\n                _config.size ? width / height > 1 ? _config.size : Math.floor((width / height) * _config.size) : width;\r\n            calculatedHeight =\r\n                _config.size ? width / height > 1 ? Math.floor((height / width) * _config.size) : _config.size : height;\r\n            _canvasSize.x = calculatedWidth;\r\n            _canvasSize.y = calculatedHeight;\r\n            loaded = true;\r\n            frameIdx = 0;\r\n            setTimeout(function() {\r\n                publishEvent(\"canrecord\", []);\r\n            }, 0);\r\n        }, offset, size, _config.sequence);\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(newWidth) {\r\n        calculatedWidth = newWidth;\r\n    };\r\n\r\n    that.setHeight = function(newHeight) {\r\n        calculatedHeight = newHeight;\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        if (stream.sequence === false) {\r\n            baseUrl = stream.src;\r\n            size = 1;\r\n        } else {\r\n            baseUrl = stream.src;\r\n            size = stream.length;\r\n        }\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(canvasSize) {\r\n        _canvasSize.x = canvasSize.x;\r\n        _canvasSize.y = canvasSize.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        var frame;\r\n\r\n        if (!loaded){\r\n            return null;\r\n        }\r\n        if (!paused) {\r\n            frame = imgArray[frameIdx];\r\n            if (frameIdx < (size - 1)) {\r\n                frameIdx++;\r\n            } else {\r\n                setTimeout(function() {\r\n                    ended = true;\r\n                    publishEvent(\"ended\", []);\r\n                }, 0);\r\n            }\r\n        }\r\n        return frame;\r\n    };\r\n\r\n    return that;\r\n};\r\n\r\nexport default InputStream;\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/input/input_stream.js\n **/","var ImageLoader = {};\r\nImageLoader.load = function(directory, callback, offset, size, sequence) {\r\n    var htmlImagesSrcArray = new Array(size),\r\n        htmlImagesArray = new Array(htmlImagesSrcArray.length),\r\n        i,\r\n        img,\r\n        num;\r\n\r\n    if (sequence === false) {\r\n        htmlImagesSrcArray[0] = directory;\r\n    } else {\r\n        for ( i = 0; i < htmlImagesSrcArray.length; i++) {\r\n            num = (offset + i);\r\n            htmlImagesSrcArray[i] = directory + \"image-\" + (\"00\" + num).slice(-3) + \".jpg\";\r\n        }\r\n    }\r\n    htmlImagesArray.notLoaded = [];\r\n    htmlImagesArray.addImage = function(image) {\r\n        htmlImagesArray.notLoaded.push(image);\r\n    };\r\n    htmlImagesArray.loaded = function(loadedImg) {\r\n        var notloadedImgs = htmlImagesArray.notLoaded;\r\n        for (var x = 0; x < notloadedImgs.length; x++) {\r\n            if (notloadedImgs[x] === loadedImg) {\r\n                notloadedImgs.splice(x, 1);\r\n                for (var y = 0; y < htmlImagesSrcArray.length; y++) {\r\n                    var imgName = htmlImagesSrcArray[y].substr(htmlImagesSrcArray[y].lastIndexOf(\"/\"));\r\n                    if (loadedImg.src.lastIndexOf(imgName) !== -1) {\r\n                        htmlImagesArray[y] = loadedImg;\r\n                        break;\r\n                    }\r\n                }\r\n                break;\r\n            }\r\n        }\r\n        if (notloadedImgs.length === 0) {\r\n            if (ENV.development) {\r\n                console.log(\"Images loaded\");\r\n            }\r\n            callback.apply(null, [htmlImagesArray]);\r\n        }\r\n    };\r\n\r\n    for ( i = 0; i < htmlImagesSrcArray.length; i++) {\r\n        img = new Image();\r\n        htmlImagesArray.addImage(img);\r\n        addOnloadHandler(img, htmlImagesArray);\r\n        img.src = htmlImagesSrcArray[i];\r\n    }\r\n};\r\n\r\nfunction addOnloadHandler(img, htmlImagesArray) {\r\n    img.onload = function() {\r\n        htmlImagesArray.loaded(this);\r\n    };\r\n}\r\n\r\nexport default (ImageLoader);\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/input/image_loader.js\n **/","import CVUtils from '../common/cv_utils';\r\n\r\nvar FrameGrabber = {};\r\n\r\nFrameGrabber.create = function(inputStream, canvas) {\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        _sx = topRight.x,\r\n        _sy = topRight.y,\r\n        _canvas,\r\n        _ctx = null,\r\n        _data = null;\r\n\r\n    _canvas = canvas ? canvas : document.createElement(\"canvas\");\r\n    _canvas.width = _canvasSize.x;\r\n    _canvas.height = _canvasSize.y;\r\n    _ctx = _canvas.getContext(\"2d\");\r\n    _data = new Uint8Array(_size.x * _size.y);\r\n    if (ENV.development) {\r\n        console.log(\"FrameGrabber\", JSON.stringify({\r\n            size: _size,\r\n            topRight: topRight,\r\n            videoSize: _video_size,\r\n            canvasSize: _canvasSize\r\n        }));\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 doHalfSample = _streamConfig.halfSample,\r\n            frame = inputStream.getFrame(),\r\n            ctxData;\r\n        if (frame) {\r\n            _ctx.drawImage(frame, 0, 0, _canvasSize.x, _canvasSize.y);\r\n            ctxData = _ctx.getImageData(_sx, _sy, _size.x, _size.y).data;\r\n            if (doHalfSample){\r\n                CVUtils.grayAndHalfSampleFromCanvasData(ctxData, _size, _data);\r\n            } else {\r\n                CVUtils.computeGray(ctxData, _data, _streamConfig);\r\n            }\r\n            return true;\r\n        } else {\r\n            return false;\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\nexport default FrameGrabber;\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/input/frame_grabber.js\n **/"],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/myModuleDefinition","webpack:///webpack/bootstrap 4fec31778c88edd1bc4e","webpack:///./~/webrtc-adapter/src/js/utils.js","webpack:///./~/lodash/_root.js","webpack:///./~/lodash/isObject.js","webpack:///./~/lodash/_Map.js","webpack:///./~/lodash/isArray.js","webpack:///./src/reader/barcode_reader.js","webpack:///./~/gl-vec2/clone.js","webpack:///./~/lodash/isObjectLike.js","webpack:///./src/common/array_helper.js","webpack:///./src/common/image_debug.js","webpack:///./src/reader/ean_reader.js","webpack:///./~/lodash/_assocIndexOf.js","webpack:///./~/lodash/_getNative.js","webpack:///./~/lodash/_isKeyable.js","webpack:///./~/lodash/_nativeCreate.js","webpack:///./~/lodash/eq.js","webpack:///./~/lodash/isFunction.js","webpack:///./src/common/cv_utils.js","webpack:///./src/common/image_wrapper.js","webpack:///./~/lodash/_arrayReduce.js","webpack:///./~/lodash/_copyObject.js","webpack:///./~/lodash/_isHostObject.js","webpack:///./~/lodash/_isIndex.js","webpack:///./~/lodash/_isPrototype.js","webpack:///./~/lodash/isArguments.js","webpack:///./~/lodash/isArrayLike.js","webpack:///./~/lodash/isArrayLikeObject.js","webpack:///./~/lodash/isLength.js","webpack:///./~/lodash/merge.js","webpack:///./src/locator/tracer.js","webpack:///./src/reader/code_39_reader.js","webpack:///./~/gl-vec2/dot.js","webpack:///./~/lodash/_Stack.js","webpack:///./~/lodash/_arrayEach.js","webpack:///./~/lodash/_assignMergeValue.js","webpack:///./~/lodash/_assignValue.js","webpack:///./~/lodash/_assocDelete.js","webpack:///./~/lodash/_assocGet.js","webpack:///./~/lodash/_assocHas.js","webpack:///./~/lodash/_assocSet.js","webpack:///./~/lodash/_cloneArrayBuffer.js","webpack:///./~/lodash/_copyArray.js","webpack:///./~/lodash/_hashHas.js","webpack:///./~/lodash/_indexKeys.js","webpack:///./~/lodash/isTypedArray.js","webpack:///./~/lodash/keys.js","webpack:///./~/lodash/keysIn.js","webpack:///./~/lodash/rest.js","webpack:///(webpack)/buildin/module.js","webpack:///./src/quagga.js","webpack:///./src/analytics/result_collector.js","webpack:///./src/common/cluster.js","webpack:///./src/common/events.js","webpack:///./src/common/subImage.js","webpack:///./src/common/typedefs.js","webpack:///./src/config/config.dev.js","webpack:///./src/config/config.js","webpack:///./src/decoder/barcode_decoder.js","webpack:///./src/decoder/bresenham.js","webpack:///./src/input/camera_access.js","webpack:///./src/input/frame_grabber.js","webpack:///./src/input/image_loader.js","webpack:///./src/input/input_stream.js","webpack:///./src/locator/barcode_locator.js","webpack:///./src/locator/rasterizer.js","webpack:///./src/locator/skeletonizer.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/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/_MapCache.js","webpack:///./~/lodash/_Reflect.js","webpack:///./~/lodash/_Set.js","webpack:///./~/lodash/_Symbol.js","webpack:///./~/lodash/_Uint8Array.js","webpack:///./~/lodash/_WeakMap.js","webpack:///./~/lodash/_addMapEntry.js","webpack:///./~/lodash/_addSetEntry.js","webpack:///./~/lodash/_apply.js","webpack:///./~/lodash/_arrayPush.js","webpack:///./~/lodash/_baseAssign.js","webpack:///./~/lodash/_baseClone.js","webpack:///./~/lodash/_baseCreate.js","webpack:///./~/lodash/_baseFlatten.js","webpack:///./~/lodash/_baseFor.js","webpack:///./~/lodash/_baseForOwn.js","webpack:///./~/lodash/_baseHas.js","webpack:///./~/lodash/_baseKeys.js","webpack:///./~/lodash/_baseKeysIn.js","webpack:///./~/lodash/_baseMerge.js","webpack:///./~/lodash/_baseMergeDeep.js","webpack:///./~/lodash/_basePick.js","webpack:///./~/lodash/_baseProperty.js","webpack:///./~/lodash/_baseTimes.js","webpack:///./~/lodash/_checkGlobal.js","webpack:///./~/lodash/_cloneBuffer.js","webpack:///./~/lodash/_cloneMap.js","webpack:///./~/lodash/_cloneRegExp.js","webpack:///./~/lodash/_cloneSet.js","webpack:///./~/lodash/_cloneSymbol.js","webpack:///./~/lodash/_cloneTypedArray.js","webpack:///./~/lodash/_copyObjectWith.js","webpack:///./~/lodash/_copySymbols.js","webpack:///./~/lodash/_createAssigner.js","webpack:///./~/lodash/_createBaseFor.js","webpack:///./~/lodash/_getLength.js","webpack:///./~/lodash/_getSymbols.js","webpack:///./~/lodash/_getTag.js","webpack:///./~/lodash/_hashDelete.js","webpack:///./~/lodash/_hashGet.js","webpack:///./~/lodash/_hashSet.js","webpack:///./~/lodash/_initCloneArray.js","webpack:///./~/lodash/_initCloneByTag.js","webpack:///./~/lodash/_initCloneObject.js","webpack:///./~/lodash/_isIterateeCall.js","webpack:///./~/lodash/_iteratorToArray.js","webpack:///./~/lodash/_mapClear.js","webpack:///./~/lodash/_mapDelete.js","webpack:///./~/lodash/_mapGet.js","webpack:///./~/lodash/_mapHas.js","webpack:///./~/lodash/_mapSet.js","webpack:///./~/lodash/_mapToArray.js","webpack:///./~/lodash/_setToArray.js","webpack:///./~/lodash/_stackClear.js","webpack:///./~/lodash/_stackDelete.js","webpack:///./~/lodash/_stackGet.js","webpack:///./~/lodash/_stackHas.js","webpack:///./~/lodash/_stackSet.js","webpack:///./~/lodash/constant.js","webpack:///./~/lodash/isBuffer.js","webpack:///./~/lodash/isNative.js","webpack:///./~/lodash/isPlainObject.js","webpack:///./~/lodash/isString.js","webpack:///./~/lodash/pick.js","webpack:///./~/lodash/toInteger.js","webpack:///./~/lodash/toNumber.js","webpack:///./~/lodash/toPlainObject.js","webpack:///./~/webrtc-adapter/src/js/adapter_core.js","webpack:///./~/webrtc-adapter/src/js/chrome/chrome_shim.js","webpack:///./~/webrtc-adapter/src/js/chrome/getusermedia.js","webpack:///./~/webrtc-adapter/src/js/edge/edge_sdp.js","webpack:///./~/webrtc-adapter/src/js/edge/edge_shim.js","webpack:///./~/webrtc-adapter/src/js/firefox/firefox_shim.js","webpack:///./~/webrtc-adapter/src/js/firefox/getusermedia.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACRA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,iBAAS;AACT;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,cAAa,QAAQ;AACrB,cAAa,QAAQ;AACrB,cAAa,QAAQ;AACrB,eAAc,QAAQ;AACtB;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,eAAc,OAAO;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACpGA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA,iBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACNA;AACA;AACA;AACA;AACA;AACA,W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K,CAAL,CAAhC,CArB2D;EAA9B;;AAwBjC,6CAAe,YAAf,C;;;;;;AC5VA;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,SAAS;AACpB,YAAW,EAAE;AACb,YAAW,QAAQ;AACnB,cAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,YAAW,OAAO,WAAW;AAC7B,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA,8BAA6B,kBAAkB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1CA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,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wBH,uBAAU,CAAC,OAAD,CAxBP;UAFP;MADJ;AA8BA,YAAO,IAAP,CAzC2C;EAAX;;AA4CpC,6CAAe,YAAf,C;;;;;;ACtNA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA,E;;;;;;ACXA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,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,YAAW,MAAM;AACjB,YAAW,SAAS;AACpB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;;;;;;;AC9BA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,YAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,YAAY;AACvB,cAAa,YAAY;AACzB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,WAAW;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvBA;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1EA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;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;;AAEA;;;;;;;ACtDA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;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;;AAEA;;;;;;;ACrDA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA,KAAI;AACJ;AACA;AACA;AACA;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;AACA;AACA;;AAEA;;;;;;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAoB,iBAAiB,EAAE;AACvC,sBAAqB,qBAAqB;AAC1C,IAAG;AACH;AACA;AACA;AACA,qBAAoB,iBAAiB;AACrC,IAAG;AACH;AACA;AACA;AACA,qBAAoB,iBAAiB;AACrC,IAAG;AACH;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,KAAM,OAAO;AACT,YAAO,oBAAQ,CAAR,CAAP;EADE;;AAIN,KAAI,YAAJ;KACI,aADJ;KAEI,QAFJ;KAGI,mBAAmB;AACf,UAAK;AACD,gBAAO,IAAP;AACA,kBAAS,IAAT;MAFJ;AAIA,UAAK;AACD,gBAAO,IAAP;AACA,kBAAS,IAAT;MAFJ;EALJ;KAUA,kBAbJ;KAcI,QAdJ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hB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AChBA;;AAEA;AACA;AACA;AACA;AACA,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;;;;;;AC1BA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,OAAO;AAClB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA,E;;;;;;ACdA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,E;;;;;;AChBA;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,cAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,E;;;;;;ACdA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAa,OAAO;AACpB;AACA;;AAEA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACNA;;AAEA;AACA;;AAEA;;;;;;;ACLA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACNA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,YAAW,EAAE;AACb,YAAW,KAAK;AAChB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;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;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;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;AACA,YAAW,EAAE;AACb,YAAW,QAAQ;AACnB,YAAW,QAAQ;AACnB,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA0C;AAC1C;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;;;;;;;AClIA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,YAAW,QAAQ;AACnB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;;AAEA;;;;;;;AChBA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,aAAa;AACxB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,8CAA6C,eAAe;AAC5D;AACA;AACA;AACA;;AAEA;;;;;;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjFA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG,IAAI;AACP;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,YAAY;AACzB;AACA;AACA;AACA;;AAEA;;;;;;;ACXA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,QAAQ;AACnB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,QAAQ;AACnB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,YAAW,OAAO,WAAW;AAC7B,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;AACA,yBAAwB;;AAExB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO,WAAW;AAC7B,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;ACpCA;AACA;AACA;AACA;AACA,YAAW,QAAQ;AACnB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;;AAEA;;;;;;;ACdA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1DA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,EAAE;AACb;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,QAAQ;AACnB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;ACzEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,YAAW,EAAE;AACb,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAG;AACH;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAG;AACH;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAmB;AACnB;;AAEA;;;;;;;ACXA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,SAAS;AACtB;AACA;AACA,kBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;AC/CA;AACA;AACA;;AAEA;AACA,qCAAoC;;AAEpC;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpDA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,qBAAqB;AAChC;AACA,cAAa,OAAO;AACpB;AACA;AACA,kBAAiB;AACjB;AACA;AACA,WAAU;AACV;AACA;AACA,6BAA4B;AAC5B,EAAC;;AAED;;;;;;;ACzBA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;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;;;;;;;AC3CA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;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;;;;;;;AC1DA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa,SAAS;AACtB,WAAU;AACV;AACA,cAAa,SAAS;AACtB,WAAU;AACV;AACA;AACA;AACA;;AAEA;;;;;;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAC;;;;;;;AC1ED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,0BAAyB,sBAAsB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA,cAAa;AACb;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA,cAAa;AACb,YAAW;AACX;AACA,QAAO;AACP;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA,UAAS;AACT;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qEAAoE;AACpE;AACA,yEAAwE;AACxE;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA,YAAW;;AAEX;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAiB;AACjB,YAAW;AACX;AACA;AACA,UAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA,QAAO;AACP;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX,UAAS;AACT;AACA;AACA;AACA,MAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAe;AACf;AACA;AACA;AACA;AACA;AACA,gBAAe;AACf;AACA,UAAS;AACT;AACA,MAAK;AACL,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA,MAAK;AACL;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AClPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL;;AAEA;AACA,+BAA8B;AAC9B;AACA;AACA,sBAAqB;AACrB;AACA;AACA,qBAAoB;AACpB;AACA;AACA;AACA,YAAW;AACX,UAAS;AACT,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;AAGA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,kBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAuC;AACvC;AACA,qCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,6CAA4C;AAC5C,wEAAuE;AACvE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qBAAoB;AACpB,2BAA0B;AAC1B;AACA;AACA;AACA,0DAAyD;AACzD,kBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL,kDAAiD;AACjD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,0DAAyD;AACzD;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0DAAyD;AACzD;AACA;AACA;AACA,MAAK;AACL;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAiB,kBAAkB,OAAO;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,6CAA4C;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;;;;;ACjYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,0CAAyC,0BAA0B;AACnE,2CAA0C,2BAA2B;;AAErE;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA,QAAO;AACP;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,cAAa;AACb;AACA;AACA;AACA,UAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAAyB,qBAAqB;AAC9C;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAuB,sCAAsC;AAC7D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA,wBAAuB,gDAAgD;AACvE;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA2B;;AAE3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,UAAS;AACT;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;;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;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA;AACA,cAAa;AACb;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAiB;AACjB;AACA,YAAW;AACX,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;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;AACA,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA,QAAO;AACP;AACA,QAAO;AACP;AACA,QAAO;AACP;AACA,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;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,YAAW;AACX;AACA;AACA,YAAW;AACX;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,wBAAuB,8BAA8B;AACrD;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;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb,YAAW;AACX;AACA;AACA;AACA;AACA,UAAS;AACT,QAAO;AACP;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACj4BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,0BAAyB,sBAAsB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA,cAAa;AACb,YAAW;AACX;AACA,QAAO;AACP;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA,UAAS;AACT;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA2B,gCAAgC;AAC3D;AACA;AACA,gCAA+B,wBAAwB;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA,kEAAiE;AACjE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA;AACA;AACA,UAAS;AACT;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAwB;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAAyB;AACzB,cAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,QAAO;AACP;;AAEA;AACA;AACA,iCAAgC;AAChC,uCAAsC,EAAE;AACxC,0CAAyC;AACzC;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,gEAAgE;AAC3E,YAAW;AACX;AACA;AACA,QAAO;AACP;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACtOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAuB;AACvB,YAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL;;AAEA;AACA;AACA,+BAA8B;AAC9B,qCAAoC,EAAE;AACtC,wCAAuC;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,UAAS,gEAAgE;AACzE,UAAS;AACT;AACA;AACA,MAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA","file":"quagga.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(factory.toString()).default;\n\telse if(typeof exports === 'object')\n\t\texports[\"Quagga\"] = factory(factory.toString()).default;\n\telse\n\t\troot[\"Quagga\"] = factory(factory.toString()).default;\n})(this, function(__factorySource__) {\nreturn \n\n\n/** WEBPACK FOOTER **\n ** webpack/myModuleDefinition\n **/"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].e;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\te: {},\n \t\t\ti: moduleId,\n \t\t\tl: false\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.e, module, module.e, __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.e;\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// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 154);\n\n\n\n/** WEBPACK FOOTER **\n ** webpack/bootstrap 4fec31778c88edd1bc4e\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\nvar logDisabled_ = false;\n\n// Utility methods.\nvar utils = {\n  disableLog: function(bool) {\n    if (typeof bool !== 'boolean') {\n      return new Error('Argument type: ' + typeof bool +\n          '. Please use a boolean.');\n    }\n    logDisabled_ = bool;\n    return (bool) ? 'adapter.js logging disabled' :\n        'adapter.js logging enabled';\n  },\n\n  log: function() {\n    if (typeof window === 'object') {\n      if (logDisabled_) {\n        return;\n      }\n      console.log.apply(console, arguments);\n    }\n  },\n\n   /**\n   * Extract browser version out of the provided user agent string.\n   * @param {!string} uastring userAgent string.\n   * @param {!string} expr Regular expression used as match criteria.\n   * @param {!number} pos position in the version string to be returned.\n   * @return {!number} browser version.\n   */\n  extractVersion: function(uastring, expr, pos) {\n    var match = uastring.match(expr);\n    return match && match.length >= pos && parseInt(match[pos], 10);\n  },\n\n  /**\n   * Browser detector.\n   * @return {object} result containing browser, version and minVersion\n   *     properties.\n   */\n  detectBrowser: function() {\n    // Returned result object.\n    var result = {};\n    result.browser = null;\n    result.version = null;\n    result.minVersion = null;\n\n    if (typeof window === 'undefined' || !window.navigator) {\n      result.browser = 'Not a browser.';\n      return result;\n    } else if (navigator.mozGetUserMedia) {\n      // Firefox.\n      result.browser = 'firefox';\n      result.version = this.extractVersion(navigator.userAgent,\n          /Firefox\\/([0-9]+)\\./, 1);\n      result.minVersion = 31;\n    } else if (navigator.webkitGetUserMedia && window.webkitRTCPeerConnection) {\n      // Chrome, Chromium, WebView, Opera and other WebKit browsers.\n      result.browser = 'chrome';\n      result.version = this.extractVersion(navigator.userAgent,\n          /Chrom(e|ium)\\/([0-9]+)\\./, 2);\n      result.minVersion = 38;\n    } else if(navigator.mediaDevices &&\n        navigator.userAgent.match(/Edge\\/(\\d+).(\\d+)$/)) {\n      // Edge.\n      result.browser = 'edge';\n      result.version = this.extractVersion(navigator.userAgent,\n          /Edge\\/(\\d+).(\\d+)$/, 2);\n      result.minVersion = 10547;\n    } else {\n      result.browser = 'Not a supported browser.';\n      return result;\n    }\n\n    // Warn if version is less than minVersion.\n    if (result.version < result.minVersion) {\n      utils.log('Browser: ' + result.browser + ' Version: ' + result.version +\n          ' < minimum supported version: ' + result.minVersion +\n          '\\n some things might not work!');\n    }\n\n    return result;\n  }\n};\n\n// Export.\nmodule.exports = {\n  log: utils.log,\n  disableLog: utils.disableLog,\n  browserDetails: utils.detectBrowser(),\n  extractVersion: utils.extractVersion\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/utils.js\n ** module id = 0\n ** module chunks = 0\n **/","var checkGlobal = require('./_checkGlobal');\n\n/** Used to determine if values are of the language type `Object`. */\nvar objectTypes = {\n  'function': true,\n  'object': true\n};\n\n/** Detect free variable `exports`. */\nvar freeExports = (objectTypes[typeof exports] && exports && !exports.nodeType)\n  ? exports\n  : undefined;\n\n/** Detect free variable `module`. */\nvar freeModule = (objectTypes[typeof module] && module && !module.nodeType)\n  ? module\n  : undefined;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = checkGlobal(freeExports && freeModule && typeof global == 'object' && global);\n\n/** Detect free variable `self`. */\nvar freeSelf = checkGlobal(objectTypes[typeof self] && self);\n\n/** Detect free variable `window`. */\nvar freeWindow = checkGlobal(objectTypes[typeof window] && window);\n\n/** Detect `this` as the global object. */\nvar thisGlobal = checkGlobal(objectTypes[typeof this] && this);\n\n/**\n * Used as a reference to the global object.\n *\n * The `this` value is used if it's the global object to avoid Greasemonkey's\n * restricted `window` object, otherwise the `window` object is used.\n */\nvar root = freeGlobal ||\n  ((freeWindow !== (thisGlobal && thisGlobal.window)) && freeWindow) ||\n    freeSelf || thisGlobal || Function('return this')();\n\nmodule.exports = root;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_root.js\n ** module id = 1\n ** module chunks = 0\n **/","/**\n * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`.\n * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\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 && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isObject.js\n ** module id = 2\n ** module chunks = 0\n **/","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_Map.js\n ** module id = 3\n ** module chunks = 0\n **/","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @type {Function}\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, 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 = 4\n ** module chunks = 0\n **/","function BarcodeReader(config) {\r\n    this._row = [];\r\n    this.config = config || {};\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) {\r\n    var i,\r\n        error = 0,\r\n        singleError = 0,\r\n        modulo = this.MODULO,\r\n        maxSingleError = this.SINGLE_CODE_ERROR || 1;\r\n\r\n    for (i = 0; i < counter.length; i++) {\r\n        singleError = Math.abs(code[i] - counter[i]);\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._normalize = function(counter, modulo) {\r\n    var i,\r\n        self = this,\r\n        sum = 0,\r\n        ratio,\r\n        numOnes = 0,\r\n        normalized = [],\r\n        norm = 0;\r\n\r\n    if (!modulo) {\r\n        modulo = self.MODULO;\r\n    }\r\n    for (i = 0; i < counter.length; i++) {\r\n        if (counter[i] === 1) {\r\n            numOnes++;\r\n        } else {\r\n            sum += counter[i];\r\n        }\r\n    }\r\n    ratio = sum / (modulo - numOnes);\r\n    if (ratio > 1.0) {\r\n        for (i = 0; i < counter.length; i++) {\r\n            norm = counter[i] === 1 ? counter[i] : counter[i] / ratio;\r\n            normalized.push(norm);\r\n        }\r\n    } else {\r\n        ratio = (sum + numOnes) / modulo;\r\n        for (i = 0; i < counter.length; i++) {\r\n            norm = counter[i] / ratio;\r\n            normalized.push(norm);\r\n        }\r\n    }\r\n    return normalized;\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\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 **/","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 = 6\n ** module chunks = 0\n **/","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @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 && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isObjectLike.js\n ** module id = 7\n ** module chunks = 0\n **/","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\n **/","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\n **/","import BarcodeReader from './barcode_reader';\r\n\r\nfunction EANReader(opts) {\r\n    BarcodeReader.call(this, opts);\r\n}\r\n\r\nvar properties = {\r\n    CODE_L_START: {value: 0},\r\n    MODULO: {value: 7},\r\n    CODE_G_START: {value: 10},\r\n    START_PATTERN: {value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7]},\r\n    STOP_PATTERN: {value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7]},\r\n    MIDDLE_PATTERN: {value: [1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7]},\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.67},\r\n    AVG_CODE_ERROR: {value: 0.27},\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        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = 0; code < coderange; code++) {\r\n                        error = self._matchPattern(normalized, 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                }\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        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    error = self._matchPattern(normalized, 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                }\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\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    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    };\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\nexport default (EANReader);\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/reader/ean_reader.js\n **/","var eq = require('./eq');\n\n/**\n * Gets the index at which the first occurrence of `key` is found in `array`\n * of key-value pairs.\n *\n * @private\n * @param {Array} array The array to search.\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 = 11\n ** module chunks = 0\n **/","var isNative = require('./isNative');\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 = object[key];\n  return isNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_getNative.js\n ** module id = 12\n ** module chunks = 0\n **/","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n  var type = typeof value;\n  return type == 'number' || type == 'boolean' ||\n    (type == 'string' && value != '__proto__') || value == null;\n}\n\nmodule.exports = isKeyable;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_isKeyable.js\n ** module id = 13\n ** module chunks = 0\n **/","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_nativeCreate.js\n ** module id = 14\n ** module chunks = 0\n **/","/**\n * Performs a [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\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 = { 'user': 'fred' };\n * var other = { 'user': 'fred' };\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 = 15\n ** module chunks = 0\n **/","var isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 8 which returns 'object' for typed array and weak map constructors,\n  // and PhantomJS 1.9 which returns 'function' for `NodeList` instances.\n  var tag = isObject(value) ? objectToString.call(value) : '';\n  return tag == funcTag || tag == genTag;\n}\n\nmodule.exports = isFunction;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isFunction.js\n ** module id = 16\n ** module chunks = 0\n **/","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] = Math.floor((\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] = Math.floor(\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\n **/","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\n **/","/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n  var index = -1,\n      length = array.length;\n\n  if (initAccum && length) {\n    accumulator = array[++index];\n  }\n  while (++index < length) {\n    accumulator = iteratee(accumulator, array[index], index, array);\n  }\n  return accumulator;\n}\n\nmodule.exports = arrayReduce;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_arrayReduce.js\n ** module id = 19\n ** module chunks = 0\n **/","var copyObjectWith = require('./_copyObjectWith');\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 names to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object) {\n  return copyObjectWith(source, props, object);\n}\n\nmodule.exports = copyObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_copyObject.js\n ** module id = 20\n ** module chunks = 0\n **/","/**\n * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nfunction isHostObject(value) {\n  // Many host objects are `Object` objects that can coerce to strings\n  // despite having improperly defined `toString` methods.\n  var result = false;\n  if (value != null && typeof value.toString != 'function') {\n    try {\n      result = !!(value + '');\n    } catch (e) {}\n  }\n  return result;\n}\n\nmodule.exports = isHostObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_isHostObject.js\n ** module id = 21\n ** module chunks = 0\n **/","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1;\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return 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 = 22\n ** module chunks = 0\n **/","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\nmodule.exports = isPrototype;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_isPrototype.js\n ** module id = 23\n ** module chunks = 0\n **/","var isArrayLikeObject = require('./isArrayLikeObject');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\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 [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\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 * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nfunction isArguments(value) {\n  // Safari 8.1 incorrectly makes `arguments.callee` enumerable in strict mode.\n  return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&\n    (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);\n}\n\nmodule.exports = isArguments;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isArguments.js\n ** module id = 24\n ** module chunks = 0\n **/","var getLength = require('./_getLength'),\n    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 * @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(getLength(value)) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isArrayLike.js\n ** module id = 25\n ** module chunks = 0\n **/","var isArrayLike = require('./isArrayLike'),\n    isObjectLike = require('./isObjectLike');\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object, 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 = 26\n ** module chunks = 0\n **/","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This function is loosely based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength).\n *\n * @static\n * @memberOf _\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 = 27\n ** module chunks = 0\n **/","var baseMerge = require('./_baseMerge'),\n    createAssigner = require('./_createAssigner');\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable properties of source objects into the destination\n * object. Source properties that resolve to `undefined` are skipped if a\n * destination value exists. Array and plain object properties are merged\n * recursively.Other objects and value types are overridden by assignment.\n * Source objects are applied from left to right. Subsequent sources\n * overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\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 users = {\n *   'data': [{ 'user': 'barney' }, { 'user': 'fred' }]\n * };\n *\n * var ages = {\n *   'data': [{ 'age': 36 }, { 'age': 40 }]\n * };\n *\n * _.merge(users, ages);\n * // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] }\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\n **/","/**\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\n **/","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._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\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\n **/","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 = 31\n ** module chunks = 0\n **/","var 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} [values] The values to cache.\n */\nfunction Stack(values) {\n  var index = -1,\n      length = values ? values.length : 0;\n\n  this.clear();\n  while (++index < length) {\n    var entry = values[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add functions to the `Stack` cache.\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 = 32\n ** module chunks = 0\n **/","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee 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 `array`.\n */\nfunction arrayEach(array, iteratee) {\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    if (iteratee(array[index], index, array) === false) {\n      break;\n    }\n  }\n  return array;\n}\n\nmodule.exports = arrayEach;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_arrayEach.js\n ** module id = 33\n ** module chunks = 0\n **/","var 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      (typeof key == 'number' && value === undefined && !(key in object))) {\n    object[key] = value;\n  }\n}\n\nmodule.exports = assignMergeValue;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assignMergeValue.js\n ** module id = 34\n ** module chunks = 0\n **/","var 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/6.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    object[key] = value;\n  }\n}\n\nmodule.exports = assignValue;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assignValue.js\n ** module id = 35\n ** module chunks = 0\n **/","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the associative array.\n *\n * @private\n * @param {Array} array The array to query.\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 assocDelete(array, key) {\n  var index = assocIndexOf(array, key);\n  if (index < 0) {\n    return false;\n  }\n  var lastIndex = array.length - 1;\n  if (index == lastIndex) {\n    array.pop();\n  } else {\n    splice.call(array, index, 1);\n  }\n  return true;\n}\n\nmodule.exports = assocDelete;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assocDelete.js\n ** module id = 36\n ** module chunks = 0\n **/","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the associative array value for `key`.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction assocGet(array, key) {\n  var index = assocIndexOf(array, key);\n  return index < 0 ? undefined : array[index][1];\n}\n\nmodule.exports = assocGet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assocGet.js\n ** module id = 37\n ** module chunks = 0\n **/","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if an associative array value for `key` exists.\n *\n * @private\n * @param {Array} array The array to query.\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 assocHas(array, key) {\n  return assocIndexOf(array, key) > -1;\n}\n\nmodule.exports = assocHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assocHas.js\n ** module id = 38\n ** module chunks = 0\n **/","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the associative array `key` to `value`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n */\nfunction assocSet(array, key, value) {\n  var index = assocIndexOf(array, key);\n  if (index < 0) {\n    array.push([key, value]);\n  } else {\n    array[index][1] = value;\n  }\n}\n\nmodule.exports = assocSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assocSet.js\n ** module id = 39\n ** module chunks = 0\n **/","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n  new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n  return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneArrayBuffer.js\n ** module id = 40\n ** module chunks = 0\n **/","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n  var index = -1,\n      length = source.length;\n\n  array || (array = Array(length));\n  while (++index < length) {\n    array[index] = source[index];\n  }\n  return array;\n}\n\nmodule.exports = copyArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_copyArray.js\n ** module id = 41\n ** module chunks = 0\n **/","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @param {Object} hash The hash to query.\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(hash, key) {\n  return nativeCreate ? hash[key] !== undefined : hasOwnProperty.call(hash, key);\n}\n\nmodule.exports = hashHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_hashHas.js\n ** module id = 42\n ** module chunks = 0\n **/","var baseTimes = require('./_baseTimes'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isLength = require('./isLength'),\n    isString = require('./isString');\n\n/**\n * Creates an array of index keys for `object` values of arrays,\n * `arguments` objects, and strings, otherwise `null` is returned.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array|null} Returns index keys, else `null`.\n */\nfunction indexKeys(object) {\n  var length = object ? object.length : undefined;\n  if (isLength(length) &&\n      (isArray(object) || isString(object) || isArguments(object))) {\n    return baseTimes(length, String);\n  }\n  return null;\n}\n\nmodule.exports = indexKeys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_indexKeys.js\n ** module id = 43\n ** module chunks = 0\n **/","var 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    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[dateTag] = typedArrayTags[errorTag] =\ntypedArrayTags[funcTag] = typedArrayTags[mapTag] =\ntypedArrayTags[numberTag] = typedArrayTags[objectTag] =\ntypedArrayTags[regexpTag] = typedArrayTags[setTag] =\ntypedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nfunction isTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[objectToString.call(value)];\n}\n\nmodule.exports = isTypedArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isTypedArray.js\n ** module id = 44\n ** module chunks = 0\n **/","var baseHas = require('./_baseHas'),\n    baseKeys = require('./_baseKeys'),\n    indexKeys = require('./_indexKeys'),\n    isArrayLike = require('./isArrayLike'),\n    isIndex = require('./_isIndex'),\n    isPrototype = require('./_isPrototype');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @memberOf _\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 * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n  var isProto = isPrototype(object);\n  if (!(isProto || isArrayLike(object))) {\n    return baseKeys(object);\n  }\n  var indexes = indexKeys(object),\n      skipIndexes = !!indexes,\n      result = indexes || [],\n      length = result.length;\n\n  for (var key in object) {\n    if (baseHas(object, key) &&\n        !(skipIndexes && (key == 'length' || isIndex(key, length))) &&\n        !(isProto && key == 'constructor')) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = keys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/keys.js\n ** module id = 45\n ** module chunks = 0\n **/","var baseKeysIn = require('./_baseKeysIn'),\n    indexKeys = require('./_indexKeys'),\n    isIndex = require('./_isIndex'),\n    isPrototype = require('./_isPrototype');\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 own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\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  var index = -1,\n      isProto = isPrototype(object),\n      props = baseKeysIn(object),\n      propsLength = props.length,\n      indexes = indexKeys(object),\n      skipIndexes = !!indexes,\n      result = indexes || [],\n      length = result.length;\n\n  while (++index < propsLength) {\n    var key = props[index];\n    if (!(skipIndexes && (key == 'length' || isIndex(key, length))) &&\n        !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = keysIn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/keysIn.js\n ** module id = 46\n ** module chunks = 0\n **/","var apply = require('./_apply'),\n    toInteger = require('./toInteger');\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as an array.\n *\n * **Note:** This method is based on the [rest parameter](https://mdn.io/rest_parameters).\n *\n * @static\n * @memberOf _\n * @category Function\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 * @example\n *\n * var say = _.rest(function(what, names) {\n *   return what + ' ' + _.initial(names).join(', ') +\n *     (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\nfunction rest(func, start) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  start = nativeMax(start === undefined ? (func.length - 1) : toInteger(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    switch (start) {\n      case 0: return func.call(this, array);\n      case 1: return func.call(this, args[0], array);\n      case 2: return func.call(this, args[0], args[1], array);\n    }\n    var otherArgs = Array(start + 1);\n    index = -1;\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = array;\n    return apply(func, this, otherArgs);\n  };\n}\n\nmodule.exports = rest;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/rest.js\n ** module id = 47\n ** module chunks = 0\n **/","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\tmodule.children = [];\r\n\t\tObject.defineProperty(module, \"exports\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tconfigurable: false,\r\n\t\t\tget: function() { return module.e; },\r\n\t\t\tset: function(v) { return module.e = v; }\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tconfigurable: false,\r\n\t\t\tget: function() { return module.l; }\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tconfigurable: false,\r\n\t\t\tget: function() { return module.i; }\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 = 48\n ** module chunks = 0\n **/","import TypeDefs from './common/typedefs'; // eslint-disable-line no-unused-vars\r\nimport WebrtcAdapter from 'webrtc-adapter'; // 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.setAttribute(\"autoplay\", true);\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    const resultToPublish = result && (result.barcodes || result);\r\n\r\n    if (result && _onUIThread) {\r\n        transformResult(result);\r\n        addResult(result, imageData);\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: _config\r\n    }, [workerThread.imageData.buffer]);\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};\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/quagga.js\n **/","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\n **/","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\n **/","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            event.subscribers = subscribers.filter(function(subscriber) {\r\n                publishSubscription(subscriber, data);\r\n                return !subscriber.once;\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\n **/","/**\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\n **/","/*\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\n\n\n/** WEBPACK FOOTER **\n ** ./src/common/typedefs.js\n **/","module.exports = {\r\n    inputStream: {\r\n        name: \"Live\",\r\n        type: \"LiveStream\",\r\n        constraints: {\r\n            width: 640,\r\n            height: 480,\r\n            // aspectRatio: 640/480, // optional\r\n            facingMode: \"environment\", // or user\r\n            // deviceId: \"38745983457387598375983759834\"\r\n        },\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        debug: {\r\n            drawBoundingBox: false,\r\n            showFrequency: false,\r\n            drawScanline: false,\r\n            showPattern: false\r\n        }\r\n    },\r\n    locator: {\r\n        halfSample: true,\r\n        patchSize: \"medium\", // x-small, small, medium, large, x-large\r\n        debug: {\r\n            showCanvas: false,\r\n            showPatches: false,\r\n            showFoundPatches: false,\r\n            showSkeleton: false,\r\n            showLabels: false,\r\n            showPatchLabels: false,\r\n            showRemainingPatchLabels: false,\r\n            boxFromPatches: {\r\n                showTransformed: false,\r\n                showTransformedBox: false,\r\n                showBB: false\r\n            }\r\n        }\r\n    }\r\n};\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/config/config.dev.js\n **/","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\n **/","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 UPCEReader from '../reader/upc_e_reader';\r\nimport I2of5Reader from '../reader/i2of5_reader';\r\n\r\nconst READERS = {\r\n    code_128_reader: Code128Reader,\r\n    ean_reader: EANReader,\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};\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\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                _barcodeReaders.push(new READERS[reader](configuration));\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\n **/","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\n **/","import {merge, pick} from 'lodash';\r\n\r\nvar streamRef,\r\n    loadedDataHandler;\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 > 0 && video.videoHeight > 0) {\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 navigator.mediaDevices.getUserMedia(constraints)\r\n    .then((stream) => {\r\n        return new Promise((resolve, reject) => {\r\n            streamRef = stream;\r\n            video.src = window.URL.createObjectURL(stream);\r\n            video.onloadedmetadata = (e) => {\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\nfunction applyCameraFacing(facing, constraints) {\r\n    if (typeof constraints.video.deviceId !== 'undefined' || !facing){\r\n        return Promise.resolve(constraints);\r\n    }\r\n    if ( typeof MediaStreamTrack !== 'undefined' &&\r\n            typeof MediaStreamTrack.getSources !== 'undefined') {\r\n        return new Promise((resolve, reject) => {\r\n            MediaStreamTrack.getSources((sourceInfos) => {\r\n                const videoSource = sourceInfos.filter((sourceInfo) => (\r\n                    sourceInfo.kind === \"video\" && sourceInfo.facing === facing\r\n                ))[0];\r\n                if (videoSource) {\r\n                    return resolve(merge({}, constraints,\r\n                        {video: {deviceId: videoSource.id}}));\r\n                }\r\n                return resolve(constraints);\r\n            });\r\n        });\r\n    }\r\n    return Promise.resolve(merge({}, constraints, {video: {facingMode: facing}}));\r\n}\r\n\r\nfunction pickConstraints(videoConstraints) {\r\n    const constraints = {\r\n        audio: false,\r\n        video: deprecatedConstraints(videoConstraints)\r\n    };\r\n    return applyCameraFacing(constraints.video.facingMode, constraints);\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};\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/input/camera_access.js\n **/","import {\r\n    imageRef,\r\n    grayAndHalfSampleFromCanvasData,\r\n    computeGray\r\n} from '../common/cv_utils';\r\n\r\nvar FrameGrabber = {};\r\n\r\nFrameGrabber.create = function(inputStream, canvas) {\r\n    var _that = {},\r\n        _streamConfig = inputStream.getConfig(),\r\n        _video_size = imageRef(inputStream.getRealWidth(), inputStream.getRealHeight()),\r\n        _canvasSize = inputStream.getCanvasSize(),\r\n        _size = imageRef(inputStream.getWidth(), inputStream.getHeight()),\r\n        topRight = inputStream.getTopRight(),\r\n        _sx = topRight.x,\r\n        _sy = topRight.y,\r\n        _canvas,\r\n        _ctx = null,\r\n        _data = null;\r\n\r\n    _canvas = canvas ? canvas : document.createElement(\"canvas\");\r\n    _canvas.width = _canvasSize.x;\r\n    _canvas.height = _canvasSize.y;\r\n    _ctx = _canvas.getContext(\"2d\");\r\n    _data = new Uint8Array(_size.x * _size.y);\r\n    if (ENV.development) {\r\n        console.log(\"FrameGrabber\", JSON.stringify({\r\n            size: _size,\r\n            topRight: topRight,\r\n            videoSize: _video_size,\r\n            canvasSize: _canvasSize\r\n        }));\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 doHalfSample = _streamConfig.halfSample,\r\n            frame = inputStream.getFrame(),\r\n            ctxData;\r\n        if (frame) {\r\n            _ctx.drawImage(frame, 0, 0, _canvasSize.x, _canvasSize.y);\r\n            ctxData = _ctx.getImageData(_sx, _sy, _size.x, _size.y).data;\r\n            if (doHalfSample){\r\n                grayAndHalfSampleFromCanvasData(ctxData, _size, _data);\r\n            } else {\r\n                computeGray(ctxData, _data, _streamConfig);\r\n            }\r\n            return true;\r\n        } else {\r\n            return false;\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\nexport default FrameGrabber;\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/input/frame_grabber.js\n **/","var ImageLoader = {};\r\nImageLoader.load = function(directory, callback, offset, size, sequence) {\r\n    var htmlImagesSrcArray = new Array(size),\r\n        htmlImagesArray = new Array(htmlImagesSrcArray.length),\r\n        i,\r\n        img,\r\n        num;\r\n\r\n    if (sequence === false) {\r\n        htmlImagesSrcArray[0] = directory;\r\n    } else {\r\n        for ( i = 0; i < htmlImagesSrcArray.length; i++) {\r\n            num = (offset + i);\r\n            htmlImagesSrcArray[i] = directory + \"image-\" + (\"00\" + num).slice(-3) + \".jpg\";\r\n        }\r\n    }\r\n    htmlImagesArray.notLoaded = [];\r\n    htmlImagesArray.addImage = function(image) {\r\n        htmlImagesArray.notLoaded.push(image);\r\n    };\r\n    htmlImagesArray.loaded = function(loadedImg) {\r\n        var notloadedImgs = htmlImagesArray.notLoaded;\r\n        for (var x = 0; x < notloadedImgs.length; x++) {\r\n            if (notloadedImgs[x] === loadedImg) {\r\n                notloadedImgs.splice(x, 1);\r\n                for (var y = 0; y < htmlImagesSrcArray.length; y++) {\r\n                    var imgName = htmlImagesSrcArray[y].substr(htmlImagesSrcArray[y].lastIndexOf(\"/\"));\r\n                    if (loadedImg.src.lastIndexOf(imgName) !== -1) {\r\n                        htmlImagesArray[y] = loadedImg;\r\n                        break;\r\n                    }\r\n                }\r\n                break;\r\n            }\r\n        }\r\n        if (notloadedImgs.length === 0) {\r\n            if (ENV.development) {\r\n                console.log(\"Images loaded\");\r\n            }\r\n            callback.apply(null, [htmlImagesArray]);\r\n        }\r\n    };\r\n\r\n    for ( i = 0; i < htmlImagesSrcArray.length; i++) {\r\n        img = new Image();\r\n        htmlImagesArray.addImage(img);\r\n        addOnloadHandler(img, htmlImagesArray);\r\n        img.src = htmlImagesSrcArray[i];\r\n    }\r\n};\r\n\r\nfunction addOnloadHandler(img, htmlImagesArray) {\r\n    img.onload = function() {\r\n        htmlImagesArray.loaded(this);\r\n    };\r\n}\r\n\r\nexport default (ImageLoader);\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/input/image_loader.js\n **/","import ImageLoader from './image_loader';\r\n\r\nvar InputStream = {};\r\nInputStream.createVideoStream = function(video) {\r\n    var that = {},\r\n        _config = null,\r\n        _eventNames = ['canrecord', 'ended'],\r\n        _eventHandlers = {},\r\n        _calculatedWidth,\r\n        _calculatedHeight,\r\n        _topRight = {x: 0, y: 0},\r\n        _canvasSize = {x: 0, y: 0};\r\n\r\n    function initSize() {\r\n        var width = video.videoWidth,\r\n            height = video.videoHeight;\r\n\r\n        _calculatedWidth =\r\n            _config.size ? width / height > 1 ? _config.size : Math.floor((width / height) * _config.size) : width;\r\n        _calculatedHeight =\r\n            _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\r\n    that.getRealWidth = function() {\r\n        return video.videoWidth;\r\n    };\r\n\r\n    that.getRealHeight = function() {\r\n        return video.videoHeight;\r\n    };\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.setInputStream = function(config) {\r\n        _config = config;\r\n        video.src = (typeof config.src !== 'undefined') ? config.src : '';\r\n    };\r\n\r\n    that.ended = function() {\r\n        return video.ended;\r\n    };\r\n\r\n    that.getConfig = function() {\r\n        return _config;\r\n    };\r\n\r\n    that.setAttribute = function(name, value) {\r\n        video.setAttribute(name, value);\r\n    };\r\n\r\n    that.pause = function() {\r\n        video.pause();\r\n    };\r\n\r\n    that.play = function() {\r\n        video.play();\r\n    };\r\n\r\n    that.setCurrentTime = function(time) {\r\n        if (_config.type !== \"LiveStream\") {\r\n            video.currentTime = time;\r\n        }\r\n    };\r\n\r\n    that.addEventListener = function(event, f, bool) {\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        } else {\r\n            video.addEventListener(event, f, bool);\r\n        }\r\n    };\r\n\r\n    that.clearEventHandlers = function() {\r\n        _eventNames.forEach(function(eventName) {\r\n            var handlers = _eventHandlers[eventName];\r\n            if (handlers && handlers.length > 0) {\r\n                handlers.forEach(function(handler) {\r\n                    video.removeEventListener(eventName, handler);\r\n                });\r\n            }\r\n        });\r\n    };\r\n\r\n    that.trigger = function(eventName, args) {\r\n        var j,\r\n            handlers = _eventHandlers[eventName];\r\n\r\n        if (eventName === 'canrecord') {\r\n            initSize();\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    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        return video;\r\n    };\r\n\r\n    return that;\r\n};\r\n\r\nInputStream.createLiveStream = function(video) {\r\n    video.setAttribute(\"autoplay\", true);\r\n    var that = InputStream.createVideoStream(video);\r\n\r\n    that.ended = function() {\r\n        return false;\r\n    };\r\n\r\n    return that;\r\n};\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        imgArray = null,\r\n        size = 0,\r\n        offset = 1,\r\n        baseUrl = null,\r\n        ended = false,\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        ImageLoader.load(baseUrl, function(imgs) {\r\n            imgArray = imgs;\r\n            width = imgs[0].width;\r\n            height = imgs[0].height;\r\n            calculatedWidth =\r\n                _config.size ? width / height > 1 ? _config.size : Math.floor((width / height) * _config.size) : width;\r\n            calculatedHeight =\r\n                _config.size ? width / height > 1 ? Math.floor((height / width) * _config.size) : _config.size : height;\r\n            _canvasSize.x = calculatedWidth;\r\n            _canvasSize.y = calculatedHeight;\r\n            loaded = true;\r\n            frameIdx = 0;\r\n            setTimeout(function() {\r\n                publishEvent(\"canrecord\", []);\r\n            }, 0);\r\n        }, offset, size, _config.sequence);\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(newWidth) {\r\n        calculatedWidth = newWidth;\r\n    };\r\n\r\n    that.setHeight = function(newHeight) {\r\n        calculatedHeight = newHeight;\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        if (stream.sequence === false) {\r\n            baseUrl = stream.src;\r\n            size = 1;\r\n        } else {\r\n            baseUrl = stream.src;\r\n            size = stream.length;\r\n        }\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(canvasSize) {\r\n        _canvasSize.x = canvasSize.x;\r\n        _canvasSize.y = canvasSize.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        var frame;\r\n\r\n        if (!loaded){\r\n            return null;\r\n        }\r\n        if (!paused) {\r\n            frame = imgArray[frameIdx];\r\n            if (frameIdx < (size - 1)) {\r\n                frameIdx++;\r\n            } else {\r\n                setTimeout(function() {\r\n                    ended = true;\r\n                    publishEvent(\"ended\", []);\r\n                }, 0);\r\n            }\r\n        }\r\n        return frame;\r\n    };\r\n\r\n    return that;\r\n};\r\n\r\nexport default InputStream;\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/input/input_stream.js\n **/","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 (_config.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\n **/","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\n **/","/* @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\n **/","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\n **/","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    MODULO: {value: 11},\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: 1},\r\n    AVG_CODE_ERROR: {value: 0.5},\r\n    FORMAT: {value: \"code_128\", writeable: false}\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) {\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        },\r\n        code,\r\n        error,\r\n        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n                        error = self._matchPattern(normalized, 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                    return bestMatch;\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\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        },\r\n        code,\r\n        error,\r\n        j,\r\n        sum,\r\n        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) {\r\n                        error = self._matchPattern(normalized, 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                        return bestMatch;\r\n                    }\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    };\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);\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\nexport default Code128Reader;\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/reader/code_128_reader.js\n **/","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\n **/","import EANReader from './ean_reader';\r\n\r\nfunction EAN8Reader() {\r\n    EANReader.call(this);\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\n **/","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        MODULO: {value: 10},\r\n        START_PATTERN: {value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5]},\r\n        STOP_PATTERN: {value: [N * 2, N * 2, W * 2]},\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    error = self._matchPattern(normalized, 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                }\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    normalized = self._normalize(counter);\r\n    if (normalized) {\r\n        for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n            error = self._matchPattern(normalized, 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    return null;\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\n **/","import EANReader from './ean_reader';\r\n\r\nfunction UPCEReader() {\r\n    EANReader.call(this);\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\n **/","import EANReader from './ean_reader';\r\n\r\nfunction UPCReader() {\r\n    EANReader.call(this);\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\n **/","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 = 73\n ** module chunks = 0\n **/","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 = 74\n ** module chunks = 0\n **/","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 = 75\n ** module chunks = 0\n **/","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 = 76\n ** module chunks = 0\n **/","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 = 77\n ** module chunks = 0\n **/","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 = 78\n ** module chunks = 0\n **/","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Creates an hash object.\n *\n * @private\n * @constructor\n * @returns {Object} Returns the new hash object.\n */\nfunction Hash() {}\n\n// Avoid inheriting from `Object.prototype` when possible.\nHash.prototype = nativeCreate ? nativeCreate(null) : objectProto;\n\nmodule.exports = Hash;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_Hash.js\n ** module id = 79\n ** module chunks = 0\n **/","var mapClear = require('./_mapClear'),\n    mapDelete = require('./_mapDelete'),\n    mapGet = require('./_mapGet'),\n    mapHas = require('./_mapHas'),\n    mapSet = require('./_mapSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction MapCache(values) {\n  var index = -1,\n      length = values ? values.length : 0;\n\n  this.clear();\n  while (++index < length) {\n    var entry = values[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add functions to the `MapCache`.\nMapCache.prototype.clear = mapClear;\nMapCache.prototype['delete'] = mapDelete;\nMapCache.prototype.get = mapGet;\nMapCache.prototype.has = mapHas;\nMapCache.prototype.set = mapSet;\n\nmodule.exports = MapCache;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_MapCache.js\n ** module id = 80\n ** module chunks = 0\n **/","var root = require('./_root');\n\n/** Built-in value references. */\nvar Reflect = root.Reflect;\n\nmodule.exports = Reflect;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_Reflect.js\n ** module id = 81\n ** module chunks = 0\n **/","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_Set.js\n ** module id = 82\n ** module chunks = 0\n **/","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 = 83\n ** module chunks = 0\n **/","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 = 84\n ** module chunks = 0\n **/","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_WeakMap.js\n ** module id = 85\n ** module chunks = 0\n **/","/**\n * Adds the key-value `pair` to `map`.\n *\n * @private\n * @param {Object} map The map to modify.\n * @param {Array} pair The key-value pair to add.\n * @returns {Object} Returns `map`.\n */\nfunction addMapEntry(map, pair) {\n  // Don't return `Map#set` because it doesn't return the map instance in IE 11.\n  map.set(pair[0], pair[1]);\n  return map;\n}\n\nmodule.exports = addMapEntry;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_addMapEntry.js\n ** module id = 86\n ** module chunks = 0\n **/","/**\n * Adds `value` to `set`.\n *\n * @private\n * @param {Object} set The set to modify.\n * @param {*} value The value to add.\n * @returns {Object} Returns `set`.\n */\nfunction addSetEntry(set, value) {\n  set.add(value);\n  return set;\n}\n\nmodule.exports = addSetEntry;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_addSetEntry.js\n ** module id = 87\n ** module chunks = 0\n **/","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {...*} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n  var length = args.length;\n  switch (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 = 88\n ** module chunks = 0\n **/","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n  var index = -1,\n      length = values.length,\n      offset = array.length;\n\n  while (++index < length) {\n    array[offset + index] = values[index];\n  }\n  return array;\n}\n\nmodule.exports = arrayPush;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_arrayPush.js\n ** module id = 89\n ** module chunks = 0\n **/","var copyObject = require('./_copyObject'),\n    keys = require('./keys');\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n  return object && copyObject(source, keys(source), object);\n}\n\nmodule.exports = baseAssign;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseAssign.js\n ** module id = 90\n ** module chunks = 0\n **/","var Stack = require('./_Stack'),\n    arrayEach = require('./_arrayEach'),\n    assignValue = require('./_assignValue'),\n    baseAssign = require('./_baseAssign'),\n    baseForOwn = require('./_baseForOwn'),\n    cloneBuffer = require('./_cloneBuffer'),\n    copyArray = require('./_copyArray'),\n    copySymbols = require('./_copySymbols'),\n    getTag = require('./_getTag'),\n    initCloneArray = require('./_initCloneArray'),\n    initCloneByTag = require('./_initCloneByTag'),\n    initCloneObject = require('./_initCloneObject'),\n    isArray = require('./isArray'),\n    isBuffer = require('./isBuffer'),\n    isHostObject = require('./_isHostObject'),\n    isObject = require('./isObject');\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    genTag = '[object GeneratorFunction]',\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    symbolTag = '[object Symbol]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\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 supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[boolTag] =\ncloneableTags[dateTag] = cloneableTags[float32Tag] =\ncloneableTags[float64Tag] = cloneableTags[int8Tag] =\ncloneableTags[int16Tag] = cloneableTags[int32Tag] =\ncloneableTags[mapTag] = cloneableTags[numberTag] =\ncloneableTags[objectTag] = cloneableTags[regexpTag] =\ncloneableTags[setTag] = cloneableTags[stringTag] =\ncloneableTags[symbolTag] = cloneableTags[uint8Tag] =\ncloneableTags[uint8ClampedTag] = cloneableTags[uint16Tag] =\ncloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @param {boolean} [isFull] Specify a clone including symbols.\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, isDeep, isFull, customizer, key, object, stack) {\n  var result;\n  if (customizer) {\n    result = object ? customizer(value, key, object, stack) : customizer(value);\n  }\n  if (result !== undefined) {\n    return result;\n  }\n  if (!isObject(value)) {\n    return value;\n  }\n  var isArr = isArray(value);\n  if (isArr) {\n    result = initCloneArray(value);\n    if (!isDeep) {\n      return copyArray(value, result);\n    }\n  } else {\n    var tag = getTag(value),\n        isFunc = tag == funcTag || tag == genTag;\n\n    if (isBuffer(value)) {\n      return cloneBuffer(value, isDeep);\n    }\n    if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n      if (isHostObject(value)) {\n        return object ? value : {};\n      }\n      result = initCloneObject(isFunc ? {} : value);\n      if (!isDeep) {\n        result = baseAssign(result, value);\n        return isFull ? copySymbols(value, result) : result;\n      }\n    } else {\n      if (!cloneableTags[tag]) {\n        return object ? value : {};\n      }\n      result = initCloneByTag(value, tag, isDeep);\n    }\n  }\n  // Check for circular references and return its corresponding clone.\n  stack || (stack = new Stack);\n  var stacked = stack.get(value);\n  if (stacked) {\n    return stacked;\n  }\n  stack.set(value, result);\n\n  // Recursively populate clone (susceptible to call stack limits).\n  (isArr ? arrayEach : baseForOwn)(value, function(subValue, key) {\n    assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack));\n  });\n  return (isFull && !isArr) ? copySymbols(value, result) : result;\n}\n\nmodule.exports = baseClone;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseClone.js\n ** module id = 91\n ** module chunks = 0\n **/","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} prototype The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nfunction baseCreate(proto) {\n  return isObject(proto) ? objectCreate(proto) : {};\n}\n\nmodule.exports = baseCreate;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseCreate.js\n ** module id = 92\n ** module chunks = 0\n **/","var arrayPush = require('./_arrayPush'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isArrayLikeObject = require('./isArrayLikeObject');\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} [isStrict] Restrict flattening to arrays-like objects.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, isStrict, result) {\n  result || (result = []);\n\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    var value = array[index];\n    if (depth > 0 && isArrayLikeObject(value) &&\n        (isStrict || isArray(value) || isArguments(value))) {\n      if (depth > 1) {\n        // Recursively flatten arrays (susceptible to call stack limits).\n        baseFlatten(value, depth - 1, 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 = 93\n ** module chunks = 0\n **/","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForIn` and `baseForOwn` which iterates\n * over `object` properties returned by `keysFunc` invoking `iteratee` for\n * each property. Iteratee functions may exit iteration early by explicitly\n * 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 = 94\n ** module chunks = 0\n **/","var baseFor = require('./_baseFor'),\n    keys = require('./keys');\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n  return object && baseFor(object, iteratee, keys);\n}\n\nmodule.exports = baseForOwn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseForOwn.js\n ** module id = 95\n ** module chunks = 0\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 getPrototypeOf = Object.getPrototypeOf;\n\n/**\n * The base implementation of `_.has` 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 baseHas(object, key) {\n  // Avoid a bug in IE 10-11 where objects with a [[Prototype]] of `null`,\n  // that are composed entirely of index properties, return `false` for\n  // `hasOwnProperty` checks of them.\n  return hasOwnProperty.call(object, key) ||\n    (typeof object == 'object' && key in object && getPrototypeOf(object) === null);\n}\n\nmodule.exports = baseHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseHas.js\n ** module id = 96\n ** module chunks = 0\n **/","/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = Object.keys;\n\n/**\n * The base implementation of `_.keys` which doesn't skip the constructor\n * property of prototypes or 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 baseKeys(object) {\n  return nativeKeys(Object(object));\n}\n\nmodule.exports = baseKeys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseKeys.js\n ** module id = 97\n ** module chunks = 0\n **/","var Reflect = require('./_Reflect'),\n    iteratorToArray = require('./_iteratorToArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar enumerate = Reflect ? Reflect.enumerate : undefined,\n    propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * The base implementation of `_.keysIn` which doesn't skip the constructor\n * property of prototypes or 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  object = object == null ? object : Object(object);\n\n  var result = [];\n  for (var key in object) {\n    result.push(key);\n  }\n  return result;\n}\n\n// Fallback for IE < 9 with es6-shim.\nif (enumerate && !propertyIsEnumerable.call({ 'valueOf': 1 }, 'valueOf')) {\n  baseKeysIn = function(object) {\n    return iteratorToArray(enumerate(object));\n  };\n}\n\nmodule.exports = baseKeysIn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseKeysIn.js\n ** module id = 98\n ** module chunks = 0\n **/","var Stack = require('./_Stack'),\n    arrayEach = require('./_arrayEach'),\n    assignMergeValue = require('./_assignMergeValue'),\n    baseMergeDeep = require('./_baseMergeDeep'),\n    isArray = require('./isArray'),\n    isObject = require('./isObject'),\n    isTypedArray = require('./isTypedArray'),\n    keysIn = require('./keysIn');\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 counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n  if (object === source) {\n    return;\n  }\n  var props = (isArray(source) || isTypedArray(source))\n    ? undefined\n    : keysIn(source);\n\n  arrayEach(props || source, function(srcValue, key) {\n    if (props) {\n      key = srcValue;\n      srcValue = source[key];\n    }\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(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  });\n}\n\nmodule.exports = baseMerge;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseMerge.js\n ** module id = 99\n ** module chunks = 0\n **/","var assignMergeValue = require('./_assignMergeValue'),\n    baseClone = require('./_baseClone'),\n    copyArray = require('./_copyArray'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isArrayLikeObject = require('./isArrayLikeObject'),\n    isFunction = require('./isFunction'),\n    isObject = require('./isObject'),\n    isPlainObject = require('./isPlainObject'),\n    isTypedArray = require('./isTypedArray'),\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 counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n  var objValue = object[key],\n      srcValue = 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    newValue = srcValue;\n    if (isArray(srcValue) || isTypedArray(srcValue)) {\n      if (isArray(objValue)) {\n        newValue = objValue;\n      }\n      else if (isArrayLikeObject(objValue)) {\n        newValue = copyArray(objValue);\n      }\n      else {\n        isCommon = false;\n        newValue = baseClone(srcValue, !customizer);\n      }\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      if (isArguments(objValue)) {\n        newValue = toPlainObject(objValue);\n      }\n      else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) {\n        isCommon = false;\n        newValue = baseClone(srcValue, !customizer);\n      }\n      else {\n        newValue = objValue;\n      }\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  stack.set(srcValue, newValue);\n\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n  }\n  stack['delete'](srcValue);\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\n **/","var arrayReduce = require('./_arrayReduce');\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property names.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} props The property names to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, props) {\n  object = Object(object);\n  return arrayReduce(props, function(result, key) {\n    if (key in object) {\n      result[key] = object[key];\n    }\n    return result;\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\n **/","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new function.\n */\nfunction baseProperty(key) {\n  return function(object) {\n    return object == null ? undefined : object[key];\n  };\n}\n\nmodule.exports = baseProperty;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseProperty.js\n ** module id = 102\n ** module chunks = 0\n **/","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n  var index = -1,\n      result = Array(n);\n\n  while (++index < n) {\n    result[index] = iteratee(index);\n  }\n  return result;\n}\n\nmodule.exports = baseTimes;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseTimes.js\n ** module id = 103\n ** module chunks = 0\n **/","/**\n * Checks if `value` is a global object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {null|Object} Returns `value` if it's a global object, else `null`.\n */\nfunction checkGlobal(value) {\n  return (value && value.Object === Object) ? value : null;\n}\n\nmodule.exports = checkGlobal;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_checkGlobal.js\n ** module id = 104\n ** module chunks = 0\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 result = new buffer.constructor(buffer.length);\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 = 105\n ** module chunks = 0\n **/","var addMapEntry = require('./_addMapEntry'),\n    arrayReduce = require('./_arrayReduce'),\n    mapToArray = require('./_mapToArray');\n\n/**\n * Creates a clone of `map`.\n *\n * @private\n * @param {Object} map The map to clone.\n * @returns {Object} Returns the cloned map.\n */\nfunction cloneMap(map) {\n  return arrayReduce(mapToArray(map), addMapEntry, new map.constructor);\n}\n\nmodule.exports = cloneMap;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneMap.js\n ** module id = 106\n ** module chunks = 0\n **/","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n  var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n  result.lastIndex = regexp.lastIndex;\n  return result;\n}\n\nmodule.exports = cloneRegExp;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneRegExp.js\n ** module id = 107\n ** module chunks = 0\n **/","var addSetEntry = require('./_addSetEntry'),\n    arrayReduce = require('./_arrayReduce'),\n    setToArray = require('./_setToArray');\n\n/**\n * Creates a clone of `set`.\n *\n * @private\n * @param {Object} set The set to clone.\n * @returns {Object} Returns the cloned set.\n */\nfunction cloneSet(set) {\n  return arrayReduce(setToArray(set), addSetEntry, new set.constructor);\n}\n\nmodule.exports = cloneSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneSet.js\n ** module id = 108\n ** module chunks = 0\n **/","var Symbol = require('./_Symbol');\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n  return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nmodule.exports = cloneSymbol;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneSymbol.js\n ** module id = 109\n ** module chunks = 0\n **/","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneTypedArray.js\n ** module id = 110\n ** module chunks = 0\n **/","var assignValue = require('./_assignValue');\n\n/**\n * This function is like `copyObject` except that it accepts a function to\n * customize copied values.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property names 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 copyObjectWith(source, props, object, customizer) {\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      : source[key];\n\n    assignValue(object, key, newValue);\n  }\n  return object;\n}\n\nmodule.exports = copyObjectWith;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_copyObjectWith.js\n ** module id = 111\n ** module chunks = 0\n **/","var copyObject = require('./_copyObject'),\n    getSymbols = require('./_getSymbols');\n\n/**\n * Copies own symbol properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n  return copyObject(source, getSymbols(source), object);\n}\n\nmodule.exports = copySymbols;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_copySymbols.js\n ** module id = 112\n ** module chunks = 0\n **/","var isIterateeCall = require('./_isIterateeCall'),\n    rest = require('./rest');\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 rest(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 = 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 = 113\n ** module chunks = 0\n **/","/**\n * Creates a base function for methods like `_.forIn`.\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 = 114\n ** module chunks = 0\n **/","var baseProperty = require('./_baseProperty');\n\n/**\n * Gets the \"length\" property value of `object`.\n *\n * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792)\n * that affects Safari on at least iOS 8.1-8.3 ARM64.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {*} Returns the \"length\" value.\n */\nvar getLength = baseProperty('length');\n\nmodule.exports = getLength;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_getLength.js\n ** module id = 115\n ** module chunks = 0\n **/","/** Built-in value references. */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own symbol properties of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = getOwnPropertySymbols || function() {\n  return [];\n};\n\nmodule.exports = getSymbols;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_getSymbols.js\n ** module id = 116\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    Set = require('./_Set'),\n    WeakMap = require('./_WeakMap');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    objectTag = '[object Object]',\n    setTag = '[object Set]',\n    weakMapTag = '[object WeakMap]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = Function.prototype.toString;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Used to detect maps, sets, and weakmaps. */\nvar mapCtorString = Map ? funcToString.call(Map) : '',\n    setCtorString = Set ? funcToString.call(Set) : '',\n    weakMapCtorString = WeakMap ? funcToString.call(WeakMap) : '';\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction getTag(value) {\n  return objectToString.call(value);\n}\n\n// Fallback for IE 11 providing `toStringTag` values for maps, sets, and weakmaps.\nif ((Map && getTag(new Map) != mapTag) ||\n    (Set && getTag(new Set) != setTag) ||\n    (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n  getTag = function(value) {\n    var result = objectToString.call(value),\n        Ctor = result == objectTag ? value.constructor : null,\n        ctorString = typeof Ctor == 'function' ? funcToString.call(Ctor) : '';\n\n    if (ctorString) {\n      switch (ctorString) {\n        case mapCtorString: return mapTag;\n        case setCtorString: return setTag;\n        case weakMapCtorString: return weakMapTag;\n      }\n    }\n    return result;\n  };\n}\n\nmodule.exports = getTag;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_getTag.js\n ** module id = 117\n ** module chunks = 0\n **/","var hashHas = require('./_hashHas');\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\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(hash, key) {\n  return hashHas(hash, key) && delete hash[key];\n}\n\nmodule.exports = hashDelete;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_hashDelete.js\n ** module id = 118\n ** module chunks = 0\n **/","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @param {Object} hash The hash to query.\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(hash, key) {\n  if (nativeCreate) {\n    var result = hash[key];\n    return result === HASH_UNDEFINED ? undefined : result;\n  }\n  return hasOwnProperty.call(hash, key) ? hash[key] : undefined;\n}\n\nmodule.exports = hashGet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_hashGet.js\n ** module id = 119\n ** module chunks = 0\n **/","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n */\nfunction hashSet(hash, key, value) {\n  hash[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n}\n\nmodule.exports = hashSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_hashSet.js\n ** module id = 120\n ** module chunks = 0\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 * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n  var length = array.length,\n      result = array.constructor(length);\n\n  // Add properties assigned by `RegExp#exec`.\n  if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n    result.index = array.index;\n    result.input = array.input;\n  }\n  return result;\n}\n\nmodule.exports = initCloneArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_initCloneArray.js\n ** module id = 121\n ** module chunks = 0\n **/","var cloneArrayBuffer = require('./_cloneArrayBuffer'),\n    cloneMap = require('./_cloneMap'),\n    cloneRegExp = require('./_cloneRegExp'),\n    cloneSet = require('./_cloneSet'),\n    cloneSymbol = require('./_cloneSymbol'),\n    cloneTypedArray = require('./_cloneTypedArray');\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\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/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n  var Ctor = object.constructor;\n  switch (tag) {\n    case arrayBufferTag:\n      return cloneArrayBuffer(object);\n\n    case boolTag:\n    case dateTag:\n      return new Ctor(+object);\n\n    case float32Tag: case float64Tag:\n    case int8Tag: case int16Tag: case int32Tag:\n    case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n      return cloneTypedArray(object, isDeep);\n\n    case mapTag:\n      return cloneMap(object);\n\n    case numberTag:\n    case stringTag:\n      return new Ctor(object);\n\n    case regexpTag:\n      return cloneRegExp(object);\n\n    case setTag:\n      return cloneSet(object);\n\n    case symbolTag:\n      return cloneSymbol(object);\n  }\n}\n\nmodule.exports = initCloneByTag;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_initCloneByTag.js\n ** module id = 122\n ** module chunks = 0\n **/","var baseCreate = require('./_baseCreate'),\n    isPrototype = require('./_isPrototype');\n\n/** Built-in value references. */\nvar getPrototypeOf = Object.getPrototypeOf;\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(getPrototypeOf(object))\n    : {};\n}\n\nmodule.exports = initCloneObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_initCloneObject.js\n ** module id = 123\n ** module chunks = 0\n **/","var eq = require('./eq'),\n    isArrayLike = require('./isArrayLike'),\n    isIndex = require('./_isIndex'),\n    isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call, 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    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 = 124\n ** module chunks = 0\n **/","/**\n * Converts `iterator` to an array.\n *\n * @private\n * @param {Object} iterator The iterator to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction iteratorToArray(iterator) {\n  var data,\n      result = [];\n\n  while (!(data = iterator.next()).done) {\n    result.push(data.value);\n  }\n  return result;\n}\n\nmodule.exports = iteratorToArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_iteratorToArray.js\n ** module id = 125\n ** module chunks = 0\n **/","var Hash = require('./_Hash'),\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 mapClear() {\n  this.__data__ = {\n    'hash': new Hash,\n    'map': Map ? new Map : [],\n    'string': new Hash\n  };\n}\n\nmodule.exports = mapClear;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapClear.js\n ** module id = 126\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    assocDelete = require('./_assocDelete'),\n    hashDelete = require('./_hashDelete'),\n    isKeyable = require('./_isKeyable');\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 mapDelete(key) {\n  var data = this.__data__;\n  if (isKeyable(key)) {\n    return hashDelete(typeof key == 'string' ? data.string : data.hash, key);\n  }\n  return Map ? data.map['delete'](key) : assocDelete(data.map, key);\n}\n\nmodule.exports = mapDelete;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapDelete.js\n ** module id = 127\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    assocGet = require('./_assocGet'),\n    hashGet = require('./_hashGet'),\n    isKeyable = require('./_isKeyable');\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 mapGet(key) {\n  var data = this.__data__;\n  if (isKeyable(key)) {\n    return hashGet(typeof key == 'string' ? data.string : data.hash, key);\n  }\n  return Map ? data.map.get(key) : assocGet(data.map, key);\n}\n\nmodule.exports = mapGet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapGet.js\n ** module id = 128\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    assocHas = require('./_assocHas'),\n    hashHas = require('./_hashHas'),\n    isKeyable = require('./_isKeyable');\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 mapHas(key) {\n  var data = this.__data__;\n  if (isKeyable(key)) {\n    return hashHas(typeof key == 'string' ? data.string : data.hash, key);\n  }\n  return Map ? data.map.has(key) : assocHas(data.map, key);\n}\n\nmodule.exports = mapHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapHas.js\n ** module id = 129\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    assocSet = require('./_assocSet'),\n    hashSet = require('./_hashSet'),\n    isKeyable = require('./_isKeyable');\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 object.\n */\nfunction mapSet(key, value) {\n  var data = this.__data__;\n  if (isKeyable(key)) {\n    hashSet(typeof key == 'string' ? data.string : data.hash, key, value);\n  } else if (Map) {\n    data.map.set(key, value);\n  } else {\n    assocSet(data.map, key, value);\n  }\n  return this;\n}\n\nmodule.exports = mapSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapSet.js\n ** module id = 130\n ** module chunks = 0\n **/","/**\n * Converts `map` to an array.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction mapToArray(map) {\n  var index = -1,\n      result = Array(map.size);\n\n  map.forEach(function(value, key) {\n    result[++index] = [key, value];\n  });\n  return result;\n}\n\nmodule.exports = mapToArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapToArray.js\n ** module id = 131\n ** module chunks = 0\n **/","/**\n * Converts `set` to an array.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction setToArray(set) {\n  var index = -1,\n      result = Array(set.size);\n\n  set.forEach(function(value) {\n    result[++index] = value;\n  });\n  return result;\n}\n\nmodule.exports = setToArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_setToArray.js\n ** module id = 132\n ** module chunks = 0\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__ = { 'array': [], 'map': null };\n}\n\nmodule.exports = stackClear;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackClear.js\n ** module id = 133\n ** module chunks = 0\n **/","var assocDelete = require('./_assocDelete');\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n  var data = this.__data__,\n      array = data.array;\n\n  return array ? assocDelete(array, key) : data.map['delete'](key);\n}\n\nmodule.exports = stackDelete;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackDelete.js\n ** module id = 134\n ** module chunks = 0\n **/","var assocGet = require('./_assocGet');\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n  var data = this.__data__,\n      array = data.array;\n\n  return array ? assocGet(array, key) : data.map.get(key);\n}\n\nmodule.exports = stackGet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackGet.js\n ** module id = 135\n ** module chunks = 0\n **/","var assocHas = require('./_assocHas');\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n  var data = this.__data__,\n      array = data.array;\n\n  return array ? assocHas(array, key) : data.map.has(key);\n}\n\nmodule.exports = stackHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackHas.js\n ** module id = 136\n ** module chunks = 0\n **/","var MapCache = require('./_MapCache'),\n    assocSet = require('./_assocSet');\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 object.\n */\nfunction stackSet(key, value) {\n  var data = this.__data__,\n      array = data.array;\n\n  if (array) {\n    if (array.length < (LARGE_ARRAY_SIZE - 1)) {\n      assocSet(array, key, value);\n    } else {\n      data.array = null;\n      data.map = new MapCache(array);\n    }\n  }\n  var map = data.map;\n  if (map) {\n    map.set(key, value);\n  }\n  return this;\n}\n\nmodule.exports = stackSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackSet.js\n ** module id = 137\n ** module chunks = 0\n **/","/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var object = { 'user': 'fred' };\n * var getter = _.constant(object);\n *\n * getter() === object;\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 = 138\n ** module chunks = 0\n **/","var constant = require('./constant'),\n    root = require('./_root');\n\n/** Used to determine if values are of the language type `Object`. */\nvar objectTypes = {\n  'function': true,\n  'object': true\n};\n\n/** Detect free variable `exports`. */\nvar freeExports = (objectTypes[typeof exports] && exports && !exports.nodeType)\n  ? exports\n  : undefined;\n\n/** Detect free variable `module`. */\nvar freeModule = (objectTypes[typeof module] && module && !module.nodeType)\n  ? module\n  : undefined;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = (freeModule && freeModule.exports === freeExports)\n  ? freeExports\n  : undefined;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\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 = !Buffer ? constant(false) : function(value) {\n  return value instanceof Buffer;\n};\n\nmodule.exports = isBuffer;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isBuffer.js\n ** module id = 139\n ** module chunks = 0\n **/","var isFunction = require('./isFunction'),\n    isHostObject = require('./_isHostObject'),\n    isObjectLike = require('./isObjectLike');\n\n/** Used to match `RegExp` [syntax characters](http://ecma-international.org/ecma-262/6.0/#sec-patterns). */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari > 5). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = Function.prototype.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 * Checks if `value` is a native function.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function, else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\nfunction isNative(value) {\n  if (value == null) {\n    return false;\n  }\n  if (isFunction(value)) {\n    return reIsNative.test(funcToString.call(value));\n  }\n  return isObjectLike(value) &&\n    (isHostObject(value) ? reIsNative : reIsHostCtor).test(value);\n}\n\nmodule.exports = isNative;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isNative.js\n ** module id = 140\n ** module chunks = 0\n **/","var isHostObject = require('./_isHostObject'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = Function.prototype.toString;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar getPrototypeOf = Object.getPrototypeOf;\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 * @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) ||\n      objectToString.call(value) != objectTag || isHostObject(value)) {\n    return false;\n  }\n  var proto = getPrototypeOf(value);\n  if (proto === null) {\n    return true;\n  }\n  var Ctor = proto.constructor;\n  return (typeof Ctor == 'function' &&\n    Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString);\n}\n\nmodule.exports = isPlainObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isPlainObject.js\n ** module id = 141\n ** module chunks = 0\n **/","var isArray = require('./isArray'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar stringTag = '[object String]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n  return typeof value == 'string' ||\n    (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag);\n}\n\nmodule.exports = isString;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isString.js\n ** module id = 142\n ** module chunks = 0\n **/","var baseFlatten = require('./_baseFlatten'),\n    basePick = require('./_basePick'),\n    rest = require('./rest');\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [props] The property names to pick, specified\n *  individually or in arrays.\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 = rest(function(object, props) {\n  return object == null ? {} : basePick(object, baseFlatten(props, 1));\n});\n\nmodule.exports = pick;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/pick.js\n ** module id = 143\n ** module chunks = 0\n **/","var toNumber = require('./toNumber');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n    MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This function is loosely based on [`ToInteger`](http://www.ecma-international.org/ecma-262/6.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3');\n * // => 3\n */\nfunction toInteger(value) {\n  if (!value) {\n    return value === 0 ? value : 0;\n  }\n  value = toNumber(value);\n  if (value === INFINITY || value === -INFINITY) {\n    var sign = (value < 0 ? -1 : 1);\n    return sign * MAX_INTEGER;\n  }\n  var remainder = value % 1;\n  return value === value ? (remainder ? value - remainder : value) : 0;\n}\n\nmodule.exports = toInteger;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/toInteger.js\n ** module id = 144\n ** module chunks = 0\n **/","var isFunction = require('./isFunction'),\n    isObject = require('./isObject');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3);\n * // => 3\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3');\n * // => 3\n */\nfunction toNumber(value) {\n  if (isObject(value)) {\n    var other = isFunction(value.valueOf) ? value.valueOf() : value;\n    value = isObject(other) ? (other + '') : other;\n  }\n  if (typeof value != 'string') {\n    return value === 0 ? value : +value;\n  }\n  value = value.replace(reTrim, '');\n  var isBinary = reIsBinary.test(value);\n  return (isBinary || reIsOctal.test(value))\n    ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n    : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/toNumber.js\n ** module id = 145\n ** module chunks = 0\n **/","var copyObject = require('./_copyObject'),\n    keysIn = require('./keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable\n * properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\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 = 146\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\n// Shimming starts here.\n(function() {\n  // Utils.\n  var logging = require('./utils').log;\n  var browserDetails = require('./utils').browserDetails;\n  // Export to the adapter global object visible in the browser.\n  module.exports.browserDetails = browserDetails;\n  module.exports.extractVersion = require('./utils').extractVersion;\n  module.exports.disableLog = require('./utils').disableLog;\n\n  // Uncomment if you do not want any logging at all including the switch\n  // statement below. Can also be turned off in the browser via\n  // adapter.disableLog(true) but then logging from the switch statement below\n  // will still appear.\n  //require('./utils').disableLog(true);\n\n  // Browser shims.\n  var chromeShim = require('./chrome/chrome_shim') || null;\n  var edgeShim = require('./edge/edge_shim') || null;\n  var firefoxShim = require('./firefox/firefox_shim') || null;\n\n  // Shim browser if found.\n  switch (browserDetails.browser) {\n    case 'chrome':\n      if (!chromeShim || !chromeShim.shimPeerConnection) {\n        logging('Chrome shim is not included in this adapter release.');\n        return;\n      }\n      logging('adapter.js shimming chrome!');\n      // Export to the adapter global object visible in the browser.\n      module.exports.browserShim = chromeShim;\n\n      chromeShim.shimGetUserMedia();\n      chromeShim.shimSourceObject();\n      chromeShim.shimPeerConnection();\n      chromeShim.shimOnTrack();\n      break;\n    case 'edge':\n      if (!edgeShim || !edgeShim.shimPeerConnection) {\n        logging('MS edge shim is not included in this adapter release.');\n        return;\n      }\n      logging('adapter.js shimming edge!');\n      // Export to the adapter global object visible in the browser.\n      module.exports.browserShim = edgeShim;\n\n      edgeShim.shimPeerConnection();\n      break;\n    case 'firefox':\n      if (!firefoxShim || !firefoxShim.shimPeerConnection) {\n        logging('Firefox shim is not included in this adapter release.');\n        return;\n      }\n      logging('adapter.js shimming firefox!');\n      // Export to the adapter global object visible in the browser.\n      module.exports.browserShim = firefoxShim;\n\n      firefoxShim.shimGetUserMedia();\n      firefoxShim.shimSourceObject();\n      firefoxShim.shimPeerConnection();\n      firefoxShim.shimOnTrack();\n      break;\n    default:\n      logging('Unsupported browser!');\n  }\n})();\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/adapter_core.js\n ** module id = 147\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\nvar logging = require('../utils.js').log;\nvar browserDetails = require('../utils.js').browserDetails;\n\nvar chromeShim = {\n  shimOnTrack: function() {\n    if (typeof window === 'object' && window.RTCPeerConnection && !('ontrack' in\n        window.RTCPeerConnection.prototype)) {\n      Object.defineProperty(window.RTCPeerConnection.prototype, 'ontrack', {\n        get: function() { return this._ontrack; },\n        set: function(f) {\n          var self = this;\n          if (this._ontrack) {\n            this.removeEventListener('track', this._ontrack);\n            this.removeEventListener('addstream', this._ontrackpoly);\n          }\n          this.addEventListener('track', this._ontrack = f);\n          this.addEventListener('addstream', this._ontrackpoly = function(e) {\n            // onaddstream does not fire when a track is added to an existing stream.\n            // but stream.onaddtrack is implemented so we use that\n            e.stream.addEventListener('addtrack', function(te) {\n              var event = new Event('track');\n              event.track = te.track;\n              event.receiver = {track: te.track};\n              event.streams = [e.stream];\n              self.dispatchEvent(event);\n            });\n            e.stream.getTracks().forEach(function(track) {\n              var event = new Event('track');\n              event.track = track;\n              event.receiver = {track: track};\n              event.streams = [e.stream];\n              this.dispatchEvent(event);\n            }.bind(this));\n          }.bind(this));\n        }\n      });\n    }\n  },\n\n  shimSourceObject: function() {\n    if (typeof window === 'object') {\n      if (window.HTMLMediaElement &&\n        !('srcObject' in window.HTMLMediaElement.prototype)) {\n        // Shim the srcObject property, once, when HTMLMediaElement is found.\n        Object.defineProperty(window.HTMLMediaElement.prototype, 'srcObject', {\n          get: function() {\n            return this._srcObject;\n          },\n          set: function(stream) {\n            var self = this;\n            // Use _srcObject as a private property for this shim\n            this._srcObject = stream;\n            if (this.src) {\n              URL.revokeObjectURL(this.src);\n            }\n\n            if (!stream) {\n              this.src = '';\n              return;\n            }\n            this.src = URL.createObjectURL(stream);\n            // We need to recreate the blob url when a track is added or removed.\n            // Doing it manually since we want to avoid a recursion.\n            stream.addEventListener('addtrack', function() {\n              if (self.src) {\n                URL.revokeObjectURL(self.src);\n              }\n              self.src = URL.createObjectURL(stream);\n            });\n            stream.addEventListener('removetrack', function() {\n              if (self.src) {\n                URL.revokeObjectURL(self.src);\n              }\n              self.src = URL.createObjectURL(stream);\n            });\n          }\n        });\n      }\n    }\n  },\n\n  shimPeerConnection: function() {\n    // The RTCPeerConnection object.\n    window.RTCPeerConnection = function(pcConfig, pcConstraints) {\n      // Translate iceTransportPolicy to iceTransports,\n      // see https://code.google.com/p/webrtc/issues/detail?id=4869\n      logging('PeerConnection');\n      if (pcConfig && pcConfig.iceTransportPolicy) {\n        pcConfig.iceTransports = pcConfig.iceTransportPolicy;\n      }\n\n      var pc = new webkitRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors\n      var origGetStats = pc.getStats.bind(pc);\n      pc.getStats = function(selector, successCallback, errorCallback) { // jshint ignore: line\n        var self = this;\n        var args = arguments;\n\n        // If selector is a function then we are in the old style stats so just\n        // pass back the original getStats format to avoid breaking old users.\n        if (arguments.length > 0 && typeof selector === 'function') {\n          return origGetStats(selector, successCallback);\n        }\n\n        var fixChromeStats_ = function(response) {\n          var standardReport = {};\n          var reports = response.result();\n          reports.forEach(function(report) {\n            var standardStats = {\n              id: report.id,\n              timestamp: report.timestamp,\n              type: report.type\n            };\n            report.names().forEach(function(name) {\n              standardStats[name] = report.stat(name);\n            });\n            standardReport[standardStats.id] = standardStats;\n          });\n\n          return standardReport;\n        };\n\n        if (arguments.length >= 2) {\n          var successCallbackWrapper_ = function(response) {\n            args[1](fixChromeStats_(response));\n          };\n\n          return origGetStats.apply(this, [successCallbackWrapper_, arguments[0]]);\n        }\n\n        // promise-support\n        return new Promise(function(resolve, reject) {\n          if (args.length === 1 && selector === null) {\n            origGetStats.apply(self, [\n                function(response) {\n                  resolve.apply(null, [fixChromeStats_(response)]);\n                }, reject]);\n          } else {\n            origGetStats.apply(self, [resolve, reject]);\n          }\n        });\n      };\n\n      return pc;\n    };\n    window.RTCPeerConnection.prototype = webkitRTCPeerConnection.prototype;\n\n    // wrap static methods. Currently just generateCertificate.\n    if (webkitRTCPeerConnection.generateCertificate) {\n      Object.defineProperty(window.RTCPeerConnection, 'generateCertificate', {\n        get: function() {\n          if (arguments.length) {\n            return webkitRTCPeerConnection.generateCertificate.apply(null,\n                arguments);\n          } else {\n            return webkitRTCPeerConnection.generateCertificate;\n          }\n        }\n      });\n    }\n\n    // add promise support\n    ['createOffer', 'createAnswer'].forEach(function(method) {\n      var nativeMethod = webkitRTCPeerConnection.prototype[method];\n      webkitRTCPeerConnection.prototype[method] = function() {\n        var self = this;\n        if (arguments.length < 1 || (arguments.length === 1 &&\n            typeof(arguments[0]) === 'object')) {\n          var opts = arguments.length === 1 ? arguments[0] : undefined;\n          return new Promise(function(resolve, reject) {\n            nativeMethod.apply(self, [resolve, reject, opts]);\n          });\n        } else {\n          return nativeMethod.apply(this, arguments);\n        }\n      };\n    });\n\n    ['setLocalDescription', 'setRemoteDescription',\n        'addIceCandidate'].forEach(function(method) {\n      var nativeMethod = webkitRTCPeerConnection.prototype[method];\n      webkitRTCPeerConnection.prototype[method] = function() {\n        var args = arguments;\n        var self = this;\n        return new Promise(function(resolve, reject) {\n          nativeMethod.apply(self, [args[0],\n              function() {\n                resolve();\n                if (args.length >= 2) {\n                  args[1].apply(null, []);\n                }\n              },\n              function(err) {\n                reject(err);\n                if (args.length >= 3) {\n                  args[2].apply(null, [err]);\n                }\n              }]\n            );\n        });\n      };\n    });\n  },\n\n  // Attach a media stream to an element.\n  attachMediaStream: function(element, stream) {\n    logging('DEPRECATED, attachMediaStream will soon be removed.');\n    if (browserDetails.version >= 43) {\n      element.srcObject = stream;\n    } else if (typeof element.src !== 'undefined') {\n      element.src = URL.createObjectURL(stream);\n    } else {\n      logging('Error attaching stream to element.');\n    }\n  },\n\n  reattachMediaStream: function(to, from) {\n    logging('DEPRECATED, reattachMediaStream will soon be removed.');\n    if (browserDetails.version >= 43) {\n      to.srcObject = from.srcObject;\n    } else {\n      to.src = from.src;\n    }\n  }\n}\n\n\n// Expose public methods.\nmodule.exports = {\n  shimOnTrack: chromeShim.shimOnTrack,\n  shimSourceObject: chromeShim.shimSourceObject,\n  shimPeerConnection: chromeShim.shimPeerConnection,\n  shimGetUserMedia: require('./getusermedia'),\n  attachMediaStream: chromeShim.attachMediaStream,\n  reattachMediaStream: chromeShim.reattachMediaStream\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/chrome/chrome_shim.js\n ** module id = 148\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\nvar logging = require('../utils.js').log;\n\n// Expose public methods.\nmodule.exports = function() {\n  var constraintsToChrome_ = function(c) {\n    if (typeof c !== 'object' || c.mandatory || c.optional) {\n      return c;\n    }\n    var cc = {};\n    Object.keys(c).forEach(function(key) {\n      if (key === 'require' || key === 'advanced' || key === 'mediaSource') {\n        return;\n      }\n      var r = (typeof c[key] === 'object') ? c[key] : {ideal: c[key]};\n      if (r.exact !== undefined && typeof r.exact === 'number') {\n        r.min = r.max = r.exact;\n      }\n      var oldname_ = function(prefix, name) {\n        if (prefix) {\n          return prefix + name.charAt(0).toUpperCase() + name.slice(1);\n        }\n        return (name === 'deviceId') ? 'sourceId' : name;\n      };\n      if (r.ideal !== undefined) {\n        cc.optional = cc.optional || [];\n        var oc = {};\n        if (typeof r.ideal === 'number') {\n          oc[oldname_('min', key)] = r.ideal;\n          cc.optional.push(oc);\n          oc = {};\n          oc[oldname_('max', key)] = r.ideal;\n          cc.optional.push(oc);\n        } else {\n          oc[oldname_('', key)] = r.ideal;\n          cc.optional.push(oc);\n        }\n      }\n      if (r.exact !== undefined && typeof r.exact !== 'number') {\n        cc.mandatory = cc.mandatory || {};\n        cc.mandatory[oldname_('', key)] = r.exact;\n      } else {\n        ['min', 'max'].forEach(function(mix) {\n          if (r[mix] !== undefined) {\n            cc.mandatory = cc.mandatory || {};\n            cc.mandatory[oldname_(mix, key)] = r[mix];\n          }\n        });\n      }\n    });\n    if (c.advanced) {\n      cc.optional = (cc.optional || []).concat(c.advanced);\n    }\n    return cc;\n  };\n\n  var getUserMedia_ = function(constraints, onSuccess, onError) {\n    if (constraints.audio) {\n      constraints.audio = constraintsToChrome_(constraints.audio);\n    }\n    if (constraints.video) {\n      constraints.video = constraintsToChrome_(constraints.video);\n    }\n    logging('chrome: ' + JSON.stringify(constraints));\n    return navigator.webkitGetUserMedia(constraints, onSuccess, onError);\n  };\n  navigator.getUserMedia = getUserMedia_;\n\n  // Returns the result of getUserMedia as a Promise.\n  var getUserMediaPromise_ = function(constraints) {\n    return new Promise(function(resolve, reject) {\n      navigator.getUserMedia(constraints, resolve, reject);\n    });\n  }\n\n  if (!navigator.mediaDevices) {\n    navigator.mediaDevices = {getUserMedia: getUserMediaPromise_,\n                             enumerateDevices: function() {\n      return new Promise(function(resolve) {\n        var kinds = {audio: 'audioinput', video: 'videoinput'};\n        return MediaStreamTrack.getSources(function(devices) {\n          resolve(devices.map(function(device) {\n            return {label: device.label,\n                    kind: kinds[device.kind],\n                    deviceId: device.id,\n                    groupId: ''};\n          }));\n        });\n      });\n    }};\n  }\n\n  // A shim for getUserMedia method on the mediaDevices object.\n  // TODO(KaptenJansson) remove once implemented in Chrome stable.\n  if (!navigator.mediaDevices.getUserMedia) {\n    navigator.mediaDevices.getUserMedia = function(constraints) {\n      return getUserMediaPromise_(constraints);\n    };\n  } else {\n    // Even though Chrome 45 has navigator.mediaDevices and a getUserMedia\n    // function which returns a Promise, it does not accept spec-style\n    // constraints.\n    var origGetUserMedia = navigator.mediaDevices.getUserMedia.\n        bind(navigator.mediaDevices);\n    navigator.mediaDevices.getUserMedia = function(c) {\n      if (c) {\n        logging('spec:   ' + JSON.stringify(c)); // whitespace for alignment\n        c.audio = constraintsToChrome_(c.audio);\n        c.video = constraintsToChrome_(c.video);\n        logging('chrome: ' + JSON.stringify(c));\n      }\n      return origGetUserMedia(c);\n    }.bind(this);\n  }\n\n  // Dummy devicechange event methods.\n  // TODO(KaptenJansson) remove once implemented in Chrome stable.\n  if (typeof navigator.mediaDevices.addEventListener === 'undefined') {\n    navigator.mediaDevices.addEventListener = function() {\n      logging('Dummy mediaDevices.addEventListener called.');\n    };\n  }\n  if (typeof navigator.mediaDevices.removeEventListener === 'undefined') {\n    navigator.mediaDevices.removeEventListener = function() {\n      logging('Dummy mediaDevices.removeEventListener called.');\n    };\n  }\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/chrome/getusermedia.js\n ** module id = 149\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\n// SDP helpers.\nvar SDPUtils = {};\n\n// Generate an alphanumeric identifier for cname or mids.\n// TODO: use UUIDs instead? https://gist.github.com/jed/982883\nSDPUtils.generateIdentifier = function() {\n  return Math.random().toString(36).substr(2, 10);\n};\n\n// The RTCP CNAME used by all peerconnections from the same JS.\nSDPUtils.localCName = SDPUtils.generateIdentifier();\n\n\n// Splits SDP into lines, dealing with both CRLF and LF.\nSDPUtils.splitLines = function(blob) {\n  return blob.trim().split('\\n').map(function(line) {\n    return line.trim();\n  });\n};\n// Splits SDP into sessionpart and mediasections. Ensures CRLF.\nSDPUtils.splitSections = function(blob) {\n  var parts = blob.split('\\r\\nm=');\n  return parts.map(function(part, index) {\n    return (index > 0 ? 'm=' + part : part).trim() + '\\r\\n';\n  });\n};\n\n// Returns lines that start with a certain prefix.\nSDPUtils.matchPrefix = function(blob, prefix) {\n  return SDPUtils.splitLines(blob).filter(function(line) {\n    return line.indexOf(prefix) === 0;\n  });\n};\n\n// Parses an ICE candidate line. Sample input:\n// candidate:702786350 2 udp 41819902 8.8.8.8 60769 typ relay raddr 8.8.8.8 rport 55996\"\nSDPUtils.parseCandidate = function(line) {\n  var parts;\n  // Parse both variants.\n  if (line.indexOf('a=candidate:') === 0) {\n    parts = line.substring(12).split(' ');\n  } else {\n    parts = line.substring(10).split(' ');\n  }\n\n  var candidate = {\n    foundation: parts[0],\n    component: parts[1],\n    protocol: parts[2].toLowerCase(),\n    priority: parseInt(parts[3], 10),\n    ip: parts[4],\n    port: parseInt(parts[5], 10),\n    // skip parts[6] == 'typ'\n    type: parts[7]\n  };\n\n  for (var i = 8; i < parts.length; i += 2) {\n    switch (parts[i]) {\n      case 'raddr':\n        candidate.relatedAddress = parts[i + 1];\n        break;\n      case 'rport':\n        candidate.relatedPort = parseInt(parts[i + 1], 10);\n        break;\n      case 'tcptype':\n        candidate.tcpType = parts[i + 1];\n        break;\n      default: // Unknown extensions are silently ignored.\n        break;\n    }\n  }\n  return candidate;\n};\n\n// Translates a candidate object into SDP candidate attribute.\nSDPUtils.writeCandidate = function(candidate) {\n  var sdp = [];\n  sdp.push(candidate.foundation);\n  sdp.push(candidate.component);\n  sdp.push(candidate.protocol.toUpperCase());\n  sdp.push(candidate.priority);\n  sdp.push(candidate.ip);\n  sdp.push(candidate.port);\n\n  var type = candidate.type;\n  sdp.push('typ');\n  sdp.push(type);\n  if (type !== 'host' && candidate.relatedAddress &&\n      candidate.relatedPort) {\n    sdp.push('raddr');\n    sdp.push(candidate.relatedAddress); // was: relAddr\n    sdp.push('rport');\n    sdp.push(candidate.relatedPort); // was: relPort\n  }\n  if (candidate.tcpType && candidate.protocol.toLowerCase() === 'tcp') {\n    sdp.push('tcptype');\n    sdp.push(candidate.tcpType);\n  }\n  return 'candidate:' + sdp.join(' ');\n};\n\n// Parses an rtpmap line, returns RTCRtpCoddecParameters. Sample input:\n// a=rtpmap:111 opus/48000/2\nSDPUtils.parseRtpMap = function(line) {\n  var parts = line.substr(9).split(' ');\n  var parsed = {\n    payloadType: parseInt(parts.shift(), 10) // was: id\n  };\n\n  parts = parts[0].split('/');\n\n  parsed.name = parts[0];\n  parsed.clockRate = parseInt(parts[1], 10); // was: clockrate\n  parsed.numChannels = parts.length === 3 ? parseInt(parts[2], 10) : 1; // was: channels\n  return parsed;\n};\n\n// Generate an a=rtpmap line from RTCRtpCodecCapability or RTCRtpCodecParameters.\nSDPUtils.writeRtpMap = function(codec) {\n  var pt = codec.payloadType;\n  if (codec.preferredPayloadType !== undefined) {\n    pt = codec.preferredPayloadType;\n  }\n  return 'a=rtpmap:' + pt + ' ' + codec.name + '/' + codec.clockRate +\n      (codec.numChannels !== 1 ? '/' + codec.numChannels : '') + '\\r\\n';\n};\n\n// Parses an ftmp line, returns dictionary. Sample input:\n// a=fmtp:96 vbr=on;cng=on\n// Also deals with vbr=on; cng=on\nSDPUtils.parseFmtp = function(line) {\n  var parsed = {};\n  var kv;\n  var parts = line.substr(line.indexOf(' ') + 1).split(';');\n  for (var j = 0; j < parts.length; j++) {\n    kv = parts[j].trim().split('=');\n    parsed[kv[0].trim()] = kv[1];\n  }\n  return parsed;\n};\n\n// Generates an a=ftmp line from RTCRtpCodecCapability or RTCRtpCodecParameters.\nSDPUtils.writeFtmp = function(codec) {\n  var line = '';\n  var pt = codec.payloadType;\n  if (codec.preferredPayloadType !== undefined) {\n    pt = codec.preferredPayloadType;\n  }\n  if (codec.parameters && codec.parameters.length) {\n    var params = [];\n    Object.keys(codec.parameters).forEach(function(param) {\n      params.push(param + '=' + codec.parameters[param]);\n    });\n    line += 'a=fmtp:' + pt + ' ' + params.join(';') + '\\r\\n';\n  }\n  return line;\n};\n\n// Parses an rtcp-fb line, returns RTCPRtcpFeedback object. Sample input:\n// a=rtcp-fb:98 nack rpsi\nSDPUtils.parseRtcpFb = function(line) {\n  var parts = line.substr(line.indexOf(' ') + 1).split(' ');\n  return {\n    type: parts.shift(),\n    parameter: parts.join(' ')\n  };\n};\n// Generate a=rtcp-fb lines from RTCRtpCodecCapability or RTCRtpCodecParameters.\nSDPUtils.writeRtcpFb = function(codec) {\n  var lines = '';\n  var pt = codec.payloadType;\n  if (codec.preferredPayloadType !== undefined) {\n    pt = codec.preferredPayloadType;\n  }\n  if (codec.rtcpFeedback && codec.rtcpFeedback.length) {\n    // FIXME: special handling for trr-int?\n    codec.rtcpFeedback.forEach(function(fb) {\n      lines += 'a=rtcp-fb:' + pt + ' ' + fb.type + ' ' + fb.parameter +\n          '\\r\\n';\n    });\n  }\n  return lines;\n};\n\n// Parses an RFC 5576 ssrc media attribute. Sample input:\n// a=ssrc:3735928559 cname:something\nSDPUtils.parseSsrcMedia = function(line) {\n  var sp = line.indexOf(' ');\n  var parts = {\n    ssrc: line.substr(7, sp - 7),\n  };\n  var colon = line.indexOf(':', sp);\n  if (colon > -1) {\n    parts.attribute = line.substr(sp + 1, colon - sp - 1);\n    parts.value = line.substr(colon + 1);\n  } else {\n    parts.attribute = line.substr(sp + 1);\n  }\n  return parts;\n};\n\n// Extracts DTLS parameters from SDP media section or sessionpart.\n// FIXME: for consistency with other functions this should only\n//   get the fingerprint line as input. See also getIceParameters.\nSDPUtils.getDtlsParameters = function(mediaSection, sessionpart) {\n  var lines = SDPUtils.splitLines(mediaSection);\n  lines = lines.concat(SDPUtils.splitLines(sessionpart)); // Search in session part, too.\n  var fpLine = lines.filter(function(line) {\n    return line.indexOf('a=fingerprint:') === 0;\n  })[0].substr(14);\n  // Note: a=setup line is ignored since we use the 'auto' role.\n  var dtlsParameters = {\n    role: 'auto',\n    fingerprints: [{\n      algorithm: fpLine.split(' ')[0],\n      value: fpLine.split(' ')[1]\n    }]\n  };\n  return dtlsParameters;\n};\n\n// Serializes DTLS parameters to SDP.\nSDPUtils.writeDtlsParameters = function(params, setupType) {\n  var sdp = 'a=setup:' + setupType + '\\r\\n';\n  params.fingerprints.forEach(function(fp) {\n    sdp += 'a=fingerprint:' + fp.algorithm + ' ' + fp.value + '\\r\\n';\n  });\n  return sdp;\n};\n// Parses ICE information from SDP media section or sessionpart.\n// FIXME: for consistency with other functions this should only\n//   get the ice-ufrag and ice-pwd lines as input.\nSDPUtils.getIceParameters = function(mediaSection, sessionpart) {\n  var lines = SDPUtils.splitLines(mediaSection);\n  lines = lines.concat(SDPUtils.splitLines(sessionpart)); // Search in session part, too.\n  var iceParameters = {\n    usernameFragment: lines.filter(function(line) {\n      return line.indexOf('a=ice-ufrag:') === 0;\n    })[0].substr(12),\n    password: lines.filter(function(line) {\n      return line.indexOf('a=ice-pwd:') === 0;\n    })[0].substr(10)\n  };\n  return iceParameters;\n};\n\n// Serializes ICE parameters to SDP.\nSDPUtils.writeIceParameters = function(params) {\n  return 'a=ice-ufrag:' + params.usernameFragment + '\\r\\n' +\n      'a=ice-pwd:' + params.password + '\\r\\n';\n};\n\n// Parses the SDP media section and returns RTCRtpParameters.\nSDPUtils.parseRtpParameters = function(mediaSection) {\n  var description = {\n    codecs: [],\n    headerExtensions: [],\n    fecMechanisms: [],\n    rtcp: []\n  };\n  var lines = SDPUtils.splitLines(mediaSection);\n  var mline = lines[0].split(' ');\n  for (var i = 3; i < mline.length; i++) { // find all codecs from mline[3..]\n    var pt = mline[i];\n    var rtpmapline = SDPUtils.matchPrefix(\n        mediaSection, 'a=rtpmap:' + pt + ' ')[0];\n    if (rtpmapline) {\n      var codec = SDPUtils.parseRtpMap(rtpmapline);\n      var fmtps = SDPUtils.matchPrefix(\n          mediaSection, 'a=fmtp:' + pt + ' ');\n      // Only the first a=fmtp:<pt> is considered.\n      codec.parameters = fmtps.length ? SDPUtils.parseFmtp(fmtps[0]) : {};\n      codec.rtcpFeedback = SDPUtils.matchPrefix(\n          mediaSection, 'a=rtcp-fb:' + pt + ' ')\n        .map(SDPUtils.parseRtcpFb);\n      description.codecs.push(codec);\n    }\n  }\n  // FIXME: parse headerExtensions, fecMechanisms and rtcp.\n  return description;\n};\n\n// Generates parts of the SDP media section describing the capabilities / parameters.\nSDPUtils.writeRtpDescription = function(kind, caps) {\n  var sdp = '';\n\n  // Build the mline.\n  sdp += 'm=' + kind + ' ';\n  sdp += caps.codecs.length > 0 ? '9' : '0'; // reject if no codecs.\n  sdp += ' UDP/TLS/RTP/SAVPF ';\n  sdp += caps.codecs.map(function(codec) {\n    if (codec.preferredPayloadType !== undefined) {\n      return codec.preferredPayloadType;\n    }\n    return codec.payloadType;\n  }).join(' ') + '\\r\\n';\n\n  sdp += 'c=IN IP4 0.0.0.0\\r\\n';\n  sdp += 'a=rtcp:9 IN IP4 0.0.0.0\\r\\n';\n\n  // Add a=rtpmap lines for each codec. Also fmtp and rtcp-fb.\n  caps.codecs.forEach(function(codec) {\n    sdp += SDPUtils.writeRtpMap(codec);\n    sdp += SDPUtils.writeFtmp(codec);\n    sdp += SDPUtils.writeRtcpFb(codec);\n  });\n  // FIXME: add headerExtensions, fecMechanismş and rtcp.\n  sdp += 'a=rtcp-mux\\r\\n';\n  return sdp;\n};\n\nSDPUtils.writeSessionBoilerplate = function() {\n  // FIXME: sess-id should be an NTP timestamp.\n  return 'v=0\\r\\n' +\n      'o=thisisadapterortc 8169639915646943137 2 IN IP4 127.0.0.1\\r\\n' +\n      's=-\\r\\n' +\n      't=0 0\\r\\n';\n};\n\nSDPUtils.writeMediaSection = function(transceiver, caps, type, stream) {\n  var sdp = SDPUtils.writeRtpDescription(transceiver.kind, caps);\n\n  // Map ICE parameters (ufrag, pwd) to SDP.\n  sdp += SDPUtils.writeIceParameters(\n      transceiver.iceGatherer.getLocalParameters());\n\n  // Map DTLS parameters to SDP.\n  sdp += SDPUtils.writeDtlsParameters(\n      transceiver.dtlsTransport.getLocalParameters(),\n      type === 'offer' ? 'actpass' : 'active');\n\n  sdp += 'a=mid:' + transceiver.mid + '\\r\\n';\n\n  if (transceiver.rtpSender && transceiver.rtpReceiver) {\n    sdp += 'a=sendrecv\\r\\n';\n  } else if (transceiver.rtpSender) {\n    sdp += 'a=sendonly\\r\\n';\n  } else if (transceiver.rtpReceiver) {\n    sdp += 'a=recvonly\\r\\n';\n  } else {\n    sdp += 'a=inactive\\r\\n';\n  }\n\n  // FIXME: for RTX there might be multiple SSRCs. Not implemented in Edge yet.\n  if (transceiver.rtpSender) {\n    var msid = 'msid:' + stream.id + ' ' +\n        transceiver.rtpSender.track.id + '\\r\\n';\n    sdp += 'a=' + msid;\n    sdp += 'a=ssrc:' + transceiver.sendSsrc + ' ' + msid;\n  }\n  // FIXME: this should be written by writeRtpDescription.\n  sdp += 'a=ssrc:' + transceiver.sendSsrc + ' cname:' +\n      SDPUtils.localCName + '\\r\\n';\n  return sdp;\n};\n\n// Gets the direction from the mediaSection or the sessionpart.\nSDPUtils.getDirection = function(mediaSection, sessionpart) {\n  // Look for sendrecv, sendonly, recvonly, inactive, default to sendrecv.\n  var lines = SDPUtils.splitLines(mediaSection);\n  for (var i = 0; i < lines.length; i++) {\n    switch (lines[i]) {\n      case 'a=sendrecv':\n      case 'a=sendonly':\n      case 'a=recvonly':\n      case 'a=inactive':\n        return lines[i].substr(2);\n    }\n  }\n  if (sessionpart) {\n    return SDPUtils.getDirection(sessionpart);\n  }\n  return 'sendrecv';\n};\n\n// Expose public methods.\nmodule.exports = SDPUtils;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/edge/edge_sdp.js\n ** module id = 150\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\nvar SDPUtils = require('./edge_sdp');\nvar logging = require('../utils').log;\nvar browserDetails = require('../utils').browserDetails;\n\nvar edgeShim = {\n  shimPeerConnection: function() {\n    if (window.RTCIceGatherer) {\n      // ORTC defines an RTCIceCandidate object but no constructor.\n      // Not implemented in Edge.\n      if (!window.RTCIceCandidate) {\n        window.RTCIceCandidate = function(args) {\n          return args;\n        };\n      }\n      // ORTC does not have a session description object but\n      // other browsers (i.e. Chrome) that will support both PC and ORTC\n      // in the future might have this defined already.\n      if (!window.RTCSessionDescription) {\n        window.RTCSessionDescription = function(args) {\n          return args;\n        };\n      }\n    }\n\n    window.RTCPeerConnection = function(config) {\n      var self = this;\n\n      var _eventTarget = document.createDocumentFragment();\n      ['addEventListener', 'removeEventListener', 'dispatchEvent'].forEach(\n          function(method) {\n        self[method] = _eventTarget[method].bind(_eventTarget);\n      });\n\n      this.onicecandidate = null;\n      this.onaddstream = null;\n      this.ontrack = null;\n      this.onremovestream = null;\n      this.onsignalingstatechange = null;\n      this.oniceconnectionstatechange = null;\n      this.onnegotiationneeded = null;\n      this.ondatachannel = null;\n\n      this.localStreams = [];\n      this.remoteStreams = [];\n      this.getLocalStreams = function() { return self.localStreams; };\n      this.getRemoteStreams = function() { return self.remoteStreams; };\n\n      this.localDescription = new RTCSessionDescription({\n        type: '',\n        sdp: ''\n      });\n      this.remoteDescription = new RTCSessionDescription({\n        type: '',\n        sdp: ''\n      });\n      this.signalingState = 'stable';\n      this.iceConnectionState = 'new';\n      this.iceGatheringState = 'new';\n\n      this.iceOptions = {\n        gatherPolicy: 'all',\n        iceServers: []\n      };\n      if (config && config.iceTransportPolicy) {\n        switch (config.iceTransportPolicy) {\n          case 'all':\n          case 'relay':\n            this.iceOptions.gatherPolicy = config.iceTransportPolicy;\n            break;\n          case 'none':\n            // FIXME: remove once implementation and spec have added this.\n            throw new TypeError('iceTransportPolicy \"none\" not supported');\n        }\n      }\n      if (config && config.iceServers) {\n        // Edge does not like\n        // 1) stun:\n        // 2) turn: that does not have all of turn:host:port?transport=udp\n        this.iceOptions.iceServers = config.iceServers.filter(function(server) {\n          if (server && server.urls) {\n            server.urls = server.urls.filter(function(url) {\n              return url.indexOf('transport=udp') !== -1;\n            })[0];\n            return true;\n          }\n          return false;\n        });\n      }\n\n      // per-track iceGathers, iceTransports, dtlsTransports, rtpSenders, ...\n      // everything that is needed to describe a SDP m-line.\n      this.transceivers = [];\n\n      // since the iceGatherer is currently created in createOffer but we\n      // must not emit candidates until after setLocalDescription we buffer\n      // them in this array.\n      this._localIceCandidatesBuffer = [];\n    };\n\n    window.RTCPeerConnection.prototype._emitBufferedCandidates = function() {\n      var self = this;\n      var sections = SDPUtils.splitSections(self.localDescription.sdp);\n      // FIXME: need to apply ice candidates in a way which is async but in-order\n      this._localIceCandidatesBuffer.forEach(function(event) {\n        var end = !event.candidate || Object.keys(event.candidate).length == 0;\n        if (end) {\n          for (var j = 1; j < sections.length; j++) {\n            sections[j] += 'a=end-of-candidates\\r\\n';\n          }\n        } else {\n          sections[event.candidate.sdpMLineIndex + 1] +=\n              'a=' + event.candidate.candidate + '\\r\\n';\n        }\n        self.dispatchEvent(event);\n        if (self.onicecandidate !== null) {\n          self.onicecandidate(event);\n        }\n        if (!event.candidate) {\n          self.iceGatheringState = 'complete';\n        }\n      });\n      this._localIceCandidatesBuffer = [];\n      this.localDescription.sdp = sections.join('');\n    };\n\n    window.RTCPeerConnection.prototype.addStream = function(stream) {\n      // Clone is necessary for local demos mostly, attaching directly\n      // to two different senders does not work (build 10547).\n      this.localStreams.push(stream.clone());\n      this._maybeFireNegotiationNeeded();\n    };\n\n    window.RTCPeerConnection.prototype.removeStream = function(stream) {\n      var idx = this.localStreams.indexOf(stream);\n      if (idx > -1) {\n        this.localStreams.splice(idx, 1);\n        this._maybeFireNegotiationNeeded();\n      }\n    };\n\n    // Determines the intersection of local and remote capabilities.\n    window.RTCPeerConnection.prototype._getCommonCapabilities =\n        function(localCapabilities, remoteCapabilities) {\n      var commonCapabilities = {\n        codecs: [],\n        headerExtensions: [],\n        fecMechanisms: []\n      };\n      localCapabilities.codecs.forEach(function(lCodec) {\n        for (var i = 0; i < remoteCapabilities.codecs.length; i++) {\n          var rCodec = remoteCapabilities.codecs[i];\n          if (lCodec.name.toLowerCase() === rCodec.name.toLowerCase() &&\n              lCodec.clockRate === rCodec.clockRate &&\n              lCodec.numChannels === rCodec.numChannels) {\n            // push rCodec so we reply with offerer payload type\n            commonCapabilities.codecs.push(rCodec);\n\n            // FIXME: also need to determine intersection between\n            // .rtcpFeedback and .parameters\n            break;\n          }\n        }\n      });\n\n      localCapabilities.headerExtensions.forEach(function(lHeaderExtension) {\n        for (var i = 0; i < remoteCapabilities.headerExtensions.length; i++) {\n          var rHeaderExtension = remoteCapabilities.headerExtensions[i];\n          if (lHeaderExtension.uri === rHeaderExtension.uri) {\n            commonCapabilities.headerExtensions.push(rHeaderExtension);\n            break;\n          }\n        }\n      });\n\n      // FIXME: fecMechanisms\n      return commonCapabilities;\n    };\n\n    // Create ICE gatherer, ICE transport and DTLS transport.\n    window.RTCPeerConnection.prototype._createIceAndDtlsTransports =\n        function(mid, sdpMLineIndex) {\n      var self = this;\n      var iceGatherer = new RTCIceGatherer(self.iceOptions);\n      var iceTransport = new RTCIceTransport(iceGatherer);\n      iceGatherer.onlocalcandidate = function(evt) {\n        var event = new Event('icecandidate');\n        event.candidate = {sdpMid: mid, sdpMLineIndex: sdpMLineIndex};\n\n        var cand = evt.candidate;\n        var end = !cand || Object.keys(cand).length === 0;\n        // Edge emits an empty object for RTCIceCandidateComplete‥\n        if (end) {\n          // polyfill since RTCIceGatherer.state is not implemented in Edge 10547 yet.\n          if (iceGatherer.state === undefined) {\n            iceGatherer.state = 'completed';\n          }\n\n          // Emit a candidate with type endOfCandidates to make the samples work.\n          // Edge requires addIceCandidate with this empty candidate to start checking.\n          // The real solution is to signal end-of-candidates to the other side when\n          // getting the null candidate but some apps (like the samples) don't do that.\n          event.candidate.candidate =\n              'candidate:1 1 udp 1 0.0.0.0 9 typ endOfCandidates';\n        } else {\n          // RTCIceCandidate doesn't have a component, needs to be added\n          cand.component = iceTransport.component === 'RTCP' ? 2 : 1;\n          event.candidate.candidate = SDPUtils.writeCandidate(cand);\n        }\n\n        var complete = self.transceivers.every(function(transceiver) {\n          return transceiver.iceGatherer &&\n              transceiver.iceGatherer.state === 'completed';\n        });\n        // update .localDescription with candidate and (potentially) end-of-candidates.\n        //     To make this harder, the gatherer might emit candidates before localdescription\n        //     is set. To make things worse, gather.getLocalCandidates still errors in\n        //     Edge 10547 when no candidates have been gathered yet.\n        if (self.localDescription && self.localDescription.type !== '') {\n          var sections = SDPUtils.splitSections(self.localDescription.sdp);\n          sections[sdpMLineIndex + 1] += (!end ? 'a=' + event.candidate.candidate :\n              'a=end-of-candidates') + '\\r\\n';\n          self.localDescription.sdp = sections.join('');\n        }\n\n        // Emit candidate if localDescription is set.\n        // Also emits null candidate when all gatherers are complete.\n        switch(self.iceGatheringState) {\n        case 'new':\n          self._localIceCandidatesBuffer.push(event);\n          if (complete) {\n            self._localIceCandidatesBuffer.push(new Event('icecandidate'));\n          }\n          break;\n        case 'gathering':\n          self._emitBufferedCandidates();\n          self.dispatchEvent(event);\n          if (self.onicecandidate !== null) {\n            self.onicecandidate(event);\n          }\n          if (complete) {\n            self.dispatchEvent(new Event('icecandidate'));\n            if (self.onicecandidate !== null) {\n              self.onicecandidate(new Event('icecandidate'));\n            }\n            self.iceGatheringState = 'complete';\n          }\n          break;\n        case 'complete':\n          // should not happen... currently!\n          break;\n        }\n      };\n      iceTransport.onicestatechange = function() {\n        self._updateConnectionState();\n      };\n\n      var dtlsTransport = new RTCDtlsTransport(iceTransport);\n      dtlsTransport.ondtlsstatechange = function() {\n        self._updateConnectionState();\n      };\n      dtlsTransport.onerror = function() {\n        // onerror does not set state to failed by itself.\n        dtlsTransport.state = 'failed';\n        self._updateConnectionState();\n      };\n\n      return {\n        iceGatherer: iceGatherer,\n        iceTransport: iceTransport,\n        dtlsTransport: dtlsTransport\n      };\n    };\n\n    // Start the RTP Sender and Receiver for a transceiver.\n    window.RTCPeerConnection.prototype._transceive = function(transceiver,\n        send, recv) {\n      var params = this._getCommonCapabilities(transceiver.localCapabilities,\n          transceiver.remoteCapabilities);\n      if (send && transceiver.rtpSender) {\n        params.encodings = [{\n          ssrc: transceiver.sendSsrc\n        }];\n        params.rtcp = {\n          cname: SDPUtils.localCName,\n          ssrc: transceiver.recvSsrc\n        };\n        transceiver.rtpSender.send(params);\n      }\n      if (recv && transceiver.rtpReceiver) {\n        params.encodings = [{\n          ssrc: transceiver.recvSsrc\n        }];\n        params.rtcp = {\n          cname: transceiver.cname,\n          ssrc: transceiver.sendSsrc\n        };\n        transceiver.rtpReceiver.receive(params);\n      }\n    };\n\n    window.RTCPeerConnection.prototype.setLocalDescription =\n        function(description) {\n      var self = this;\n      if (description.type === 'offer') {\n        if (!this._pendingOffer) {\n        } else {\n          this.transceivers = this._pendingOffer;\n          delete this._pendingOffer;\n        }\n      } else if (description.type === 'answer') {\n        var sections = SDPUtils.splitSections(self.remoteDescription.sdp);\n        var sessionpart = sections.shift();\n        sections.forEach(function(mediaSection, sdpMLineIndex) {\n          var transceiver = self.transceivers[sdpMLineIndex];\n          var iceGatherer = transceiver.iceGatherer;\n          var iceTransport = transceiver.iceTransport;\n          var dtlsTransport = transceiver.dtlsTransport;\n          var localCapabilities = transceiver.localCapabilities;\n          var remoteCapabilities = transceiver.remoteCapabilities;\n          var rejected = mediaSection.split('\\n', 1)[0]\n              .split(' ', 2)[1] === '0';\n\n          if (!rejected) {\n            var remoteIceParameters = SDPUtils.getIceParameters(mediaSection,\n                sessionpart);\n            iceTransport.start(iceGatherer, remoteIceParameters, 'controlled');\n\n            var remoteDtlsParameters = SDPUtils.getDtlsParameters(mediaSection,\n              sessionpart);\n            dtlsTransport.start(remoteDtlsParameters);\n\n            // Calculate intersection of capabilities.\n            var params = self._getCommonCapabilities(localCapabilities,\n                remoteCapabilities);\n\n            // Start the RTCRtpSender. The RTCRtpReceiver for this transceiver\n            // has already been started in setRemoteDescription.\n            self._transceive(transceiver,\n                params.codecs.length > 0,\n                false);\n          }\n        });\n      }\n\n      this.localDescription = {\n        type: description.type,\n        sdp: description.sdp\n      };\n      switch (description.type) {\n        case 'offer':\n          this._updateSignalingState('have-local-offer');\n          break;\n        case 'answer':\n          this._updateSignalingState('stable');\n          break;\n        default:\n          throw new TypeError('unsupported type \"' + description.type + '\"');\n      }\n\n      // If a success callback was provided, emit ICE candidates after it has been\n      // executed. Otherwise, emit callback after the Promise is resolved.\n      var hasCallback = arguments.length > 1 &&\n        typeof arguments[1] === 'function';\n      if (hasCallback) {\n        var cb = arguments[1];\n        window.setTimeout(function() {\n          cb();\n          if (self.iceGatheringState === 'new') {\n            self.iceGatheringState = 'gathering';\n          }\n          self._emitBufferedCandidates();\n        }, 0);\n      }\n      var p = Promise.resolve();\n      p.then(function() {\n        if (!hasCallback) {\n          if (self.iceGatheringState === 'new') {\n            self.iceGatheringState = 'gathering';\n          }\n          // Usually candidates will be emitted earlier.\n          window.setTimeout(self._emitBufferedCandidates.bind(self), 500);\n        }\n      });\n      return p;\n    };\n\n    window.RTCPeerConnection.prototype.setRemoteDescription =\n        function(description) {\n      var self = this;\n      var stream = new MediaStream();\n      var receiverList = [];\n      var sections = SDPUtils.splitSections(description.sdp);\n      var sessionpart = sections.shift();\n      sections.forEach(function(mediaSection, sdpMLineIndex) {\n        var lines = SDPUtils.splitLines(mediaSection);\n        var mline = lines[0].substr(2).split(' ');\n        var kind = mline[0];\n        var rejected = mline[1] === '0';\n        var direction = SDPUtils.getDirection(mediaSection, sessionpart);\n\n        var transceiver;\n        var iceGatherer;\n        var iceTransport;\n        var dtlsTransport;\n        var rtpSender;\n        var rtpReceiver;\n        var sendSsrc;\n        var recvSsrc;\n        var localCapabilities;\n\n        var track;\n        // FIXME: ensure the mediaSection has rtcp-mux set.\n        var remoteCapabilities = SDPUtils.parseRtpParameters(mediaSection);\n        var remoteIceParameters;\n        var remoteDtlsParameters;\n        if (!rejected) {\n          remoteIceParameters = SDPUtils.getIceParameters(mediaSection,\n              sessionpart);\n          remoteDtlsParameters = SDPUtils.getDtlsParameters(mediaSection,\n              sessionpart);\n        }\n        var mid = SDPUtils.matchPrefix(mediaSection, 'a=mid:')[0].substr(6);\n\n        var cname;\n        // Gets the first SSRC. Note that with RTX there might be multiple SSRCs.\n        var remoteSsrc = SDPUtils.matchPrefix(mediaSection, 'a=ssrc:')\n            .map(function(line) {\n              return SDPUtils.parseSsrcMedia(line);\n            })\n            .filter(function(obj) {\n              return obj.attribute === 'cname';\n            })[0];\n        if (remoteSsrc) {\n          recvSsrc = parseInt(remoteSsrc.ssrc, 10);\n          cname = remoteSsrc.value;\n        }\n\n        if (description.type === 'offer') {\n          var transports = self._createIceAndDtlsTransports(mid, sdpMLineIndex);\n\n          localCapabilities = RTCRtpReceiver.getCapabilities(kind);\n          sendSsrc = (2 * sdpMLineIndex + 2) * 1001;\n\n          rtpReceiver = new RTCRtpReceiver(transports.dtlsTransport, kind);\n\n          track = rtpReceiver.track;\n          receiverList.push([track, rtpReceiver]);\n          // FIXME: not correct when there are multiple streams but that is\n          // not currently supported in this shim.\n          stream.addTrack(track);\n\n          // FIXME: look at direction.\n          if (self.localStreams.length > 0 &&\n              self.localStreams[0].getTracks().length >= sdpMLineIndex) {\n            // FIXME: actually more complicated, needs to match types etc\n            var localtrack = self.localStreams[0].getTracks()[sdpMLineIndex];\n            rtpSender = new RTCRtpSender(localtrack, transports.dtlsTransport);\n          }\n\n          self.transceivers[sdpMLineIndex] = {\n            iceGatherer: transports.iceGatherer,\n            iceTransport: transports.iceTransport,\n            dtlsTransport: transports.dtlsTransport,\n            localCapabilities: localCapabilities,\n            remoteCapabilities: remoteCapabilities,\n            rtpSender: rtpSender,\n            rtpReceiver: rtpReceiver,\n            kind: kind,\n            mid: mid,\n            cname: cname,\n            sendSsrc: sendSsrc,\n            recvSsrc: recvSsrc\n          };\n          // Start the RTCRtpReceiver now. The RTPSender is started in setLocalDescription.\n          self._transceive(self.transceivers[sdpMLineIndex],\n              false,\n              direction === 'sendrecv' || direction === 'sendonly');\n        } else if (description.type === 'answer' && !rejected) {\n          transceiver = self.transceivers[sdpMLineIndex];\n          iceGatherer = transceiver.iceGatherer;\n          iceTransport = transceiver.iceTransport;\n          dtlsTransport = transceiver.dtlsTransport;\n          rtpSender = transceiver.rtpSender;\n          rtpReceiver = transceiver.rtpReceiver;\n          sendSsrc = transceiver.sendSsrc;\n          //recvSsrc = transceiver.recvSsrc;\n          localCapabilities = transceiver.localCapabilities;\n\n          self.transceivers[sdpMLineIndex].recvSsrc = recvSsrc;\n          self.transceivers[sdpMLineIndex].remoteCapabilities =\n              remoteCapabilities;\n          self.transceivers[sdpMLineIndex].cname = cname;\n\n          iceTransport.start(iceGatherer, remoteIceParameters, 'controlling');\n          dtlsTransport.start(remoteDtlsParameters);\n\n          self._transceive(transceiver,\n              direction === 'sendrecv' || direction === 'recvonly',\n              direction === 'sendrecv' || direction === 'sendonly');\n\n          if (rtpReceiver &&\n              (direction === 'sendrecv' || direction === 'sendonly')) {\n            track = rtpReceiver.track;\n            receiverList.push([track, rtpReceiver]);\n            stream.addTrack(track);\n          } else {\n            // FIXME: actually the receiver should be created later.\n            delete transceiver.rtpReceiver;\n          }\n        }\n      });\n\n      this.remoteDescription = {\n          type: description.type,\n          sdp: description.sdp\n      };\n      switch (description.type) {\n        case 'offer':\n          this._updateSignalingState('have-remote-offer');\n          break;\n        case 'answer':\n          this._updateSignalingState('stable');\n          break;\n        default:\n          throw new TypeError('unsupported type \"' + description.type + '\"');\n      }\n      if (stream.getTracks().length) {\n        self.remoteStreams.push(stream);\n        window.setTimeout(function() {\n          var event = new Event('addstream');\n          event.stream = stream;\n          self.dispatchEvent(event);\n          if (self.onaddstream !== null) {\n            window.setTimeout(function() {\n              self.onaddstream(event);\n            }, 0);\n          }\n\n          receiverList.forEach(function(item) {\n            var track = item[0];\n            var receiver = item[1];\n            var event = new Event('track');\n            event.track = track;\n            event.receiver = receiver;\n            event.streams = [stream];\n            self.dispatchEvent(event);\n            if (self.ontrack !== null) {\n                window.setTimeout(function() {\n                  self.ontrack(event);\n                }, 0);\n            }\n          });\n        }, 0);\n      }\n      if (arguments.length > 1 && typeof arguments[1] === 'function') {\n        window.setTimeout(arguments[1], 0);\n      }\n      return Promise.resolve();\n    };\n\n    window.RTCPeerConnection.prototype.close = function() {\n      this.transceivers.forEach(function(transceiver) {\n        /* not yet\n        if (transceiver.iceGatherer) {\n          transceiver.iceGatherer.close();\n        }\n        */\n        if (transceiver.iceTransport) {\n          transceiver.iceTransport.stop();\n        }\n        if (transceiver.dtlsTransport) {\n          transceiver.dtlsTransport.stop();\n        }\n        if (transceiver.rtpSender) {\n          transceiver.rtpSender.stop();\n        }\n        if (transceiver.rtpReceiver) {\n          transceiver.rtpReceiver.stop();\n        }\n      });\n      // FIXME: clean up tracks, local streams, remote streams, etc\n      this._updateSignalingState('closed');\n    };\n\n    // Update the signaling state.\n    window.RTCPeerConnection.prototype._updateSignalingState =\n        function(newState) {\n      this.signalingState = newState;\n      var event = new Event('signalingstatechange');\n      this.dispatchEvent(event);\n      if (this.onsignalingstatechange !== null) {\n        this.onsignalingstatechange(event);\n      }\n    };\n\n    // Determine whether to fire the negotiationneeded event.\n    window.RTCPeerConnection.prototype._maybeFireNegotiationNeeded =\n        function() {\n      // Fire away (for now).\n      var event = new Event('negotiationneeded');\n      this.dispatchEvent(event);\n      if (this.onnegotiationneeded !== null) {\n        this.onnegotiationneeded(event);\n      }\n    };\n\n    // Update the connection state.\n    window.RTCPeerConnection.prototype._updateConnectionState =\n        function() {\n      var self = this;\n      var newState;\n      var states = {\n        'new': 0,\n        closed: 0,\n        connecting: 0,\n        checking: 0,\n        connected: 0,\n        completed: 0,\n        failed: 0\n      };\n      this.transceivers.forEach(function(transceiver) {\n        states[transceiver.iceTransport.state]++;\n        states[transceiver.dtlsTransport.state]++;\n      });\n      // ICETransport.completed and connected are the same for this purpose.\n      states['connected'] += states['completed'];\n\n      newState = 'new';\n      if (states['failed'] > 0) {\n        newState = 'failed';\n      } else if (states['connecting'] > 0 || states['checking'] > 0) {\n        newState = 'connecting';\n      } else if (states['disconnected'] > 0) {\n        newState = 'disconnected';\n      } else if (states['new'] > 0) {\n        newState = 'new';\n      } else if (states['connecting'] > 0 || states['completed'] > 0) {\n        newState = 'connected';\n      }\n\n      if (newState !== self.iceConnectionState) {\n        self.iceConnectionState = newState;\n        var event = new Event('iceconnectionstatechange');\n        this.dispatchEvent(event);\n        if (this.oniceconnectionstatechange !== null) {\n          this.oniceconnectionstatechange(event);\n        }\n      }\n    };\n\n    window.RTCPeerConnection.prototype.createOffer = function() {\n      var self = this;\n      if (this._pendingOffer) {\n        throw new Error('createOffer called while there is a pending offer.');\n      }\n      var offerOptions;\n      if (arguments.length === 1 && typeof arguments[0] !== 'function') {\n        offerOptions = arguments[0];\n      } else if (arguments.length === 3) {\n        offerOptions = arguments[2];\n      }\n\n      var tracks = [];\n      var numAudioTracks = 0;\n      var numVideoTracks = 0;\n      // Default to sendrecv.\n      if (this.localStreams.length) {\n        numAudioTracks = this.localStreams[0].getAudioTracks().length;\n        numVideoTracks = this.localStreams[0].getVideoTracks().length;\n      }\n      // Determine number of audio and video tracks we need to send/recv.\n      if (offerOptions) {\n        // Reject Chrome legacy constraints.\n        if (offerOptions.mandatory || offerOptions.optional) {\n          throw new TypeError(\n              'Legacy mandatory/optional constraints not supported.');\n        }\n        if (offerOptions.offerToReceiveAudio !== undefined) {\n          numAudioTracks = offerOptions.offerToReceiveAudio;\n        }\n        if (offerOptions.offerToReceiveVideo !== undefined) {\n          numVideoTracks = offerOptions.offerToReceiveVideo;\n        }\n      }\n      if (this.localStreams.length) {\n        // Push local streams.\n        this.localStreams[0].getTracks().forEach(function(track) {\n          tracks.push({\n            kind: track.kind,\n            track: track,\n            wantReceive: track.kind === 'audio' ?\n                numAudioTracks > 0 : numVideoTracks > 0\n          });\n          if (track.kind === 'audio') {\n            numAudioTracks--;\n          } else if (track.kind === 'video') {\n            numVideoTracks--;\n          }\n        });\n      }\n      // Create M-lines for recvonly streams.\n      while (numAudioTracks > 0 || numVideoTracks > 0) {\n        if (numAudioTracks > 0) {\n          tracks.push({\n            kind: 'audio',\n            wantReceive: true\n          });\n          numAudioTracks--;\n        }\n        if (numVideoTracks > 0) {\n          tracks.push({\n            kind: 'video',\n            wantReceive: true\n          });\n          numVideoTracks--;\n        }\n      }\n\n      var sdp = SDPUtils.writeSessionBoilerplate();\n      var transceivers = [];\n      tracks.forEach(function(mline, sdpMLineIndex) {\n        // For each track, create an ice gatherer, ice transport, dtls transport,\n        // potentially rtpsender and rtpreceiver.\n        var track = mline.track;\n        var kind = mline.kind;\n        var mid = SDPUtils.generateIdentifier();\n\n        var transports = self._createIceAndDtlsTransports(mid, sdpMLineIndex);\n\n        var localCapabilities = RTCRtpSender.getCapabilities(kind);\n        var rtpSender;\n        var rtpReceiver;\n\n        // generate an ssrc now, to be used later in rtpSender.send\n        var sendSsrc = (2 * sdpMLineIndex + 1) * 1001;\n        if (track) {\n          rtpSender = new RTCRtpSender(track, transports.dtlsTransport);\n        }\n\n        if (mline.wantReceive) {\n          rtpReceiver = new RTCRtpReceiver(transports.dtlsTransport, kind);\n        }\n\n        transceivers[sdpMLineIndex] = {\n          iceGatherer: transports.iceGatherer,\n          iceTransport: transports.iceTransport,\n          dtlsTransport: transports.dtlsTransport,\n          localCapabilities: localCapabilities,\n          remoteCapabilities: null,\n          rtpSender: rtpSender,\n          rtpReceiver: rtpReceiver,\n          kind: kind,\n          mid: mid,\n          sendSsrc: sendSsrc,\n          recvSsrc: null\n        };\n        var transceiver = transceivers[sdpMLineIndex];\n        sdp += SDPUtils.writeMediaSection(transceiver,\n            transceiver.localCapabilities, 'offer', self.localStreams[0]);\n      });\n\n      this._pendingOffer = transceivers;\n      var desc = new RTCSessionDescription({\n        type: 'offer',\n        sdp: sdp\n      });\n      if (arguments.length && typeof arguments[0] === 'function') {\n        window.setTimeout(arguments[0], 0, desc);\n      }\n      return Promise.resolve(desc);\n    };\n\n    window.RTCPeerConnection.prototype.createAnswer = function() {\n      var self = this;\n      var answerOptions;\n      if (arguments.length === 1 && typeof arguments[0] !== 'function') {\n        answerOptions = arguments[0];\n      } else if (arguments.length === 3) {\n        answerOptions = arguments[2];\n      }\n\n      var sdp = SDPUtils.writeSessionBoilerplate();\n      this.transceivers.forEach(function(transceiver) {\n        // Calculate intersection of capabilities.\n        var commonCapabilities = self._getCommonCapabilities(\n            transceiver.localCapabilities,\n            transceiver.remoteCapabilities);\n\n        sdp += SDPUtils.writeMediaSection(transceiver, commonCapabilities,\n            'answer', self.localStreams[0]);\n      });\n\n      var desc = new RTCSessionDescription({\n        type: 'answer',\n        sdp: sdp\n      });\n      if (arguments.length && typeof arguments[0] === 'function') {\n        window.setTimeout(arguments[0], 0, desc);\n      }\n      return Promise.resolve(desc);\n    };\n\n    window.RTCPeerConnection.prototype.addIceCandidate = function(candidate) {\n      var mLineIndex = candidate.sdpMLineIndex;\n      if (candidate.sdpMid) {\n        for (var i = 0; i < this.transceivers.length; i++) {\n          if (this.transceivers[i].mid === candidate.sdpMid) {\n            mLineIndex = i;\n            break;\n          }\n        }\n      }\n      var transceiver = this.transceivers[mLineIndex];\n      if (transceiver) {\n        var cand = Object.keys(candidate.candidate).length > 0 ?\n            SDPUtils.parseCandidate(candidate.candidate) : {};\n        // Ignore Chrome's invalid candidates since Edge does not like them.\n        if (cand.protocol === 'tcp' && cand.port === 0) {\n          return;\n        }\n        // Ignore RTCP candidates, we assume RTCP-MUX.\n        if (cand.component !== '1') {\n          return;\n        }\n        // A dirty hack to make samples work.\n        if (cand.type === 'endOfCandidates') {\n          cand = {};\n        }\n        transceiver.iceTransport.addRemoteCandidate(cand);\n\n        // update the remoteDescription.\n        var sections = SDPUtils.splitSections(this.remoteDescription.sdp);\n        sections[mLineIndex + 1] += (cand.type ? candidate.candidate.trim()\n            : 'a=end-of-candidates') + '\\r\\n';\n        this.remoteDescription.sdp = sections.join('');\n      }\n      if (arguments.length > 1 && typeof arguments[1] === 'function') {\n        window.setTimeout(arguments[1], 0);\n      }\n      return Promise.resolve();\n    };\n\n    window.RTCPeerConnection.prototype.getStats = function() {\n      var promises = [];\n      this.transceivers.forEach(function(transceiver) {\n        ['rtpSender', 'rtpReceiver', 'iceGatherer', 'iceTransport',\n            'dtlsTransport'].forEach(function(method) {\n          if (transceiver[method]) {\n            promises.push(transceiver[method].getStats());\n          }\n        });\n      });\n      var cb = arguments.length > 1 && typeof arguments[1] === 'function' &&\n          arguments[1];\n      return new Promise(function(resolve) {\n        var results = {};\n        Promise.all(promises).then(function(res) {\n          res.forEach(function(result) {\n            Object.keys(result).forEach(function(id) {\n              results[id] = result[id];\n            });\n          });\n          if (cb) {\n            window.setTimeout(cb, 0, results);\n          }\n          resolve(results);\n        });\n      });\n    };\n  },\n\n  // Attach a media stream to an element.\n  attachMediaStream: function(element, stream) {\n    logging('DEPRECATED, attachMediaStream will soon be removed.');\n    element.srcObject = stream;\n  },\n\n  reattachMediaStream: function(to, from) {\n    logging('DEPRECATED, reattachMediaStream will soon be removed.');\n    to.srcObject = from.srcObject;\n  }\n}\n\n// Expose public methods.\nmodule.exports = {\n  shimPeerConnection: edgeShim.shimPeerConnection,\n  attachMediaStream: edgeShim.attachMediaStream,\n  reattachMediaStream: edgeShim.reattachMediaStream\n}\n\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/edge/edge_shim.js\n ** module id = 151\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\nvar logging = require('../utils').log;\nvar browserDetails = require('../utils').browserDetails;\n\nvar firefoxShim = {\n  shimOnTrack: function() {\n    if (typeof window === 'object' && window.RTCPeerConnection && !('ontrack' in\n        window.RTCPeerConnection.prototype)) {\n      Object.defineProperty(window.RTCPeerConnection.prototype, 'ontrack', {\n        get: function() { return this._ontrack; },\n        set: function(f) {\n          var self = this;\n          if (this._ontrack) {\n            this.removeEventListener('track', this._ontrack);\n            this.removeEventListener('addstream', this._ontrackpoly);\n          }\n          this.addEventListener('track', this._ontrack = f);\n          this.addEventListener('addstream', this._ontrackpoly = function(e) {\n            e.stream.getTracks().forEach(function(track) {\n              var event = new Event('track');\n              event.track = track;\n              event.receiver = {track: track};\n              event.streams = [e.stream];\n              this.dispatchEvent(event);\n            }.bind(this));\n          }.bind(this));\n        }\n      });\n    }\n  },\n\n  shimSourceObject: function() {\n    // Firefox has supported mozSrcObject since FF22, unprefixed in 42.\n    if (typeof window === 'object') {\n      if (window.HTMLMediaElement &&\n        !('srcObject' in window.HTMLMediaElement.prototype)) {\n        // Shim the srcObject property, once, when HTMLMediaElement is found.\n        Object.defineProperty(window.HTMLMediaElement.prototype, 'srcObject', {\n          get: function() {\n            return this.mozSrcObject;\n          },\n          set: function(stream) {\n            this.mozSrcObject = stream;\n          }\n        });\n      }\n    }\n  },\n\n  shimPeerConnection: function() {\n    // The RTCPeerConnection object.\n    if (!window.RTCPeerConnection) {\n      window.RTCPeerConnection = function(pcConfig, pcConstraints) {\n        if (browserDetails.version < 38) {\n          // .urls is not supported in FF < 38.\n          // create RTCIceServers with a single url.\n          if (pcConfig && pcConfig.iceServers) {\n            var newIceServers = [];\n            for (var i = 0; i < pcConfig.iceServers.length; i++) {\n              var server = pcConfig.iceServers[i];\n              if (server.hasOwnProperty('urls')) {\n                for (var j = 0; j < server.urls.length; j++) {\n                  var newServer = {\n                    url: server.urls[j]\n                  };\n                  if (server.urls[j].indexOf('turn') === 0) {\n                    newServer.username = server.username;\n                    newServer.credential = server.credential;\n                  }\n                  newIceServers.push(newServer);\n                }\n              } else {\n                newIceServers.push(pcConfig.iceServers[i]);\n              }\n            }\n            pcConfig.iceServers = newIceServers;\n          }\n        }\n        return new mozRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors\n      };\n      window.RTCPeerConnection.prototype = mozRTCPeerConnection.prototype;\n\n      // wrap static methods. Currently just generateCertificate.\n      if (mozRTCPeerConnection.generateCertificate) {\n        Object.defineProperty(window.RTCPeerConnection, 'generateCertificate', {\n          get: function() {\n            if (arguments.length) {\n              return mozRTCPeerConnection.generateCertificate.apply(null,\n                  arguments);\n            } else {\n              return mozRTCPeerConnection.generateCertificate;\n            }\n          }\n        });\n      }\n\n      window.RTCSessionDescription = mozRTCSessionDescription;\n      window.RTCIceCandidate = mozRTCIceCandidate;\n    }\n  },\n\n  shimGetUserMedia: function() {\n    // getUserMedia constraints shim.\n    var getUserMedia_ = function(constraints, onSuccess, onError) {\n      var constraintsToFF37_ = function(c) {\n        if (typeof c !== 'object' || c.require) {\n          return c;\n        }\n        var require = [];\n        Object.keys(c).forEach(function(key) {\n          if (key === 'require' || key === 'advanced' || key === 'mediaSource') {\n            return;\n          }\n          var r = c[key] = (typeof c[key] === 'object') ?\n              c[key] : {ideal: c[key]};\n          if (r.min !== undefined ||\n              r.max !== undefined || r.exact !== undefined) {\n            require.push(key);\n          }\n          if (r.exact !== undefined) {\n            if (typeof r.exact === 'number') {\n              r. min = r.max = r.exact;\n            } else {\n              c[key] = r.exact;\n            }\n            delete r.exact;\n          }\n          if (r.ideal !== undefined) {\n            c.advanced = c.advanced || [];\n            var oc = {};\n            if (typeof r.ideal === 'number') {\n              oc[key] = {min: r.ideal, max: r.ideal};\n            } else {\n              oc[key] = r.ideal;\n            }\n            c.advanced.push(oc);\n            delete r.ideal;\n            if (!Object.keys(r).length) {\n              delete c[key];\n            }\n          }\n        });\n        if (require.length) {\n          c.require = require;\n        }\n        return c;\n      };\n      if (browserDetails.version < 38) {\n        logging('spec: ' + JSON.stringify(constraints));\n        if (constraints.audio) {\n          constraints.audio = constraintsToFF37_(constraints.audio);\n        }\n        if (constraints.video) {\n          constraints.video = constraintsToFF37_(constraints.video);\n        }\n        logging('ff37: ' + JSON.stringify(constraints));\n      }\n      return navigator.mozGetUserMedia(constraints, onSuccess, onError);\n    };\n\n    navigator.getUserMedia = getUserMedia_;\n\n    // Returns the result of getUserMedia as a Promise.\n    var getUserMediaPromise_ = function(constraints) {\n      return new Promise(function(resolve, reject) {\n        navigator.getUserMedia(constraints, resolve, reject);\n      });\n    }\n\n    // Shim for mediaDevices on older versions.\n    if (!navigator.mediaDevices) {\n      navigator.mediaDevices = {getUserMedia: getUserMediaPromise_,\n        addEventListener: function() { },\n        removeEventListener: function() { }\n      };\n    }\n    navigator.mediaDevices.enumerateDevices =\n        navigator.mediaDevices.enumerateDevices || function() {\n      return new Promise(function(resolve) {\n        var infos = [\n          {kind: 'audioinput', deviceId: 'default', label: '', groupId: ''},\n          {kind: 'videoinput', deviceId: 'default', label: '', groupId: ''}\n        ];\n        resolve(infos);\n      });\n    };\n\n    if (browserDetails.version < 41) {\n      // Work around http://bugzil.la/1169665\n      var orgEnumerateDevices =\n          navigator.mediaDevices.enumerateDevices.bind(navigator.mediaDevices);\n      navigator.mediaDevices.enumerateDevices = function() {\n        return orgEnumerateDevices().then(undefined, function(e) {\n          if (e.name === 'NotFoundError') {\n            return [];\n          }\n          throw e;\n        });\n      };\n    }\n  },\n\n  // Attach a media stream to an element.\n  attachMediaStream: function(element, stream) {\n    logging('DEPRECATED, attachMediaStream will soon be removed.');\n    element.srcObject = stream;\n  },\n\n  reattachMediaStream: function(to, from) {\n    logging('DEPRECATED, reattachMediaStream will soon be removed.');\n    to.srcObject = from.srcObject;\n  }\n}\n\n// Expose public methods.\nmodule.exports = {\n  shimOnTrack: firefoxShim.shimOnTrack,\n  shimSourceObject: firefoxShim.shimSourceObject,\n  shimPeerConnection: firefoxShim.shimPeerConnection,\n  shimGetUserMedia: require('./getusermedia'),\n  attachMediaStream: firefoxShim.attachMediaStream,\n  reattachMediaStream: firefoxShim.reattachMediaStream\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/firefox/firefox_shim.js\n ** module id = 152\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\nvar logging = require('../utils').log;\nvar browserDetails = require('../utils').browserDetails;\n\n// Expose public methods.\nmodule.exports = function() {\n  // getUserMedia constraints shim.\n  var getUserMedia_ = function(constraints, onSuccess, onError) {\n    var constraintsToFF37_ = function(c) {\n      if (typeof c !== 'object' || c.require) {\n        return c;\n      }\n      var require = [];\n      Object.keys(c).forEach(function(key) {\n        if (key === 'require' || key === 'advanced' || key === 'mediaSource') {\n          return;\n        }\n        var r = c[key] = (typeof c[key] === 'object') ?\n            c[key] : {ideal: c[key]};\n        if (r.min !== undefined ||\n            r.max !== undefined || r.exact !== undefined) {\n          require.push(key);\n        }\n        if (r.exact !== undefined) {\n          if (typeof r.exact === 'number') {\n            r. min = r.max = r.exact;\n          } else {\n            c[key] = r.exact;\n          }\n          delete r.exact;\n        }\n        if (r.ideal !== undefined) {\n          c.advanced = c.advanced || [];\n          var oc = {};\n          if (typeof r.ideal === 'number') {\n            oc[key] = {min: r.ideal, max: r.ideal};\n          } else {\n            oc[key] = r.ideal;\n          }\n          c.advanced.push(oc);\n          delete r.ideal;\n          if (!Object.keys(r).length) {\n            delete c[key];\n          }\n        }\n      });\n      if (require.length) {\n        c.require = require;\n      }\n      return c;\n    };\n    if (browserDetails.version < 38) {\n      logging('spec: ' + JSON.stringify(constraints));\n      if (constraints.audio) {\n        constraints.audio = constraintsToFF37_(constraints.audio);\n      }\n      if (constraints.video) {\n        constraints.video = constraintsToFF37_(constraints.video);\n      }\n      logging('ff37: ' + JSON.stringify(constraints));\n    }\n    return navigator.mozGetUserMedia(constraints, onSuccess, onError);\n  };\n\n  navigator.getUserMedia = getUserMedia_;\n\n  // Returns the result of getUserMedia as a Promise.\n  var getUserMediaPromise_ = function(constraints) {\n    return new Promise(function(resolve, reject) {\n      navigator.getUserMedia(constraints, resolve, reject);\n    });\n  }\n\n  // Shim for mediaDevices on older versions.\n  if (!navigator.mediaDevices) {\n    navigator.mediaDevices = {getUserMedia: getUserMediaPromise_,\n      addEventListener: function() { },\n      removeEventListener: function() { }\n    };\n  }\n  navigator.mediaDevices.enumerateDevices =\n      navigator.mediaDevices.enumerateDevices || function() {\n    return new Promise(function(resolve) {\n      var infos = [\n        {kind: 'audioinput', deviceId: 'default', label: '', groupId: ''},\n        {kind: 'videoinput', deviceId: 'default', label: '', groupId: ''}\n      ];\n      resolve(infos);\n    });\n  };\n\n  if (browserDetails.version < 41) {\n    // Work around http://bugzil.la/1169665\n    var orgEnumerateDevices =\n        navigator.mediaDevices.enumerateDevices.bind(navigator.mediaDevices);\n    navigator.mediaDevices.enumerateDevices = function() {\n      return orgEnumerateDevices().then(undefined, function(e) {\n        if (e.name === 'NotFoundError') {\n          return [];\n        }\n        throw e;\n      });\n    };\n  }\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/firefox/getusermedia.js\n ** module id = 153\n ** module chunks = 0\n **/"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/quagga.min.js b/dist/quagga.min.js index c75c2b6d..ff07195a 100644 --- a/dist/quagga.min.js +++ b/dist/quagga.min.js @@ -1,3 +1,3 @@ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(e.toString()):"object"==typeof exports?exports.Quagga=e(e.toString()):t.Quagga=e(e.toString())}(this,function(t){return function(t){function e(r){if(n[r])return n[r].exports;var o=n[r]={exports:{},id:r,loaded:!1};return t[r].call(o.exports,o,o.exports,e),o.loaded=!0,o.exports}var n={};return e.m=t,e.c=n,e.p="/",e(0)}([function(t,e,n){t.exports=n(1)},function(e,n,r){"use strict";function o(t){return t&&t.__esModule?t:{"default":t}}function a(t){l(t),S=k["default"].create(at.decoder,D)}function i(t){var e;if("VideoStream"===at.inputStream.type)e=document.createElement("video"),w=$["default"].createVideoStream(e);else if("ImageStream"===at.inputStream.type)w=$["default"].createImageStream();else if("LiveStream"===at.inputStream.type){var n=u();n&&(e=n.querySelector("video"),e||(e=document.createElement("video"),n.appendChild(e))),w=$["default"].createLiveStream(e),G["default"].request(e,at.inputStream.constraints,function(e){return e?t(e):void w.trigger("canrecord")})}w.setAttribute("preload","auto"),w.setAttribute("autoplay",!0),w.setInputStream(at.inputStream),w.addEventListener("canrecord",c.bind(void 0,t))}function u(){var t=at.inputStream.target;if(t&&t.nodeName&&1===t.nodeType)return t;var e="string"==typeof t?t:"#interactive.viewport";return document.querySelector(e)}function c(t){j["default"].checkImageConstraints(w,at.locator),s(at),C=tt["default"].create(w,nt.dom.image),A(at.numOfWorkers,function(){0===at.numOfWorkers&&a(),f(t)})}function f(t){w.play(),t()}function s(){if("undefined"!=typeof document){var t=u();if(nt.dom.image=document.querySelector("canvas.imgBuffer"),nt.dom.image||(nt.dom.image=document.createElement("canvas"),nt.dom.image.className="imgBuffer",t&&"ImageStream"===at.inputStream.type&&t.appendChild(nt.dom.image)),nt.ctx.image=nt.dom.image.getContext("2d"),nt.dom.image.width=w.getCanvasSize().x,nt.dom.image.height=w.getCanvasSize().y,nt.dom.overlay=document.querySelector("canvas.drawingBuffer"),!nt.dom.overlay){nt.dom.overlay=document.createElement("canvas"),nt.dom.overlay.className="drawingBuffer",t&&t.appendChild(nt.dom.overlay);var e=document.createElement("br");e.setAttribute("clear","all"),t&&t.appendChild(e)}nt.ctx.overlay=nt.dom.overlay.getContext("2d"),nt.dom.overlay.width=w.getCanvasSize().x,nt.dom.overlay.height=w.getCanvasSize().y}}function l(t){D=t?t:new N["default"]({x:w.getWidth(),y:w.getHeight()}),T=[V.vec2.clone([0,0]),V.vec2.clone([0,D.size.y]),V.vec2.clone([D.size.x,D.size.y]),V.vec2.clone([D.size.x,0])],j["default"].init(D,at.locator)}function d(){return at.locate?j["default"].locate():[[V.vec2.clone(T[0]),V.vec2.clone(T[1]),V.vec2.clone(T[2]),V.vec2.clone(T[3])]]}function h(t){function e(t){for(var e=t.length;e--;)t[e][0]+=a,t[e][1]+=i}function n(t){t[0].x+=a,t[0].y+=i,t[1].x+=a,t[1].y+=i}var r,o=w.getTopRight(),a=o.x,i=o.y;if(0!==a||0!==i){if(t.barcodes)for(r=0;r0)for(r=0;r0){if(t=rt.filter(function(t){return!t.busy})[0],!t)return;C.attachData(t.imageData)}else C.attachData(D.data);C.grab()&&(t?(t.busy=!0,t.worker.postMessage({cmd:"process",imageData:t.imageData},[t.imageData.buffer])):m())}else m()}function y(){var t=null,e=1e3/(at.frequency||60);O=!1,function n(r){t=t||r,O||(r>=t&&(t+=e,_()),window.requestAnimFrame(n))}(performance.now())}function x(){ot&&"LiveStream"===at.inputStream.type?y():_()}function M(t){var e,n={worker:void 0,imageData:new Uint8Array(w.getWidth()*w.getHeight()),busy:!0};e=R(),n.worker=new Worker(e),n.worker.onmessage=function(r){return"initialized"===r.data.event?(URL.revokeObjectURL(e),n.busy=!1,n.imageData=new Uint8Array(r.data.imageData),t(n)):void("processed"===r.data.event?(n.imageData=new Uint8Array(r.data.imageData),n.busy=!1,g(r.data.result,n.imageData)):"error"===r.data.event)},n.worker.postMessage({cmd:"init",size:{x:w.getWidth(),y:w.getHeight()},imageData:n.imageData,config:at},[n.imageData.buffer])}function b(t){function e(t){self.postMessage({event:"processed",imageData:o.data,result:t},[o.data.buffer])}function n(){self.postMessage({event:"initialized",imageData:o.data},[o.data.buffer])}if(t){var r=t();if(!r)return void self.postMessage({event:"error",message:"Quagga could not be created"})}var o;self.onmessage=function(t){if("init"===t.data.cmd){var a=t.data.config;a.numOfWorkers=0,o=new r.ImageWrapper({x:t.data.size.x,y:t.data.size.y},new Uint8Array(t.data.imageData)),r.init(a,n,o),r.onProcessed(e)}else"process"===t.data.cmd?(o.data=new Uint8Array(t.data.imageData),r.start()):"setReaders"===t.data.cmd&&r.setReaders(t.data.readers)}}function R(){var e,n;return"undefined"!=typeof t&&(n=t),e=new Blob(["("+b.toString()+")("+n+");"],{type:"text/javascript"}),window.URL.createObjectURL(e)}function E(t){S?S.setReaders(t):ot&&rt.length>0&&rt.forEach(function(e){e.worker.postMessage({cmd:"setReaders",readers:t})})}function A(t,e){var n=t-rt.length;if(0===n)return e&&e();if(0>n){var r=rt.slice(n);return r.forEach(function(t){t.worker.terminate()}),rt=rt.slice(0,n),e&&e()}for(var o=function(n){rt.push(n),rt.length>=t&&e&&e()},a=0;n>a;a++)M(o)}Object.defineProperty(n,"__esModule",{value:!0});var w,C,O,D,T,S,P,I=r(2),z=(o(I),r(3)),N=o(z),L=r(18),j=o(L),U=r(23),k=o(U),q=r(68),W=o(q),F=r(69),G=o(F),Y=r(19),B=o(Y),V=r(7),H=r(70),X=o(H),Q=r(71),K=o(Q),Z=r(73),$=o(Z),J=r(75),tt=o(J),et=r(35),nt={ctx:{image:null,overlay:null},dom:{image:null,overlay:null}},rt=[],ot=!0,at={};n["default"]={init:function(t,e,n){return at=et({},K["default"],t),n?(ot=!1,a(n),e()):void i(e)},start:function(){x()},stop:function(){O=!0,A(0),"LiveStream"===at.inputStream.type&&(G["default"].release(),w.clearEventHandlers())},pause:function(){O=!0},onDetected:function(t){W["default"].subscribe("detected",t)},offDetected:function(t){W["default"].unsubscribe("detected",t)},onProcessed:function(t){W["default"].subscribe("processed",t)},offProcessed:function(t){W["default"].unsubscribe("processed",t)},setReaders:function(t){E(t)},registerResultCollector:function(t){t&&"function"==typeof t.addResult&&(P=t)},canvas:nt,decodeSingle:function(t,e){t=et({inputStream:{type:"ImageStream",sequence:!1,size:800,src:t.src},numOfWorkers:1,locator:{halfSample:!1}},t),this.init(t,function(){W["default"].once("processed",function(t){O=!0,e.call(null,t)},!0),x()})},ImageWrapper:N["default"],ImageDebug:B["default"],ResultCollector:X["default"]},e.exports=n["default"]},function(t,e){"use strict";"undefined"!=typeof window&&(window.requestAnimFrame=function(){return window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(t){window.setTimeout(t,1e3/60)}}(),navigator.getUserMedia=navigator.getUserMedia||navigator.webkitGetUserMedia||navigator.mozGetUserMedia||navigator.msGetUserMedia,window.URL=window.URL||window.webkitURL||window.mozURL||window.msURL),Math.imul=Math.imul||function(t,e){var n=t>>>16&65535,r=65535&t,o=e>>>16&65535,a=65535&e;return r*a+(n*a+r*o<<16>>>0)|0}},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(t,e,n,r){e?this.data=e:n?(this.data=new n(t.x*t.y),n===Array&&r&&s["default"].init(this.data,0)):(this.data=new Uint8Array(t.x*t.y),Uint8Array===Array&&r&&s["default"].init(this.data,0)),this.size=t}Object.defineProperty(e,"__esModule",{value:!0});var a=n(4),i=r(a),u=n(5),c=r(u),f=n(17),s=r(f),l=n(7);o.prototype.inImageWithBorder=function(t,e){return t.x>=e&&t.y>=e&&t.xn;n++)for(r=0;o>r;r++)t.data[r*a+n]=this.data[(e.y+r)*this.size.x+e.x+n]},o.prototype.copyTo=function(t){for(var e=this.data.length,n=this.data,r=t.data;e--;)r[e]=n[e]},o.prototype.get=function(t,e){return this.data[e*this.size.x+t]},o.prototype.getSafe=function(t,e){var n;if(!this.indexMapping){for(this.indexMapping={x:[],y:[]},n=0;nt;t++)r[t]=r[(n-1)*e+t]=0;for(t=1;n-1>t;t++)r[t*e]=r[t*e+(e-1)]=0},o.prototype.invert=function(){for(var t=this.data,e=t.length;e--;)t[e]=t[e]?0:1},o.prototype.convolve=function(t){var e,n,r,o,a=t.length/2|0,i=0;for(n=0;n=o;o++)for(r=-a;a>=r;r++)i+=t[o+a][r+a]*this.getSafe(e+r,n+o);this.data[n*this.size.x+e]=i}},o.prototype.moments=function(t){var e,n,r,o,a,i,u,c,f,s,d,h,p=this.data,v=this.size.y,g=this.size.x,m=[],_=[],y=Math.PI,x=y/4;if(0>=t)return _;for(a=0;t>a;a++)m[a]={m00:0,m01:0,m10:0,m11:0,m02:0,m20:0,theta:0,rad:0};for(n=0;v>n;n++)for(o=n*n,e=0;g>e;e++)r=p[n*g+e],r>0&&(i=m[r-1],i.m00+=1,i.m01+=n,i.m10+=e,i.m11+=e*n,i.m02+=o,i.m20+=e*e);for(a=0;t>a;a++)i=m[a],isNaN(i.m00)||0===i.m00||(s=i.m10/i.m00,d=i.m01/i.m00,u=i.m11/i.m00-s*d,c=i.m02/i.m00-d*d,f=i.m20/i.m00-s*s,h=(c-f)/(2*u),h=.5*Math.atan(h)+(u>=0?x:-x)+y,i.theta=(180*h/y+90)%180-90,i.theta<0&&(i.theta+=180),i.rad=h>y?h-y:h,i.vec=l.vec2.clone([Math.cos(h),Math.sin(h)]),_.push(i));return _},o.prototype.show=function(t,e){var n,r,o,a,i,u,c;for(e||(e=1),n=t.getContext("2d"),t.width=this.size.x,t.height=this.size.y,r=n.getImageData(0,0,t.width,t.height),o=r.data,a=0,c=0;ce||e>360)&&(e=360);for(var r=[0,1,1],o=[0,0,0],a=[255,255,255],i=[0,0,0],u=[],f=t.getContext("2d"),s=f.getImageData(n.x,n.y,this.size.x,this.size.y),l=s.data,d=this.data.length;d--;)r[0]=this.data[d]*e,u=r[0]<=0?a:r[0]>=360?i:c["default"].hsv2rgb(r,o),l[4*d+0]=u[0],l[4*d+1]=u[1],l[4*d+2]=u[2],l[4*d+3]=255;f.putImageData(s,n.x,n.y)},e["default"]=o,t.exports=e["default"]},function(t,e){"use strict";function n(t,e,n){n||(n={data:null,size:e}),this.data=n.data,this.originalSize=n.size,this.I=n,this.from=t,this.size=e}Object.defineProperty(e,"__esModule",{value:!0}),n.prototype.show=function(t,e){var n,r,o,a,i,u,c;for(e||(e=1),n=t.getContext("2d"),t.width=this.size.x,t.height=this.size.y,r=n.getImageData(0,0,t.width,t.height),o=r.data,a=0,i=0;i0?Math.floor(this.x+.5):Math.floor(this.x-.5),this.y=this.y>0?Math.floor(this.y+.5):Math.floor(this.y-.5),this}};return n},f.computeIntegralImage2=function(t,e){var n,r,o=t.data,a=t.size.x,i=t.size.y,u=e.data,c=0,f=0,s=0,l=0,d=0;for(s=a,c=0,r=1;i>r;r++)c+=o[f],u[s]+=c,f+=a,s+=a;for(f=0,s=1,c=0,n=1;a>n;n++)c+=o[f],u[s]+=c,f++,s++;for(r=1;i>r;r++)for(f=r*a+1,s=(r-1)*a+1,l=r*a,d=(r-1)*a,n=1;a>n;n++)u[f]+=o[f]+u[s]+u[l]-u[d],f++,s++,l++,d++},f.computeIntegralImage=function(t,e){for(var n=t.data,r=t.size.x,o=t.size.y,a=e.data,i=0,u=0;r>u;u++)i+=n[u],a[u]=i;for(var c=1;o>c;c++){i=0;for(var f=0;r>f;f++)i+=n[c*r+f],a[c*r+f]=i+a[(c-1)*r+f]}},f.thresholdImage=function(t,e,n){n||(n=t);for(var r=t.data,o=r.length,a=n.data;o--;)a[o]=r[o]>o]++;return i},f.sharpenLine=function(t){var e,n,r=t.length,o=t[0],a=t[1];for(e=1;r-1>e;e++)n=t[e+1],t[e-1]=2*a-o-n&255,o=a,a=n;return t},f.determineOtsuThreshold=function(t,e){function n(t,e){var n,r=0;for(n=t;e>=n;n++)r+=a[n];return r}function r(t,e){var n,r=0;for(n=t;e>=n;n++)r+=n*a[n];return r}function o(){var o,i,c,s,l,d,h,p=[0],v=(1<s;s++)o=n(0,s),i=n(s+1,v),c=o*i,0===c&&(c=1),l=r(0,s)*i,d=r(s+1,v)*o,h=l-d,p[s]=h*h/c;return u["default"].maxIndex(p)}e||(e=8);var a,i,c=8-e;return i=o(),i<=r;r++)for(o=0;h>o;o++)d[r*h+o]=0,d[(p-1-r)*h+o]=0;for(r=m;p-m>r;r++)for(o=0;m>=o;o++)d[r*h+o]=0,d[r*h+(h-1-o)]=0;for(r=m+1;p-m-1>r;r++)for(o=m+1;h-m>o;o++)a=v[(r-m-1)*h+(o-m-1)],i=v[(r-m-1)*h+(o+m)],u=v[(r+m)*h+(o-m-1)],c=v[(r+m)*h+(o+m)],g=c-u-i+a,s=g/_,d[r*h+o]=l[r*h+o]>s+5?0:1},f.cluster=function(t,e,n){function r(t){var e=!1;for(i=0;ie.x-f&&t.xe.y-s&&t.yn;n++){for(i=Math.floor(Math.random()*t.length),o=[],u=i,o.push(t[u]);null!==(u=s(u,!0));)o.push(t[u]);if(i>0)for(u=i;null!==(u=s(u,!1));)o.push(t[u]);o.length>a.length&&(a=o)}return a}},f.DILATE=1,f.ERODE=2,f.dilate=function(t,e){var n,r,o,a,i,u,c,f=t.data,s=e.data,l=t.size.y,d=t.size.x;for(n=1;l-1>n;n++)for(r=1;d-1>r;r++)a=n-1,i=n+1,u=r-1,c=r+1,o=f[a*d+u]+f[a*d+c]+f[n*d+r]+f[i*d+u]+f[i*d+c],s[n*d+r]=o>0?1:0},f.erode=function(t,e){var n,r,o,a,i,u,c,f=t.data,s=e.data,l=t.size.y,d=t.size.x;for(n=1;l-1>n;n++)for(r=1;d-1>r;r++)a=n-1,i=n+1,u=r-1,c=r+1,o=f[a*d+u]+f[a*d+c]+f[n*d+r]+f[i*d+u]+f[i*d+c],s[n*d+r]=5===o?1:0},f.subtract=function(t,e,n){n||(n=t);for(var r=t.data.length,o=t.data,a=e.data,i=n.data;r--;)i[r]=o[r]-a[r]},f.bitwiseOr=function(t,e,n){n||(n=t);for(var r=t.data.length,o=t.data,a=e.data,i=n.data;r--;)i[r]=o[r]||a[r]},f.countNonZero=function(t){for(var e=t.data.length,n=t.data,r=0;e--;)r+=n[e];return r},f.topGeneric=function(t,e,n){var r,o,a,i,u=0,c=0,f=[];for(r=0;e>r;r++)f[r]={score:0,item:null};for(r=0;rc)for(a=f[u],a.score=o,a.item=t[r],c=Number.MAX_VALUE,i=0;e>i;i++)f[i].scorea;){for(r=0;u>r;r++)n[c]=Math.floor((.299*t[4*o+0]+.587*t[4*o+1]+.114*t[4*o+2]+(.299*t[4*(o+1)+0]+.587*t[4*(o+1)+1]+.114*t[4*(o+1)+2])+(.299*t[4*a+0]+.587*t[4*a+1]+.114*t[4*a+2])+(.299*t[4*(a+1)+0]+.587*t[4*(a+1)+1]+.114*t[4*(a+1)+2]))/4),c++,o+=2,a+=2;o+=f,a+=f}},f.computeGray=function(t,e,n){var r,o=t.length/4|0,a=n&&n.singleChannel===!0;if(a)for(r=0;o>r;r++)e[r]=t[4*r+0];else for(r=0;o>r;r++)e[r]=Math.floor(.299*t[4*r+0]+.587*t[4*r+1]+.114*t[4*r+2])},f.loadImageArray=function(t,e,n){n||(n=document.createElement("canvas"));var r=new Image;r.callback=e,r.onload=function(){n.width=this.width,n.height=this.height;var t=n.getContext("2d");t.drawImage(this,0,0);var e=new Uint8Array(this.width*this.height);t.drawImage(this,0,0);var r=t.getImageData(0,0,this.width,this.height).data;f.computeGray(r,e),this.callback(e,{x:this.width,y:this.height},this)},r.src=t},f.halfSample=function(t,e){for(var n=t.data,r=t.size.x,o=e.data,a=0,i=r,u=n.length,c=r/2,f=0;u>i;){for(var s=0;c>s;s++)o[f]=Math.floor((n[a]+n[a+1]+n[i]+n[i+1])/4),f++,a+=2,i+=2;a+=r,i+=r}},f.hsv2rgb=function(t,e){var n=t[0],r=t[1],o=t[2],a=o*r,i=a*(1-Math.abs(n/60%2-1)),u=o-a,c=0,f=0,s=0;return e=e||[0,0,0],60>n?(c=a,f=i):120>n?(c=i,f=a):180>n?(f=a,s=i):240>n?(f=i,s=a):300>n?(c=i,s=a):360>n&&(c=a,s=i),e[0]=255*(c+u)|0,e[1]=255*(f+u)|0,e[2]=255*(s+u)|0,e},f._computeDivisors=function(t){var e,n=[],r=[];for(e=1;ee[r]?r++:n++;return o},f.calculatePatchSize=function(t,e){function n(t){for(var e=0,n=t[Math.floor(t.length/2)];e0&&(n=Math.abs(t[e]-d)>Math.abs(t[e-1]-d)?t[e-1]:t[e]),d/nc[s-1]/c[s]?{x:n,y:n}:null}var r,o=this._computeDivisors(e.x),a=this._computeDivisors(e.y),i=Math.max(e.x,e.y),u=this._computeIntersection(o,a),c=[8,10,15,20,32,60,80],f={"x-small":5,small:4,medium:3,large:2,"x-large":1},s=f[t]||f.medium,l=c[s],d=Math.floor(i/l);return r=n(u),r||(r=n(this._computeDivisors(i)),r||(r=n(this._computeDivisors(d*l)))),r},f._parseCSSDimensionValues=function(t){var e={value:parseFloat(t),unit:(t.indexOf("%")===t.length-1,"%")};return e},f._dimensionsConverters={top:function(t,e){return"%"===t.unit?Math.floor(e.height*(t.value/100)):void 0},right:function(t,e){return"%"===t.unit?Math.floor(e.width-e.width*(t.value/100)):void 0},bottom:function(t,e){return"%"===t.unit?Math.floor(e.height-e.height*(t.value/100)):void 0},left:function(t,e){return"%"===t.unit?Math.floor(e.width*(t.value/100)):void 0}},f.computeImageArea=function(t,e,n){var r={width:t,height:e},o=Object.keys(n).reduce(function(t,e){var o=n[e],a=f._parseCSSDimensionValues(o),i=f._dimensionsConverters[e](a,r);return t[e]=i,t},{});return{sx:o.left,sy:o.top,sw:o.right-o.left,sh:o.bottom-o.top}},e["default"]=f,t.exports=e["default"]},function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var r=n(7);e["default"]={create:function(t,e){function n(){o(t),a()}function o(t){c[t.id]=t,i.push(t)}function a(){var t,e=0;for(t=0;te?!0:!1},getPoints:function(){return i},getCenter:function(){return u}}},createPoint:function(t,e,n){return{rad:t[n],point:t,id:e}}},t.exports=e["default"]},function(t,e,n){e.glMatrix=n(8),e.mat2=n(9),e.mat2d=n(10),e.mat3=n(11),e.mat4=n(12),e.quat=n(13),e.vec2=n(16),e.vec3=n(14),e.vec4=n(15)},function(t,e){var n={};n.EPSILON=1e-6,n.ARRAY_TYPE="undefined"!=typeof Float32Array?Float32Array:Array,n.RANDOM=Math.random,n.setMatrixArrayType=function(t){GLMAT_ARRAY_TYPE=t};var r=Math.PI/180;n.toRadian=function(t){return t*r},t.exports=n},function(t,e,n){var r=n(8),o={};o.create=function(){var t=new r.ARRAY_TYPE(4);return t[0]=1,t[1]=0,t[2]=0,t[3]=1,t},o.clone=function(t){var e=new r.ARRAY_TYPE(4);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t},o.identity=function(t){return t[0]=1,t[1]=0,t[2]=0,t[3]=1,t},o.transpose=function(t,e){if(t===e){var n=e[1];t[1]=e[2],t[2]=n}else t[0]=e[0],t[1]=e[2],t[2]=e[1],t[3]=e[3];return t},o.invert=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=n*a-o*r;return i?(i=1/i,t[0]=a*i,t[1]=-r*i,t[2]=-o*i,t[3]=n*i,t):null},o.adjoint=function(t,e){var n=e[0];return t[0]=e[3],t[1]=-e[1],t[2]=-e[2],t[3]=n,t},o.determinant=function(t){return t[0]*t[3]-t[2]*t[1]},o.multiply=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=n[0],c=n[1],f=n[2],s=n[3];return t[0]=r*u+a*c,t[1]=o*u+i*c,t[2]=r*f+a*s,t[3]=o*f+i*s,t},o.mul=o.multiply,o.rotate=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=Math.sin(n),c=Math.cos(n);return t[0]=r*c+a*u,t[1]=o*c+i*u,t[2]=r*-u+a*c,t[3]=o*-u+i*c,t},o.scale=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=n[0],c=n[1];return t[0]=r*u,t[1]=o*u,t[2]=a*c,t[3]=i*c,t},o.fromRotation=function(t,e){var n=Math.sin(e),r=Math.cos(e);return t[0]=r,t[1]=n,t[2]=-n,t[3]=r,t},o.fromScaling=function(t,e){return t[0]=e[0],t[1]=0,t[2]=0,t[3]=e[1],t},o.str=function(t){return"mat2("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"},o.frob=function(t){return Math.sqrt(Math.pow(t[0],2)+Math.pow(t[1],2)+Math.pow(t[2],2)+Math.pow(t[3],2))},o.LDU=function(t,e,n,r){return t[2]=r[2]/r[0],n[0]=r[0],n[1]=r[1],n[3]=r[3]-t[2]*n[1],[t,e,n]},t.exports=o},function(t,e,n){var r=n(8),o={};o.create=function(){var t=new r.ARRAY_TYPE(6);return t[0]=1,t[1]=0,t[2]=0,t[3]=1,t[4]=0,t[5]=0,t},o.clone=function(t){var e=new r.ARRAY_TYPE(6);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t},o.identity=function(t){return t[0]=1,t[1]=0,t[2]=0,t[3]=1,t[4]=0,t[5]=0,t},o.invert=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=e[4],u=e[5],c=n*a-r*o;return c?(c=1/c,t[0]=a*c,t[1]=-r*c,t[2]=-o*c,t[3]=n*c,t[4]=(o*u-a*i)*c,t[5]=(r*i-n*u)*c,t):null},o.determinant=function(t){return t[0]*t[3]-t[1]*t[2]},o.multiply=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=n[0],s=n[1],l=n[2],d=n[3],h=n[4],p=n[5];return t[0]=r*f+a*s,t[1]=o*f+i*s,t[2]=r*l+a*d,t[3]=o*l+i*d,t[4]=r*h+a*p+u,t[5]=o*h+i*p+c,t},o.mul=o.multiply,o.rotate=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=Math.sin(n),s=Math.cos(n);return t[0]=r*s+a*f,t[1]=o*s+i*f,t[2]=r*-f+a*s,t[3]=o*-f+i*s,t[4]=u,t[5]=c,t},o.scale=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=n[0],s=n[1];return t[0]=r*f,t[1]=o*f,t[2]=a*s,t[3]=i*s,t[4]=u,t[5]=c,t},o.translate=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=n[0],s=n[1];return t[0]=r,t[1]=o,t[2]=a,t[3]=i,t[4]=r*f+a*s+u,t[5]=o*f+i*s+c,t},o.fromRotation=function(t,e){var n=Math.sin(e),r=Math.cos(e);return t[0]=r,t[1]=n,t[2]=-n,t[3]=r,t[4]=0,t[5]=0,t},o.fromScaling=function(t,e){return t[0]=e[0],t[1]=0,t[2]=0,t[3]=e[1],t[4]=0,t[5]=0,t},o.fromTranslation=function(t,e){return t[0]=1,t[1]=0,t[2]=0,t[3]=1,t[4]=e[0],t[5]=e[1],t},o.str=function(t){return"mat2d("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+", "+t[4]+", "+t[5]+")"},o.frob=function(t){return Math.sqrt(Math.pow(t[0],2)+Math.pow(t[1],2)+Math.pow(t[2],2)+Math.pow(t[3],2)+Math.pow(t[4],2)+Math.pow(t[5],2)+1)},t.exports=o},function(t,e,n){var r=n(8),o={};o.create=function(){var t=new r.ARRAY_TYPE(9);return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=1,t[5]=0,t[6]=0,t[7]=0,t[8]=1,t},o.fromMat4=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[4],t[4]=e[5],t[5]=e[6],t[6]=e[8],t[7]=e[9],t[8]=e[10],t},o.clone=function(t){var e=new r.ARRAY_TYPE(9);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t},o.identity=function(t){return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=1,t[5]=0,t[6]=0,t[7]=0,t[8]=1,t},o.transpose=function(t,e){if(t===e){var n=e[1],r=e[2],o=e[5];t[1]=e[3],t[2]=e[6],t[3]=n,t[5]=e[7],t[6]=r,t[7]=o}else t[0]=e[0],t[1]=e[3],t[2]=e[6],t[3]=e[1],t[4]=e[4],t[5]=e[7],t[6]=e[2],t[7]=e[5],t[8]=e[8];return t},o.invert=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=e[4],u=e[5],c=e[6],f=e[7],s=e[8],l=s*i-u*f,d=-s*a+u*c,h=f*a-i*c,p=n*l+r*d+o*h;return p?(p=1/p,t[0]=l*p,t[1]=(-s*r+o*f)*p,t[2]=(u*r-o*i)*p,t[3]=d*p,t[4]=(s*n-o*c)*p,t[5]=(-u*n+o*a)*p,t[6]=h*p,t[7]=(-f*n+r*c)*p,t[8]=(i*n-r*a)*p,t):null},o.adjoint=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=e[4],u=e[5],c=e[6],f=e[7],s=e[8];return t[0]=i*s-u*f,t[1]=o*f-r*s,t[2]=r*u-o*i,t[3]=u*c-a*s,t[4]=n*s-o*c,t[5]=o*a-n*u,t[6]=a*f-i*c,t[7]=r*c-n*f,t[8]=n*i-r*a,t},o.determinant=function(t){var e=t[0],n=t[1],r=t[2],o=t[3],a=t[4],i=t[5],u=t[6],c=t[7],f=t[8];return e*(f*a-i*c)+n*(-f*o+i*u)+r*(c*o-a*u)},o.multiply=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=e[6],s=e[7],l=e[8],d=n[0],h=n[1],p=n[2],v=n[3],g=n[4],m=n[5],_=n[6],y=n[7],x=n[8];return t[0]=d*r+h*i+p*f,t[1]=d*o+h*u+p*s,t[2]=d*a+h*c+p*l,t[3]=v*r+g*i+m*f,t[4]=v*o+g*u+m*s,t[5]=v*a+g*c+m*l,t[6]=_*r+y*i+x*f,t[7]=_*o+y*u+x*s,t[8]=_*a+y*c+x*l,t},o.mul=o.multiply,o.translate=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=e[6],s=e[7],l=e[8],d=n[0],h=n[1];return t[0]=r,t[1]=o,t[2]=a,t[3]=i,t[4]=u,t[5]=c,t[6]=d*r+h*i+f,t[7]=d*o+h*u+s,t[8]=d*a+h*c+l,t},o.rotate=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=e[6],s=e[7],l=e[8],d=Math.sin(n),h=Math.cos(n);return t[0]=h*r+d*i,t[1]=h*o+d*u,t[2]=h*a+d*c,t[3]=h*i-d*r,t[4]=h*u-d*o,t[5]=h*c-d*a,t[6]=f,t[7]=s,t[8]=l,t},o.scale=function(t,e,n){var r=n[0],o=n[1];return t[0]=r*e[0],t[1]=r*e[1],t[2]=r*e[2],t[3]=o*e[3],t[4]=o*e[4],t[5]=o*e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t},o.fromTranslation=function(t,e){return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=1,t[5]=0,t[6]=e[0],t[7]=e[1],t[8]=1,t},o.fromRotation=function(t,e){var n=Math.sin(e),r=Math.cos(e);return t[0]=r,t[1]=n,t[2]=0,t[3]=-n,t[4]=r,t[5]=0,t[6]=0,t[7]=0,t[8]=1,t},o.fromScaling=function(t,e){return t[0]=e[0],t[1]=0,t[2]=0,t[3]=0,t[4]=e[1],t[5]=0,t[6]=0,t[7]=0,t[8]=1,t},o.fromMat2d=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=0,t[3]=e[2],t[4]=e[3],t[5]=0,t[6]=e[4],t[7]=e[5],t[8]=1,t},o.fromQuat=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=n+n,u=r+r,c=o+o,f=n*i,s=r*i,l=r*u,d=o*i,h=o*u,p=o*c,v=a*i,g=a*u,m=a*c;return t[0]=1-l-p,t[3]=s-m,t[6]=d+g,t[1]=s+m,t[4]=1-f-p,t[7]=h-v,t[2]=d-g,t[5]=h+v,t[8]=1-f-l,t},o.normalFromMat4=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=e[4],u=e[5],c=e[6],f=e[7],s=e[8],l=e[9],d=e[10],h=e[11],p=e[12],v=e[13],g=e[14],m=e[15],_=n*u-r*i,y=n*c-o*i,x=n*f-a*i,M=r*c-o*u,b=r*f-a*u,R=o*f-a*c,E=s*v-l*p,A=s*g-d*p,w=s*m-h*p,C=l*g-d*v,O=l*m-h*v,D=d*m-h*g,T=_*D-y*O+x*C+M*w-b*A+R*E;return T?(T=1/T,t[0]=(u*D-c*O+f*C)*T,t[1]=(c*w-i*D-f*A)*T,t[2]=(i*O-u*w+f*E)*T,t[3]=(o*O-r*D-a*C)*T,t[4]=(n*D-o*w+a*A)*T,t[5]=(r*w-n*O-a*E)*T,t[6]=(v*R-g*b+m*M)*T,t[7]=(g*x-p*R-m*y)*T,t[8]=(p*b-v*x+m*_)*T,t):null},o.str=function(t){return"mat3("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+", "+t[4]+", "+t[5]+", "+t[6]+", "+t[7]+", "+t[8]+")"},o.frob=function(t){return Math.sqrt(Math.pow(t[0],2)+Math.pow(t[1],2)+Math.pow(t[2],2)+Math.pow(t[3],2)+Math.pow(t[4],2)+Math.pow(t[5],2)+Math.pow(t[6],2)+Math.pow(t[7],2)+Math.pow(t[8],2))},t.exports=o},function(t,e,n){var r=n(8),o={};o.create=function(){var t=new r.ARRAY_TYPE(16);return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t},o.clone=function(t){var e=new r.ARRAY_TYPE(16);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t},o.identity=function(t){return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t},o.transpose=function(t,e){if(t===e){var n=e[1],r=e[2],o=e[3],a=e[6],i=e[7],u=e[11];t[1]=e[4],t[2]=e[8],t[3]=e[12],t[4]=n,t[6]=e[9],t[7]=e[13],t[8]=r,t[9]=a,t[11]=e[14],t[12]=o,t[13]=i,t[14]=u}else t[0]=e[0],t[1]=e[4],t[2]=e[8],t[3]=e[12],t[4]=e[1],t[5]=e[5],t[6]=e[9],t[7]=e[13],t[8]=e[2],t[9]=e[6],t[10]=e[10],t[11]=e[14],t[12]=e[3],t[13]=e[7],t[14]=e[11],t[15]=e[15];return t},o.invert=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=e[4],u=e[5],c=e[6],f=e[7],s=e[8],l=e[9],d=e[10],h=e[11],p=e[12],v=e[13],g=e[14],m=e[15],_=n*u-r*i,y=n*c-o*i,x=n*f-a*i,M=r*c-o*u,b=r*f-a*u,R=o*f-a*c,E=s*v-l*p,A=s*g-d*p,w=s*m-h*p,C=l*g-d*v,O=l*m-h*v,D=d*m-h*g,T=_*D-y*O+x*C+M*w-b*A+R*E;return T?(T=1/T,t[0]=(u*D-c*O+f*C)*T,t[1]=(o*O-r*D-a*C)*T,t[2]=(v*R-g*b+m*M)*T,t[3]=(d*b-l*R-h*M)*T,t[4]=(c*w-i*D-f*A)*T,t[5]=(n*D-o*w+a*A)*T,t[6]=(g*x-p*R-m*y)*T,t[7]=(s*R-d*x+h*y)*T,t[8]=(i*O-u*w+f*E)*T,t[9]=(r*w-n*O-a*E)*T,t[10]=(p*b-v*x+m*_)*T,t[11]=(l*x-s*b-h*_)*T,t[12]=(u*A-i*C-c*E)*T,t[13]=(n*C-r*A+o*E)*T,t[14]=(v*y-p*M-g*_)*T,t[15]=(s*M-l*y+d*_)*T,t):null},o.adjoint=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=e[4],u=e[5],c=e[6],f=e[7],s=e[8],l=e[9],d=e[10],h=e[11],p=e[12],v=e[13],g=e[14],m=e[15];return t[0]=u*(d*m-h*g)-l*(c*m-f*g)+v*(c*h-f*d),t[1]=-(r*(d*m-h*g)-l*(o*m-a*g)+v*(o*h-a*d)),t[2]=r*(c*m-f*g)-u*(o*m-a*g)+v*(o*f-a*c),t[3]=-(r*(c*h-f*d)-u*(o*h-a*d)+l*(o*f-a*c)),t[4]=-(i*(d*m-h*g)-s*(c*m-f*g)+p*(c*h-f*d)),t[5]=n*(d*m-h*g)-s*(o*m-a*g)+p*(o*h-a*d),t[6]=-(n*(c*m-f*g)-i*(o*m-a*g)+p*(o*f-a*c)),t[7]=n*(c*h-f*d)-i*(o*h-a*d)+s*(o*f-a*c),t[8]=i*(l*m-h*v)-s*(u*m-f*v)+p*(u*h-f*l),t[9]=-(n*(l*m-h*v)-s*(r*m-a*v)+p*(r*h-a*l)),t[10]=n*(u*m-f*v)-i*(r*m-a*v)+p*(r*f-a*u),t[11]=-(n*(u*h-f*l)-i*(r*h-a*l)+s*(r*f-a*u)),t[12]=-(i*(l*g-d*v)-s*(u*g-c*v)+p*(u*d-c*l)),t[13]=n*(l*g-d*v)-s*(r*g-o*v)+p*(r*d-o*l),t[14]=-(n*(u*g-c*v)-i*(r*g-o*v)+p*(r*c-o*u)),t[15]=n*(u*d-c*l)-i*(r*d-o*l)+s*(r*c-o*u),t},o.determinant=function(t){var e=t[0],n=t[1],r=t[2],o=t[3],a=t[4],i=t[5],u=t[6],c=t[7],f=t[8],s=t[9],l=t[10],d=t[11],h=t[12],p=t[13],v=t[14],g=t[15],m=e*i-n*a,_=e*u-r*a,y=e*c-o*a,x=n*u-r*i,M=n*c-o*i,b=r*c-o*u,R=f*p-s*h,E=f*v-l*h,A=f*g-d*h,w=s*v-l*p,C=s*g-d*p,O=l*g-d*v;return m*O-_*C+y*w+x*A-M*E+b*R},o.multiply=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=e[6],s=e[7],l=e[8],d=e[9],h=e[10],p=e[11],v=e[12],g=e[13],m=e[14],_=e[15],y=n[0],x=n[1],M=n[2],b=n[3];return t[0]=y*r+x*u+M*l+b*v,t[1]=y*o+x*c+M*d+b*g,t[2]=y*a+x*f+M*h+b*m,t[3]=y*i+x*s+M*p+b*_,y=n[4],x=n[5],M=n[6],b=n[7],t[4]=y*r+x*u+M*l+b*v,t[5]=y*o+x*c+M*d+b*g,t[6]=y*a+x*f+M*h+b*m,t[7]=y*i+x*s+M*p+b*_,y=n[8],x=n[9],M=n[10],b=n[11],t[8]=y*r+x*u+M*l+b*v,t[9]=y*o+x*c+M*d+b*g,t[10]=y*a+x*f+M*h+b*m,t[11]=y*i+x*s+M*p+b*_,y=n[12],x=n[13],M=n[14],b=n[15],t[12]=y*r+x*u+M*l+b*v,t[13]=y*o+x*c+M*d+b*g,t[14]=y*a+x*f+M*h+b*m,t[15]=y*i+x*s+M*p+b*_,t},o.mul=o.multiply,o.translate=function(t,e,n){var r,o,a,i,u,c,f,s,l,d,h,p,v=n[0],g=n[1],m=n[2];return e===t?(t[12]=e[0]*v+e[4]*g+e[8]*m+e[12],t[13]=e[1]*v+e[5]*g+e[9]*m+e[13],t[14]=e[2]*v+e[6]*g+e[10]*m+e[14],t[15]=e[3]*v+e[7]*g+e[11]*m+e[15]):(r=e[0],o=e[1],a=e[2],i=e[3],u=e[4],c=e[5],f=e[6],s=e[7],l=e[8],d=e[9],h=e[10],p=e[11],t[0]=r,t[1]=o,t[2]=a,t[3]=i,t[4]=u,t[5]=c,t[6]=f,t[7]=s,t[8]=l,t[9]=d,t[10]=h,t[11]=p,t[12]=r*v+u*g+l*m+e[12],t[13]=o*v+c*g+d*m+e[13],t[14]=a*v+f*g+h*m+e[14],t[15]=i*v+s*g+p*m+e[15]), -t},o.scale=function(t,e,n){var r=n[0],o=n[1],a=n[2];return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t[3]=e[3]*r,t[4]=e[4]*o,t[5]=e[5]*o,t[6]=e[6]*o,t[7]=e[7]*o,t[8]=e[8]*a,t[9]=e[9]*a,t[10]=e[10]*a,t[11]=e[11]*a,t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t},o.rotate=function(t,e,n,o){var a,i,u,c,f,s,l,d,h,p,v,g,m,_,y,x,M,b,R,E,A,w,C,O,D=o[0],T=o[1],S=o[2],P=Math.sqrt(D*D+T*T+S*S);return Math.abs(P)c?(a.cross(t,e,o),a.length(t)<1e-6&&a.cross(t,n,o),a.normalize(t,t),u.setAxisAngle(r,t,Math.PI),r):c>.999999?(r[0]=0,r[1]=0,r[2]=0,r[3]=1,r):(a.cross(t,o,i),r[0]=t[0],r[1]=t[1],r[2]=t[2],r[3]=1+c,u.normalize(r,r))}}(),u.setAxes=function(){var t=o.create();return function(e,n,r,o){return t[0]=r[0],t[3]=r[1],t[6]=r[2],t[1]=o[0],t[4]=o[1],t[7]=o[2],t[2]=-n[0],t[5]=-n[1],t[8]=-n[2],u.normalize(e,u.fromMat3(e,t))}}(),u.clone=i.clone,u.fromValues=i.fromValues,u.copy=i.copy,u.set=i.set,u.identity=function(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=1,t},u.setAxisAngle=function(t,e,n){n=.5*n;var r=Math.sin(n);return t[0]=r*e[0],t[1]=r*e[1],t[2]=r*e[2],t[3]=Math.cos(n),t},u.add=i.add,u.multiply=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3],u=n[0],c=n[1],f=n[2],s=n[3];return t[0]=r*s+i*u+o*f-a*c,t[1]=o*s+i*c+a*u-r*f,t[2]=a*s+i*f+r*c-o*u,t[3]=i*s-r*u-o*c-a*f,t},u.mul=u.multiply,u.scale=i.scale,u.rotateX=function(t,e,n){n*=.5;var r=e[0],o=e[1],a=e[2],i=e[3],u=Math.sin(n),c=Math.cos(n);return t[0]=r*c+i*u,t[1]=o*c+a*u,t[2]=a*c-o*u,t[3]=i*c-r*u,t},u.rotateY=function(t,e,n){n*=.5;var r=e[0],o=e[1],a=e[2],i=e[3],u=Math.sin(n),c=Math.cos(n);return t[0]=r*c-a*u,t[1]=o*c+i*u,t[2]=a*c+r*u,t[3]=i*c-o*u,t},u.rotateZ=function(t,e,n){n*=.5;var r=e[0],o=e[1],a=e[2],i=e[3],u=Math.sin(n),c=Math.cos(n);return t[0]=r*c+o*u,t[1]=o*c-r*u,t[2]=a*c+i*u,t[3]=i*c-a*u,t},u.calculateW=function(t,e){var n=e[0],r=e[1],o=e[2];return t[0]=n,t[1]=r,t[2]=o,t[3]=Math.sqrt(Math.abs(1-n*n-r*r-o*o)),t},u.dot=i.dot,u.lerp=i.lerp,u.slerp=function(t,e,n,r){var o,a,i,u,c,f=e[0],s=e[1],l=e[2],d=e[3],h=n[0],p=n[1],v=n[2],g=n[3];return a=f*h+s*p+l*v+d*g,0>a&&(a=-a,h=-h,p=-p,v=-v,g=-g),1-a>1e-6?(o=Math.acos(a),i=Math.sin(o),u=Math.sin((1-r)*o)/i,c=Math.sin(r*o)/i):(u=1-r,c=r),t[0]=u*f+c*h,t[1]=u*s+c*p,t[2]=u*l+c*v,t[3]=u*d+c*g,t},u.sqlerp=function(){var t=u.create(),e=u.create();return function(n,r,o,a,i,c){return u.slerp(t,r,i,c),u.slerp(e,o,a,c),u.slerp(n,t,e,2*c*(1-c)),n}}(),u.invert=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=n*n+r*r+o*o+a*a,u=i?1/i:0;return t[0]=-n*u,t[1]=-r*u,t[2]=-o*u,t[3]=a*u,t},u.conjugate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=e[3],t},u.length=i.length,u.len=u.length,u.squaredLength=i.squaredLength,u.sqrLen=u.squaredLength,u.normalize=i.normalize,u.fromMat3=function(t,e){var n,r=e[0]+e[4]+e[8];if(r>0)n=Math.sqrt(r+1),t[3]=.5*n,n=.5/n,t[0]=(e[5]-e[7])*n,t[1]=(e[6]-e[2])*n,t[2]=(e[1]-e[3])*n;else{var o=0;e[4]>e[0]&&(o=1),e[8]>e[3*o+o]&&(o=2);var a=(o+1)%3,i=(o+2)%3;n=Math.sqrt(e[3*o+o]-e[3*a+a]-e[3*i+i]+1),t[o]=.5*n,n=.5/n,t[3]=(e[3*a+i]-e[3*i+a])*n,t[a]=(e[3*a+o]+e[3*o+a])*n,t[i]=(e[3*i+o]+e[3*o+i])*n}return t},u.str=function(t){return"quat("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"},t.exports=u},function(t,e,n){var r=n(8),o={};o.create=function(){var t=new r.ARRAY_TYPE(3);return t[0]=0,t[1]=0,t[2]=0,t},o.clone=function(t){var e=new r.ARRAY_TYPE(3);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e},o.fromValues=function(t,e,n){var o=new r.ARRAY_TYPE(3);return o[0]=t,o[1]=e,o[2]=n,o},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t},o.set=function(t,e,n,r){return t[0]=e,t[1]=n,t[2]=r,t},o.add=function(t,e,n){return t[0]=e[0]+n[0],t[1]=e[1]+n[1],t[2]=e[2]+n[2],t},o.subtract=function(t,e,n){return t[0]=e[0]-n[0],t[1]=e[1]-n[1],t[2]=e[2]-n[2],t},o.sub=o.subtract,o.multiply=function(t,e,n){return t[0]=e[0]*n[0],t[1]=e[1]*n[1],t[2]=e[2]*n[2],t},o.mul=o.multiply,o.divide=function(t,e,n){return t[0]=e[0]/n[0],t[1]=e[1]/n[1],t[2]=e[2]/n[2],t},o.div=o.divide,o.min=function(t,e,n){return t[0]=Math.min(e[0],n[0]),t[1]=Math.min(e[1],n[1]),t[2]=Math.min(e[2],n[2]),t},o.max=function(t,e,n){return t[0]=Math.max(e[0],n[0]),t[1]=Math.max(e[1],n[1]),t[2]=Math.max(e[2],n[2]),t},o.scale=function(t,e,n){return t[0]=e[0]*n,t[1]=e[1]*n,t[2]=e[2]*n,t},o.scaleAndAdd=function(t,e,n,r){return t[0]=e[0]+n[0]*r,t[1]=e[1]+n[1]*r,t[2]=e[2]+n[2]*r,t},o.distance=function(t,e){var n=e[0]-t[0],r=e[1]-t[1],o=e[2]-t[2];return Math.sqrt(n*n+r*r+o*o)},o.dist=o.distance,o.squaredDistance=function(t,e){var n=e[0]-t[0],r=e[1]-t[1],o=e[2]-t[2];return n*n+r*r+o*o},o.sqrDist=o.squaredDistance,o.length=function(t){var e=t[0],n=t[1],r=t[2];return Math.sqrt(e*e+n*n+r*r)},o.len=o.length,o.squaredLength=function(t){var e=t[0],n=t[1],r=t[2];return e*e+n*n+r*r},o.sqrLen=o.squaredLength,o.negate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t},o.inverse=function(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t},o.normalize=function(t,e){var n=e[0],r=e[1],o=e[2],a=n*n+r*r+o*o;return a>0&&(a=1/Math.sqrt(a),t[0]=e[0]*a,t[1]=e[1]*a,t[2]=e[2]*a),t},o.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]},o.cross=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=n[0],u=n[1],c=n[2];return t[0]=o*c-a*u,t[1]=a*i-r*c,t[2]=r*u-o*i,t},o.lerp=function(t,e,n,r){var o=e[0],a=e[1],i=e[2];return t[0]=o+r*(n[0]-o),t[1]=a+r*(n[1]-a),t[2]=i+r*(n[2]-i),t},o.hermite=function(t,e,n,r,o,a){var i=a*a,u=i*(2*a-3)+1,c=i*(a-2)+a,f=i*(a-1),s=i*(3-2*a);return t[0]=e[0]*u+n[0]*c+r[0]*f+o[0]*s,t[1]=e[1]*u+n[1]*c+r[1]*f+o[1]*s,t[2]=e[2]*u+n[2]*c+r[2]*f+o[2]*s,t},o.bezier=function(t,e,n,r,o,a){var i=1-a,u=i*i,c=a*a,f=u*i,s=3*a*u,l=3*c*i,d=c*a;return t[0]=e[0]*f+n[0]*s+r[0]*l+o[0]*d,t[1]=e[1]*f+n[1]*s+r[1]*l+o[1]*d,t[2]=e[2]*f+n[2]*s+r[2]*l+o[2]*d,t},o.random=function(t,e){e=e||1;var n=2*r.RANDOM()*Math.PI,o=2*r.RANDOM()-1,a=Math.sqrt(1-o*o)*e;return t[0]=Math.cos(n)*a,t[1]=Math.sin(n)*a,t[2]=o*e,t},o.transformMat4=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=n[3]*r+n[7]*o+n[11]*a+n[15];return i=i||1,t[0]=(n[0]*r+n[4]*o+n[8]*a+n[12])/i,t[1]=(n[1]*r+n[5]*o+n[9]*a+n[13])/i,t[2]=(n[2]*r+n[6]*o+n[10]*a+n[14])/i,t},o.transformMat3=function(t,e,n){var r=e[0],o=e[1],a=e[2];return t[0]=r*n[0]+o*n[3]+a*n[6],t[1]=r*n[1]+o*n[4]+a*n[7],t[2]=r*n[2]+o*n[5]+a*n[8],t},o.transformQuat=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=n[0],u=n[1],c=n[2],f=n[3],s=f*r+u*a-c*o,l=f*o+c*r-i*a,d=f*a+i*o-u*r,h=-i*r-u*o-c*a;return t[0]=s*f+h*-i+l*-c-d*-u,t[1]=l*f+h*-u+d*-i-s*-c,t[2]=d*f+h*-c+s*-u-l*-i,t},o.rotateX=function(t,e,n,r){var o=[],a=[];return o[0]=e[0]-n[0],o[1]=e[1]-n[1],o[2]=e[2]-n[2],a[0]=o[0],a[1]=o[1]*Math.cos(r)-o[2]*Math.sin(r),a[2]=o[1]*Math.sin(r)+o[2]*Math.cos(r),t[0]=a[0]+n[0],t[1]=a[1]+n[1],t[2]=a[2]+n[2],t},o.rotateY=function(t,e,n,r){var o=[],a=[];return o[0]=e[0]-n[0],o[1]=e[1]-n[1],o[2]=e[2]-n[2],a[0]=o[2]*Math.sin(r)+o[0]*Math.cos(r),a[1]=o[1],a[2]=o[2]*Math.cos(r)-o[0]*Math.sin(r),t[0]=a[0]+n[0],t[1]=a[1]+n[1],t[2]=a[2]+n[2],t},o.rotateZ=function(t,e,n,r){var o=[],a=[];return o[0]=e[0]-n[0],o[1]=e[1]-n[1],o[2]=e[2]-n[2],a[0]=o[0]*Math.cos(r)-o[1]*Math.sin(r),a[1]=o[0]*Math.sin(r)+o[1]*Math.cos(r),a[2]=o[2],t[0]=a[0]+n[0],t[1]=a[1]+n[1],t[2]=a[2]+n[2],t},o.forEach=function(){var t=o.create();return function(e,n,r,o,a,i){var u,c;for(n||(n=3),r||(r=0),c=o?Math.min(o*n+r,e.length):e.length,u=r;c>u;u+=n)t[0]=e[u],t[1]=e[u+1],t[2]=e[u+2],a(t,t,i),e[u]=t[0],e[u+1]=t[1],e[u+2]=t[2];return e}}(),o.angle=function(t,e){var n=o.fromValues(t[0],t[1],t[2]),r=o.fromValues(e[0],e[1],e[2]);o.normalize(n,n),o.normalize(r,r);var a=o.dot(n,r);return a>1?0:Math.acos(a)},o.str=function(t){return"vec3("+t[0]+", "+t[1]+", "+t[2]+")"},t.exports=o},function(t,e,n){var r=n(8),o={};o.create=function(){var t=new r.ARRAY_TYPE(4);return t[0]=0,t[1]=0,t[2]=0,t[3]=0,t},o.clone=function(t){var e=new r.ARRAY_TYPE(4);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e},o.fromValues=function(t,e,n,o){var a=new r.ARRAY_TYPE(4);return a[0]=t,a[1]=e,a[2]=n,a[3]=o,a},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t},o.set=function(t,e,n,r,o){return t[0]=e,t[1]=n,t[2]=r,t[3]=o,t},o.add=function(t,e,n){return t[0]=e[0]+n[0],t[1]=e[1]+n[1],t[2]=e[2]+n[2],t[3]=e[3]+n[3],t},o.subtract=function(t,e,n){return t[0]=e[0]-n[0],t[1]=e[1]-n[1],t[2]=e[2]-n[2],t[3]=e[3]-n[3],t},o.sub=o.subtract,o.multiply=function(t,e,n){return t[0]=e[0]*n[0],t[1]=e[1]*n[1],t[2]=e[2]*n[2],t[3]=e[3]*n[3],t},o.mul=o.multiply,o.divide=function(t,e,n){return t[0]=e[0]/n[0],t[1]=e[1]/n[1],t[2]=e[2]/n[2],t[3]=e[3]/n[3],t},o.div=o.divide,o.min=function(t,e,n){return t[0]=Math.min(e[0],n[0]),t[1]=Math.min(e[1],n[1]),t[2]=Math.min(e[2],n[2]),t[3]=Math.min(e[3],n[3]),t},o.max=function(t,e,n){return t[0]=Math.max(e[0],n[0]),t[1]=Math.max(e[1],n[1]),t[2]=Math.max(e[2],n[2]),t[3]=Math.max(e[3],n[3]),t},o.scale=function(t,e,n){return t[0]=e[0]*n,t[1]=e[1]*n,t[2]=e[2]*n,t[3]=e[3]*n,t},o.scaleAndAdd=function(t,e,n,r){return t[0]=e[0]+n[0]*r,t[1]=e[1]+n[1]*r,t[2]=e[2]+n[2]*r,t[3]=e[3]+n[3]*r,t},o.distance=function(t,e){var n=e[0]-t[0],r=e[1]-t[1],o=e[2]-t[2],a=e[3]-t[3];return Math.sqrt(n*n+r*r+o*o+a*a)},o.dist=o.distance,o.squaredDistance=function(t,e){var n=e[0]-t[0],r=e[1]-t[1],o=e[2]-t[2],a=e[3]-t[3];return n*n+r*r+o*o+a*a},o.sqrDist=o.squaredDistance,o.length=function(t){var e=t[0],n=t[1],r=t[2],o=t[3];return Math.sqrt(e*e+n*n+r*r+o*o)},o.len=o.length,o.squaredLength=function(t){var e=t[0],n=t[1],r=t[2],o=t[3];return e*e+n*n+r*r+o*o},o.sqrLen=o.squaredLength,o.negate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=-e[3],t},o.inverse=function(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t[3]=1/e[3],t},o.normalize=function(t,e){var n=e[0],r=e[1],o=e[2],a=e[3],i=n*n+r*r+o*o+a*a;return i>0&&(i=1/Math.sqrt(i),t[0]=n*i,t[1]=r*i,t[2]=o*i,t[3]=a*i),t},o.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]+t[3]*e[3]},o.lerp=function(t,e,n,r){var o=e[0],a=e[1],i=e[2],u=e[3];return t[0]=o+r*(n[0]-o),t[1]=a+r*(n[1]-a),t[2]=i+r*(n[2]-i),t[3]=u+r*(n[3]-u),t},o.random=function(t,e){return e=e||1,t[0]=r.RANDOM(),t[1]=r.RANDOM(),t[2]=r.RANDOM(),t[3]=r.RANDOM(),o.normalize(t,t),o.scale(t,t,e),t},o.transformMat4=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=e[3];return t[0]=n[0]*r+n[4]*o+n[8]*a+n[12]*i,t[1]=n[1]*r+n[5]*o+n[9]*a+n[13]*i,t[2]=n[2]*r+n[6]*o+n[10]*a+n[14]*i,t[3]=n[3]*r+n[7]*o+n[11]*a+n[15]*i,t},o.transformQuat=function(t,e,n){var r=e[0],o=e[1],a=e[2],i=n[0],u=n[1],c=n[2],f=n[3],s=f*r+u*a-c*o,l=f*o+c*r-i*a,d=f*a+i*o-u*r,h=-i*r-u*o-c*a;return t[0]=s*f+h*-i+l*-c-d*-u,t[1]=l*f+h*-u+d*-i-s*-c,t[2]=d*f+h*-c+s*-u-l*-i,t[3]=e[3],t},o.forEach=function(){var t=o.create();return function(e,n,r,o,a,i){var u,c;for(n||(n=4),r||(r=0),c=o?Math.min(o*n+r,e.length):e.length,u=r;c>u;u+=n)t[0]=e[u],t[1]=e[u+1],t[2]=e[u+2],t[3]=e[u+3],a(t,t,i),e[u]=t[0],e[u+1]=t[1],e[u+2]=t[2],e[u+3]=t[3];return e}}(),o.str=function(t){return"vec4("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"},t.exports=o},function(t,e,n){var r=n(8),o={};o.create=function(){var t=new r.ARRAY_TYPE(2);return t[0]=0,t[1]=0,t},o.clone=function(t){var e=new r.ARRAY_TYPE(2);return e[0]=t[0],e[1]=t[1],e},o.fromValues=function(t,e){var n=new r.ARRAY_TYPE(2);return n[0]=t,n[1]=e,n},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t},o.set=function(t,e,n){return t[0]=e,t[1]=n,t},o.add=function(t,e,n){return t[0]=e[0]+n[0],t[1]=e[1]+n[1],t},o.subtract=function(t,e,n){return t[0]=e[0]-n[0],t[1]=e[1]-n[1],t},o.sub=o.subtract,o.multiply=function(t,e,n){return t[0]=e[0]*n[0],t[1]=e[1]*n[1],t},o.mul=o.multiply,o.divide=function(t,e,n){return t[0]=e[0]/n[0],t[1]=e[1]/n[1],t},o.div=o.divide,o.min=function(t,e,n){return t[0]=Math.min(e[0],n[0]),t[1]=Math.min(e[1],n[1]),t},o.max=function(t,e,n){return t[0]=Math.max(e[0],n[0]),t[1]=Math.max(e[1],n[1]),t},o.scale=function(t,e,n){return t[0]=e[0]*n,t[1]=e[1]*n,t},o.scaleAndAdd=function(t,e,n,r){return t[0]=e[0]+n[0]*r,t[1]=e[1]+n[1]*r,t},o.distance=function(t,e){var n=e[0]-t[0],r=e[1]-t[1];return Math.sqrt(n*n+r*r)},o.dist=o.distance,o.squaredDistance=function(t,e){var n=e[0]-t[0],r=e[1]-t[1];return n*n+r*r},o.sqrDist=o.squaredDistance,o.length=function(t){var e=t[0],n=t[1];return Math.sqrt(e*e+n*n)},o.len=o.length,o.squaredLength=function(t){var e=t[0],n=t[1];return e*e+n*n},o.sqrLen=o.squaredLength,o.negate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t},o.inverse=function(t,e){return t[0]=1/e[0],t[1]=1/e[1],t},o.normalize=function(t,e){var n=e[0],r=e[1],o=n*n+r*r;return o>0&&(o=1/Math.sqrt(o),t[0]=e[0]*o,t[1]=e[1]*o),t},o.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]},o.cross=function(t,e,n){var r=e[0]*n[1]-e[1]*n[0];return t[0]=t[1]=0,t[2]=r,t},o.lerp=function(t,e,n,r){var o=e[0],a=e[1];return t[0]=o+r*(n[0]-o),t[1]=a+r*(n[1]-a),t},o.random=function(t,e){e=e||1;var n=2*r.RANDOM()*Math.PI;return t[0]=Math.cos(n)*e,t[1]=Math.sin(n)*e,t},o.transformMat2=function(t,e,n){var r=e[0],o=e[1];return t[0]=n[0]*r+n[2]*o,t[1]=n[1]*r+n[3]*o,t},o.transformMat2d=function(t,e,n){var r=e[0],o=e[1];return t[0]=n[0]*r+n[2]*o+n[4],t[1]=n[1]*r+n[3]*o+n[5],t},o.transformMat3=function(t,e,n){var r=e[0],o=e[1];return t[0]=n[0]*r+n[3]*o+n[6],t[1]=n[1]*r+n[4]*o+n[7],t},o.transformMat4=function(t,e,n){var r=e[0],o=e[1];return t[0]=n[0]*r+n[4]*o+n[12],t[1]=n[1]*r+n[5]*o+n[13],t},o.forEach=function(){var t=o.create();return function(e,n,r,o,a,i){var u,c;for(n||(n=2),r||(r=0),c=o?Math.min(o*n+r,e.length):e.length,u=r;c>u;u+=n)t[0]=e[u],t[1]=e[u+1],a(t,t,i),e[u]=t[0],e[u+1]=t[1];return e}}(),o.str=function(t){return"vec2("+t[0]+", "+t[1]+")"},t.exports=o},function(t,e){"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e["default"]={init:function(t,e){for(var n=t.length;n--;)t[n]=e},shuffle:function(t){var e,n,r=t.length-1;for(r;r>=0;r--)e=Math.floor(Math.random()*r),n=t[r],t[r]=t[e],t[e]=n;return t},toPointList:function(t){var e,n,r=[],o=[];for(e=0;e=e&&o.push(t[r]);return o},maxIndex:function(t){var e,n=0;for(e=0;et[n]&&(n=e);return n},max:function n(t){var e,n=0;for(e=0;en&&(n=t[e]);return n},sum:function r(t){for(var e=t.length,r=0;e--;)r+=t[e];return r}},t.exports=e["default"]},function(t,e,n){(function(r){"use strict";function o(t){return t&&t.__esModule?t:{"default":t}}function a(){var t;m=g.halfSample?new D["default"]({x:w.size.x/2|0,y:w.size.y/2|0}):w,A=S["default"].calculatePatchSize(g.patchSize,m.size),G.x=m.size.x/A.x|0,G.y=m.size.y/A.y|0,E=new D["default"](m.size,void 0,Uint8Array,!1),x=new D["default"](A,void 0,Array,!0),t=new ArrayBuffer(65536),y=new D["default"](A,new Uint8Array(t,0,A.x*A.y)),_=new D["default"](A,new Uint8Array(t,A.x*A.y*3,A.x*A.y),void 0,!0),C=q["default"]("undefined"!=typeof window?window:"undefined"!=typeof self?self:r,{size:A.x},t),R=new D["default"]({x:m.size.x/y.size.x|0,y:m.size.y/y.size.y|0},void 0,Array,!0),M=new D["default"](R.size,void 0,void 0,!0),b=new D["default"](R.size,void 0,Int32Array,!0)}function i(){g.useWorker||"undefined"==typeof document||(F.dom.binary=document.createElement("canvas"),F.dom.binary.className="binaryBuffer",F.ctx.binary=F.dom.binary.getContext("2d"),F.dom.binary.width=E.size.x,F.dom.binary.height=E.size.y)}function u(t){var e,n,r,o,a,i,u,c=E.size.x,f=E.size.y,s=-E.size.x,l=-E.size.y;for(e=0,n=0;ne&&(e+=180),e=(180-e)*Math.PI/180,a=W.mat2.clone([Math.cos(e),Math.sin(e),-Math.sin(e),Math.cos(e)]),n=0;nr;r++)W.vec2.transformMat2(o.box[r],o.box[r],a);for(n=0;nr;r++)o.box[r][0]s&&(s=o.box[r][0]),o.box[r][1]l&&(l=o.box[r][1]);for(i=[[c,f],[s,f],[s,l],[c,l]],u=g.halfSample?2:1,a=W.mat2.invert(a,a),r=0;4>r;r++)W.vec2.transformMat2(i[r],i[r],a);for(r=0;4>r;r++)W.vec2.scale(i[r],i[r],u);return i}function c(){S["default"].otsuThreshold(m,E),E.zeroBorder(),g.showCanvas&&E.show(F.dom.binary,255)}function f(){var t,e,n,r,o,a,i,u=[];for(t=0;te;e++)r.push(0);for(n=b.data.length;n--;)b.data[n]>0&&r[b.data[n]-1]++;return r=r.map(function(t,e){return{val:t,label:e+1}}),r.sort(function(t,e){return e.val-t.val}),o=r.filter(function(t){return t.val>=5})}function l(t,e){var n,r,o,a,i=[],c=[];for(n=0;n=2){for(o=0;os&&c.push(t[o]);if(c.length>=2){for(i=d(c),a=0,o=0;o1&&i.length>=c.length/4*3&&i.length>t.length/4&&(a/=i.length,u={index:e[1]*G.x+e[0],pos:{x:n,y:r},box:[W.vec2.clone([n,r]),W.vec2.clone([n+y.size.x,r]),W.vec2.clone([n+y.size.x,r+y.size.y]),W.vec2.clone([n,r+y.size.y])],moments:i,rad:a,vec:W.vec2.clone([Math.cos(a),Math.sin(a)])},f.push(u))}}return f}function v(t){function e(){var t;for(t=0;ti&&n(u)):b.data[u]=Number.MAX_VALUE}var r,o,a=0,i=.95,u=0;for(I["default"].init(M.data,0),I["default"].init(b.data,0),I["default"].init(R.data,null),r=0;rr?null:(e=s(r),0===e.length?null:n=l(e,r))},checkImageConstraints:function(t,e){var n,r,o,a=t.getWidth(),i=t.getHeight(),u=e.halfSample?.5:1;if(t.getConfig().area&&(o=S["default"].computeImageArea(a,i,t.getConfig().area),t.setTopRight({x:o.sx,y:o.sy}),t.setCanvasSize({x:a,y:i}),a=o.sw,i=o.sh),r={x:Math.floor(a*u),y:Math.floor(i*u)},n=S["default"].calculatePatchSize(e.patchSize,r),t.setWidth(Math.floor(Math.floor(r.x/n.x)*(1/u)*n.x)),t.setHeight(Math.floor(Math.floor(r.y/n.y)*(1/u)*n.y)),t.getWidth()%n.x===0&&t.getHeight()%n.y===0)return!0;throw new Error("Image dimensions do not comply with the current settings: Width ("+a+" )and height ("+i+") must a multiple of "+n.x)}},t.exports=e["default"]}).call(e,function(){return this}())},function(t,e){"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e["default"]={drawRect:function(t,e,n,r){n.strokeStyle=r.color,n.fillStyle=r.color,n.lineWidth=1,n.beginPath(),n.strokeRect(t.x,t.y,e.x,e.y)},drawPath:function(t,e,n,r){n.strokeStyle=r.color,n.fillStyle=r.color,n.lineWidth=r.lineWidth,n.beginPath(),n.moveTo(t[0][e.x],t[0][e.y]);for(var o=1;o_;_++)y[_]=0;for(y[0]=n[0],v=null,d=1;u-1>d;d++)for(s=0,a=y[0],l=1;o-1>l;l++)if(m=d*o+l,0===r[m])if(e=n[m],e!==a){if(0===s)f=x+1,y[f]=e,a=e,h=c.contourTracing(d,l,f,e,i.DIR.OUTSIDE_EDGE),null!==h&&(x++,s=f,p=i.createContour2D(),p.dir=i.CONTOUR_DIR.CW_DIR,p.index=s,p.firstVertex=h,p.nextpeer=v,p.insideContours=null,null!==v&&(v.prevpeer=p),v=p);else if(h=c.contourTracing(d,l,i.DIR.INSIDE_EDGE,e,s),null!==h){for(p=i.createContour2D(),p.firstVertex=h,p.insideContours=null,0===t?p.dir=i.CONTOUR_DIR.CCW_DIR:p.dir=i.CONTOUR_DIR.CW_DIR,p.index=t,g=v;null!==g&&g.index!==s;)g=g.nextpeer;null!==g&&(p.nextpeer=g.insideContours,null!==g.insideContours&&(g.insideContours.prevpeer=p),g.insideContours=p)}}else r[m]=s;else r[m]===i.DIR.OUTSIDE_EDGE||r[m]===i.DIR.INSIDE_EDGE?(s=0,a=r[m]===i.DIR.INSIDE_EDGE?n[m]:y[0]):(s=r[m],a=y[s]);for(g=v;null!==g;)g.index=t,g=g.nextpeer;return{cc:v,count:x}},debug:{drawContour:function(t,e){var n,r,o,a=t.getContext("2d"),u=e;for(a.strokeStyle="red",a.fillStyle="red",a.lineWidth=1,n=null!==u?u.insideContours:null;null!==u;){switch(null!==n?(r=n,n=n.nextpeer):(r=u,u=u.nextpeer,n=null!==u?u.insideContours:null),r.dir){case i.CONTOUR_DIR.CW_DIR:a.strokeStyle="red";break;case i.CONTOUR_DIR.CCW_DIR:a.strokeStyle="blue";break;case i.CONTOUR_DIR.UNKNOWN_DIR:a.strokeStyle="green"}o=r.firstVertex,a.beginPath(),a.moveTo(o.x,o.y);do o=o.next,a.lineTo(o.x,o.y);while(o!==r.firstVertex);a.stroke()}}}}}};e["default"]=i,t.exports=e["default"]},function(t,e){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var n={searchDirections:[[0,1],[1,1],[1,0],[1,-1],[0,-1],[-1,-1],[-1,0],[-1,1]],create:function(t,e){function n(t,e,n,r){var o,s,l;for(o=0;7>o;o++){if(s=t.cy+c[t.dir][0],l=t.cx+c[t.dir][1],a=s*f+l,i[a]===e&&(0===u[a]||u[a]===n))return u[a]=n,t.cy=s,t.cx=l,!0;0===u[a]&&(u[a]=r),t.dir=(t.dir+1)%8}return!1}function r(t,e,n){return{dir:n,x:t,y:e,next:null,prev:null}}function o(t,e,o,a,i){var u,c,f,s=null,l={cx:e,cy:t,dir:0};if(n(l,a,o,i)){s=r(e,t,l.dir),u=s,f=l.dir,c=r(l.cx,l.cy,0),c.prev=u,u.next=c,c.next=null,u=c;do l.dir=(l.dir+6)%8,n(l,a,o,i),f!==l.dir?(u.dir=l.dir,c=r(l.cx,l.cy,0),c.prev=u,u.next=c,c.next=null,u=c):(u.dir=f,u.x=l.cx,u.y=l.cy),f=l.dir;while(l.cx!==e||l.cy!==t);s.prev=u.prev,u.prev.next=s}return s}var a,i=t.data,u=e.data,c=this.searchDirections,f=t.size.x;return{trace:function(t,e,r,o){return n(t,e,r,o)},contourTracing:function(t,e,n,r,a){return o(t,e,n,r,a)}}}};e["default"]=n,t.exports=e["default"]},function(module, exports) {"use strict";Object.defineProperty(exports, "__esModule", {value: true});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(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};}exports["default"]=Skeletonizer;module.exports=exports["default"]; },function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}Object.defineProperty(e,"__esModule",{value:!0});var o=n(24),a=r(o),i=n(19),u=(r(i),n(25)),c=r(u),f=n(27),s=r(f),l=n(28),d=r(l),h=n(29),p=r(h),v=n(30),g=r(v),m=n(31),_=r(m),y=n(32),x=r(y),M=n(33),b=r(M),R=n(34),E=r(R),A={code_128_reader:c["default"],ean_reader:s["default"],ean_8_reader:x["default"],code_39_reader:d["default"],code_39_vin_reader:p["default"],codabar_reader:g["default"],upc_reader:_["default"],upc_e_reader:b["default"],i2of5_reader:E["default"]};e["default"]={create:function(t,e){function n(){}function r(){t.readers.forEach(function(t){var e,n={};"object"==typeof t?(e=t.format,n=t.config):"string"==typeof t&&(e=t),h.push(new A[e](n))})}function o(){}function i(t,n,r){function o(e){var r={y:e*Math.sin(n),x:e*Math.cos(n)};t[0].y-=r.y,t[0].x-=r.x,t[1].y+=r.y,t[1].x+=r.x}for(o(r);r>1&&(!e.inImageWithBorder(t[0],0)||!e.inImageWithBorder(t[1],0));)r-=Math.ceil(r/2),o(-r);return t}function u(t){return[{x:(t[1][0]-t[0][0])/2+t[0][0],y:(t[1][1]-t[0][1])/2+t[0][1]},{x:(t[3][0]-t[2][0])/2+t[2][0],y:(t[3][1]-t[2][1])/2+t[2][1]}]}function c(t){var n,r=null,o=a["default"].getBarcodeLine(e,t[0],t[1]);for(a["default"].toBinaryLine(o),n=0;nr&&null===f;r++)o=i/u*r*(r%2===0?-1:1),a={y:o*s,x:o*l},e[0].y+=a.x,e[0].x-=a.y,e[1].y+=a.x,e[1].x-=a.y,f=c(e);return f}function s(t){return Math.sqrt(Math.pow(Math.abs(t[1].y-t[0].y),2)+Math.pow(Math.abs(t[1].x-t[0].x),2))}function l(t){var e,n,r,o;d.ctx.overlay;return e=u(t),o=s(e),n=Math.atan2(e[1].y-e[0].y,e[1].x-e[0].x),e=i(e,n,Math.floor(.1*o)),null===e?null:(r=c(e),null===r&&(r=f(t,e,n)),null===r?null:{codeResult:r.codeResult,line:e,angle:n,pattern:r.barcodeLine.line,threshold:r.barcodeLine.threshold})}var d={ctx:{frequency:null,pattern:null,overlay:null},dom:{frequency:null,pattern:null,overlay:null}},h=[];return n(),r(),o(),{decodeFromBoundingBox:function(t){return l(t)},decodeFromBoundingBoxes:function(e){var n,r,o=[],a=t.multiple;for(n=0;nl?l:M,b=l>b?l:b,m.push(l)}var o,a,i,u,c,f,s,l,d=0|e.x,h=0|e.y,p=0|n.x,v=0|n.y,g=Math.abs(v-h)>Math.abs(p-d),m=[],_=t.data,y=t.size.x,x=0,M=255,b=0;for(g&&(f=d,d=h,h=f,f=p,p=v,v=f),d>p&&(f=d,d=p,p=f,f=h,h=v,v=f),o=p-d,a=Math.abs(v-h),i=o/2|0,c=h,u=v>h?1:-1,s=d;p>s;s++)g?r(c,s):r(s,c),i-=a,0>i&&(c+=u,i+=o);return{line:m,min:M,max:b}},c.toOtsuBinaryLine=function(t){var e=t.line,n=new u["default"]({x:e.length-1,y:1},e),r=a["default"].determineOtsuThreshold(n,5);return e=a["default"].sharpenLine(e),a["default"].thresholdImage(n,r),{line:e,threshold:r}},c.toBinaryLine=function(t){var e,n,r,o,a,i,u=t.min,c=t.max,s=t.line,l=u+(c-u)/2,d=[],h=(c-u)/12,p=-h;for(r=s[0]>l?f.DIR.UP:f.DIR.DOWN,d.push({pos:0,val:s[0]}),a=0;ae+n&&s[a+1]<1.5*l?f.DIR.DOWN:e+n>h&&s[a+1]>.5*l?f.DIR.UP:r,r!==o&&(d.push({pos:a,val:s[a]}),r=o);for(d.push({pos:s.length,val:s[s.length-1]}),i=d[0].pos;il?0:1;for(a=1;ad[a].val?d[a].val+(d[a+1].val-d[a].val)/3*2|0:d[a+1].val+(d[a].val-d[a+1].val)/3|0,i=d[a].pos;ih?0:1;return{line:s,threshold:h}},c.debug={printFrequency:function(t,e){var n,r=e.getContext("2d");for(e.width=t.length,e.height=256,r.beginPath(),r.strokeStyle="blue",n=0;nr;r++)i[r]=i[r+2];i[4]=0,i[5]=0,s--}else s++;i[s]=1,f=!f}return null},o.prototype._decode=function(){var t,e,n=this,r=n._findStart(),o=null,a=!1,i=[],u=0,c=0,f=[],s=[],l=!1,d=!0;if(null===r)return null;switch(o={code:r.code,start:r.start,end:r.end},s.push(o),c=o.code,o.code){case n.START_CODE_A:t=n.CODE_A;break;case n.START_CODE_B:t=n.CODE_B;break;case n.START_CODE_C:t=n.CODE_C;break;default:return null}for(;!a;){if(e=l,l=!1,o=n._decodeCode(o.end),null!==o)switch(o.code!==n.STOP_CODE&&(d=!0),o.code!==n.STOP_CODE&&(f.push(o.code),u++,c+=u*o.code),s.push(o),t){case n.CODE_A:if(o.code<64)i.push(String.fromCharCode(32+o.code));else if(o.code<96)i.push(String.fromCharCode(o.code-64));else switch(o.code!==n.STOP_CODE&&(d=!1),o.code){case n.CODE_SHIFT:l=!0,t=n.CODE_B;break;case n.CODE_B:t=n.CODE_B;break;case n.CODE_C:t=n.CODE_C;break;case n.STOP_CODE:a=!0}break;case n.CODE_B:if(o.code<96)i.push(String.fromCharCode(32+o.code));else switch(o.code!==n.STOP_CODE&&(d=!1),o.code){case n.CODE_SHIFT:l=!0,t=n.CODE_A;break;case n.CODE_A:t=n.CODE_A;break;case n.CODE_C:t=n.CODE_C;break;case n.STOP_CODE:a=!0}break;case n.CODE_C:if(o.code<100)i.push(o.code<10?"0"+o.code:o.code);else switch(o.code!==n.STOP_CODE&&(d=!1),o.code){case n.CODE_A:t=n.CODE_A;break;case n.CODE_B:t=n.CODE_B;break;case n.STOP_CODE:a=!0}}else a=!0;e&&(t=t===n.CODE_A?n.CODE_B:n.CODE_A)}return null===o?null:(o.end=n._nextUnset(n._row,o.end),n._verifyTrailingWhitespace(o)?(c-=u*f[f.length-1],c%103!==f[f.length-1]?null:i.length?(d&&i.splice(i.length-1,1),{code:i.join(""),start:r.start,end:o.end,codeset:t,startInfo:r,decodedCodes:s,endInfo:o}):null):null)},i["default"].prototype._verifyTrailingWhitespace=function(t){var e,n=this;return e=t.end+(t.end-t.start)/2,ei)return Number.MAX_VALUE;r+=o}return r/a},n.prototype._nextSet=function(t,e){var n;for(e=e||0,n=e;n1)for(n=0;nr?(f.start=n-i,f.end=n,f.counter=o,f):null;c++,o[c]=1,u=!u}}else for(o.push(0),n=i;nt?0:t,r=t;e>r;r++)if(this._row[r]!==n)return!1;return!0},n.prototype._fillCounters=function(t,e,n){var r,o=this,a=0,i=[];for(n="undefined"!=typeof n?n:!0,t="undefined"!=typeof t?t:o._nextUnset(o._row),e=e||o._row.length,i[a]=0,r=t;e>r;r++)o._row[r]^n?i[a]++:(a++,i[a]=1,n=!n);return i},Object.defineProperty(n.prototype,"FORMAT",{value:"unknown",writeable:!1}),n.DIRECTION={FORWARD:1,REVERSE:-1},n.Exception={StartNotFoundException:"Start-Info was not found!",CodeNotFoundException:"Code could not be found!",PatternNotFoundException:"Pattern could not be found!"},n.CONFIG_KEYS={},e["default"]=n,t.exports=e["default"]},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(t){i["default"].call(this,t)}Object.defineProperty(e,"__esModule",{value:!0});var a=n(26),i=r(a),u={CODE_L_START:{value:0},MODULO:{value:7},CODE_G_START:{value:10},START_PATTERN:{value:[1/3*7,1/3*7,1/3*7]},STOP_PATTERN:{value:[1/3*7,1/3*7,1/3*7]},MIDDLE_PATTERN:{value:[.2*7,.2*7,.2*7,.2*7,.2*7]},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:.67},AVG_CODE_ERROR:{value:.27},FORMAT:{value:"ean_13",writeable:!1}};o.prototype=Object.create(i["default"].prototype,u),o.prototype.constructor=o,o.prototype._decodeCode=function(t,e){var n,r,o,a,i=[0,0,0,0],u=this,c=t,f=!u._row[c],s=0,l={error:Number.MAX_VALUE,code:-1,start:t,end:t};for(e||(e=u.CODE_PATTERN.length),n=c;nr;r++)o=u._matchPattern(a,u.CODE_PATTERN[r]),ou.AVG_CODE_ERROR?null:l}}else s++;i[s]=1,f=!f}return null},o.prototype._findPattern=function(t,e,n,r,o){var a,i,u,c,f,s=[],l=this,d=0,h={error:Number.MAX_VALUE,code:-1,start:0,end:0};for(e||(e=l._nextSet(l._row)),void 0===n&&(n=!1),void 0===r&&(r=!0),void 0===o&&(o=l.AVG_CODE_ERROR),a=0;ai))return h.error=i,h.start=a-c,h.end=a,h;if(!r)return null;for(u=0;u=0&&n._matchRange(t,e.start,0))return e;r=e.end,e=null}},o.prototype._verifyTrailingWhitespace=function(t){var e,n=this;return e=t.end+(t.end-t.start),er;r++){if(t=a._decodeCode(t.end),!t)return null;t.code>=a.CODE_G_START?(t.code=t.code-a.CODE_G_START,i|=1<<5-r):i|=0<<5-r,e.push(t.code),n.push(t)}if(o=a._calculateFirstDigit(i),null===o)return null;if(e.unshift(o),t=a._findPattern(a.MIDDLE_PATTERN,t.end,!0,!1),null===t)return null;for(n.push(t),r=0;6>r;r++){if(t=a._decodeCode(t.end,a.CODE_G_START),!t)return null;n.push(t),e.push(t.code)}return t},o.prototype._decode=function(){var t,e,n=this,r=[],o=[];return(t=n._findStart())?(e={code:t.code,start:t.start,end:t.end},o.push(e),(e=n._decodePayload(e,r,o))&&(e=n._findEnd(e.end,!1))?(o.push(e),n._checksum(r)?{code:r.join(""),start:t.start,end:e.end,codeset:"",startInfo:t,decodedCodes:o}:null):null):null},o.prototype._checksum=function(t){var e,n=0;for(e=t.length-2;e>=0;e-=2)n+=t[e];for(n*=3,e=t.length-1;e>=0;e-=2)n+=t[e];return n%10===0},e["default"]=o,t.exports=e["default"]},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(){i["default"].call(this)}Object.defineProperty(e,"__esModule",{value:!0});var a=n(26),i=r(a),u=n(17),c=r(u),f={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:[52,289,97,352,49,304,112,37,292,100,265,73,328,25,280,88,13,268,76,28,259,67,322,19,274,82,7,262,70,22,385,193,448,145,400,208,133,388,196,148,168,162,138,42]},ASTERISK:{value:148},FORMAT:{value:"code_39",writeable:!1}};o.prototype=Object.create(i["default"].prototype,f),o.prototype.constructor=o,o.prototype._toCounters=function(t,e){var n,r=this,o=e.length,a=r._row.length,i=!r._row[t],u=0;for(c["default"].init(e,0),n=t;a>n;n++)if(r._row[n]^i)e[u]++;else{if(u++,u===o)break;e[u]=1,i=!i}return e},o.prototype._decode=function(){var t,e,n,r,o=this,a=[0,0,0,0,0,0,0,0,0],i=[],u=o._findStart();if(!u)return null;r=o._nextSet(o._row,u.end);do{if(a=o._toCounters(r,a),n=o._toPattern(a),0>n)return null;if(t=o._patternToChar(n),0>t)return null;i.push(t),e=r,r+=c["default"].sum(a),r=o._nextSet(o._row,r)}while("*"!==t);return i.pop(),i.length&&o._verifyTrailingWhitespace(e,r,a)?{code:i.join(""),start:u.start,end:r,startInfo:u,decodedCodes:i}:null},o.prototype._verifyTrailingWhitespace=function(t,e,n){var r,o=c["default"].sum(n);return r=e-t-o,3*r>=o?!0:!1},o.prototype._patternToChar=function(t){var e,n=this;for(e=0;ee&&(r=t[n]);return r},o.prototype._toPattern=function(t){for(var e,n,r=t.length,o=0,a=r,i=0,u=this;a>3;){for(o=u._findNextWidth(t,o),a=0,e=0,n=0;r>n;n++)t[n]>o&&(e|=1<n&&a>0;n++)if(t[n]>o&&(a--,2*t[n]>=i))return-1;return e}}return-1},o.prototype._findStart=function(){var t,e,n,r=this,o=r._nextSet(r._row),a=o,i=[0,0,0,0,0,0,0,0,0],u=0,c=!1;for(t=o;te;e++)i[e]=i[e+2];i[7]=0,i[8]=0,u--}else u++;i[u]=1,c=!c}return null},e["default"]=o,t.exports=e["default"]},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(){i["default"].call(this)}Object.defineProperty(e,"__esModule",{value:!0});var a=n(28),i=r(a),u={IOQ:/[IOQ]/g,AZ09:/[A-Z0-9]{17}/};o.prototype=Object.create(i["default"].prototype),o.prototype.constructor=o,o.prototype._decode=function(){var t=i["default"].prototype._decode.apply(this);if(!t)return null;var e=t.code;return e?(e=e.replace(u.IOQ,""),e.match(u.AZ09)&&this._checkChecksum(e)?(t.code=e,t):null):null},o.prototype._checkChecksum=function(t){return!!t},e["default"]=o,t.exports=e["default"]},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(){i["default"].call(this),this._counters=[]}Object.defineProperty(e,"__esModule",{value:!0});var a=n(26),i=r(a),u={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:[3,6,9,96,18,66,33,36,48,72,12,24,69,81,84,21,26,41,11,14]},START_END:{value:[26,41,11,14]},MIN_ENCODED_CHARS:{value:4},MAX_ACCEPTABLE:{value:2},PADDING:{value:1.5},FORMAT:{value:"codabar",writeable:!1}};o.prototype=Object.create(i["default"].prototype,u),o.prototype.constructor=o,o.prototype._decode=function(){var t,e,n,r,o,a=this,i=[];if(this._counters=a._fillCounters(),t=a._findStart(),!t)return null;r=t.startCounter;do{if(n=a._toPattern(r),0>n)return null;if(e=a._patternToChar(n),0>e)return null;if(i.push(e),r+=8,i.length>1&&a._isStartEnd(n))break}while(ra._counters.length?a._counters.length:r,o=t.start+a._sumCounters(t.startCounter,r-8),{code:i.join(""),start:t.start,end:o,startInfo:t,decodedCodes:i}):null},o.prototype._verifyWhitespace=function(t,e){return(0>=t-1||this._counters[t-1]>=this._calculatePatternLength(t)/2)&&(e+8>=this._counters.length||this._counters[e+7]>=this._calculatePatternLength(e)/2)?!0:!1},o.prototype._calculatePatternLength=function(t){var e,n=0;for(e=t;t+7>e;e++)n+=this._counters[e];return n},o.prototype._thresholdResultPattern=function(t,e){var n,r,o,a,i,u=this,c={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}}},f=e;for(o=0;o=0;a--)n=2===(1&a)?c.bar:c.space,r=1===(1&i)?n.wide:n.narrow,r.size+=u._counters[f+a],r.counts++,i>>=1;f+=8}return["space","bar"].forEach(function(t){var e=c[t];e.wide.min=Math.floor((e.narrow.size/e.narrow.counts+e.wide.size/e.wide.counts)/2),e.narrow.max=Math.ceil(e.wide.min),e.wide.max=Math.ceil((e.wide.size*u.MAX_ACCEPTABLE+u.PADDING)/e.wide.counts)}),c},o.prototype._charToPattern=function(t){var e,n=this,r=t.charCodeAt(0);for(e=0;e=0;r--){if(o=0===(1&r)?f.bar:f.space,a=1===(1&u)?o.wide:o.narrow,i=c._counters[s+r],ia.max)return!1;u>>=1}s+=8}return!0},o.prototype._patternToChar=function(t){var e,n=this;for(e=0;en;n+=2)r=this._counters[n],r>a&&(a=r),o>r&&(o=r);return(o+a)/2|0},o.prototype._toPattern=function(t){var e,n,r,o,a=7,i=t+a,u=1<this._counters.length)return-1;for(e=this._computeAlternatingThreshold(t,i),n=this._computeAlternatingThreshold(t+1,i),r=0;a>r;r++)o=0===(1&r)?e:n,this._counters[t+r]>o&&(c|=u),u>>=1;return c},o.prototype._isStartEnd=function(t){var e;for(e=0;en;n++)r+=this._counters[n];return r},o.prototype._findStart=function(){var t,e,n,r=this,o=r._nextUnset(r._row);for(t=1;tr;r++){if(t=o._decodeCode(t.end,o.CODE_G_START),!t)return null;e.push(t.code),n.push(t)}if(t=o._findPattern(o.MIDDLE_PATTERN,t.end,!0,!1),null===t)return null;for(n.push(t),r=0;4>r;r++){if(t=o._decodeCode(t.end,o.CODE_G_START),!t)return null;n.push(t),e.push(t.code)}return t},e["default"]=o,t.exports=e["default"]},function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(){i["default"].call(this)}Object.defineProperty(e,"__esModule",{value:!0});var a=n(27),i=r(a),u={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:!1}};o.prototype=Object.create(i["default"].prototype,u),o.prototype.constructor=o,o.prototype._decodePayload=function(t,e,n){var r,o=this,a=0;for(r=0;6>r;r++){if(t=o._decodeCode(t.end),!t)return null;t.code>=o.CODE_G_START&&(t.code=t.code-o.CODE_G_START,a|=1<<5-r),e.push(t.code),n.push(t)}return o._determineParity(a,e)?t:null},o.prototype._determineParity=function(t,e){var n,r;for(r=0;r=n?e.concat(t.slice(1,3)).concat([n,0,0,0,0]).concat(t.slice(3,6)):3===n?e.concat(t.slice(1,4)).concat([0,0,0,0,0]).concat(t.slice(4,6)):4===n?e.concat(t.slice(1,5)).concat([0,0,0,0,0,t[5]]):e.concat(t.slice(1,6)).concat([0,0,0,0,n]),e.push(t[t.length-1]),e},o.prototype._checksum=function(t){return i["default"].prototype._checksum.call(this,this._convertToUPCA(t))},o.prototype._findEnd=function(t,e){return e=!0,i["default"].prototype._findEnd.call(this,t,e)},o.prototype._verifyTrailingWhitespace=function(t){var e,n=this;return e=t.end+(t.end-t.start)/2,ea))return d.error=a,d.start=o-u,d.end=o,d;if(!r)return null;for(i=0;i=0&&n._matchRange(t,e.start,0))return e;r=e.end,e=null}},o.prototype._verifyTrailingWhitespace=function(t){var e,n=this;return e=t.end+(t.end-t.start)/2,ei;){for(r=0;5>r;r++)c[0][r]=t[i]*this.barSpaceRatio[0],c[1][r]=t[i+1]*this.barSpaceRatio[1],i+=2;if(o=a._decodePair(c),!o)return null;for(r=0;r-1&&t%1==0&&r>=t}var r=9007199254740991;t.exports=n},function(t,e){function n(t){return!!t&&"object"==typeof t}t.exports=n},function(t,e,n){var r=n(47),o=n(44),a=n(45),i="[object Array]",u=Object.prototype,c=u.toString,f=r(Array,"isArray"),s=f||function(t){return a(t)&&o(t.length)&&c.call(t)==i};t.exports=s},function(t,e,n){function r(t,e){var n=null==t?void 0:t[e];return o(n)?n:void 0}var o=n(48);t.exports=r},function(t,e,n){function r(t){return null==t?!1:o(t)?s.test(c.call(t)):a(t)&&i.test(t)}var o=n(49),a=n(45),i=/^\[object .+?Constructor\]$/,u=Object.prototype,c=Function.prototype.toString,f=u.hasOwnProperty,s=RegExp("^"+c.call(f).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");t.exports=r},function(t,e,n){function r(t){return o(t)&&u.call(t)==a}var o=n(50),a="[object Function]",i=Object.prototype,u=i.toString;t.exports=r},function(t,e){function n(t){var e=typeof t;return!!t&&("object"==e||"function"==e)}t.exports=n},function(t,e,n){function r(t){var e;if(!i(t)||s.call(t)!=u||a(t)||!f.call(t,"constructor")&&(e=t.constructor,"function"==typeof e&&!(e instanceof e)))return!1;var n;return o(t,function(t,e){n=e}),void 0===n||f.call(t,n)}var o=n(52),a=n(40),i=n(45),u="[object Object]",c=Object.prototype,f=c.hasOwnProperty,s=c.toString;t.exports=r},function(t,e,n){function r(t,e){return o(t,e,a)}var o=n(53),a=n(56);t.exports=r},function(t,e,n){var r=n(54),o=r();t.exports=o},function(t,e,n){function r(t){return function(e,n,r){for(var a=o(e),i=r(e),u=i.length,c=t?u:-1;t?c--:++c0;++r-1&&t%1==0&&e>t}var r=/^\d+$/,o=9007199254740991;t.exports=n},function(t,e,n){function r(t){return a(t)&&o(t.length)&&!!D[S.call(t)]}var o=n(44),a=n(45),i="[object Arguments]",u="[object Array]",c="[object Boolean]",f="[object Date]",s="[object Error]",l="[object Function]",d="[object Map]",h="[object Number]",p="[object Object]",v="[object RegExp]",g="[object Set]",m="[object String]",_="[object WeakMap]",y="[object ArrayBuffer]",x="[object Float32Array]",M="[object Float64Array]",b="[object Int8Array]",R="[object Int16Array]",E="[object Int32Array]",A="[object Uint8Array]",w="[object Uint8ClampedArray]",C="[object Uint16Array]",O="[object Uint32Array]",D={};D[x]=D[M]=D[b]=D[R]=D[E]=D[A]=D[w]=D[C]=D[O]=!0,D[i]=D[u]=D[y]=D[c]=D[f]=D[s]=D[l]=D[d]=D[h]=D[p]=D[v]=D[g]=D[m]=D[_]=!1;var T=Object.prototype,S=T.toString;t.exports=r},function(t,e,n){function r(t){return o(t,a(t))}var o=n(60),a=n(56);t.exports=r},function(t,e){function n(t,e,n){n||(n={});for(var r=-1,o=e.length;++r2?n[i-2]:void 0,c=i>2?n[2]:void 0,f=i>1?n[i-1]:void 0;for("function"==typeof u?(u=o(u,f,5),i-=2):(u="function"==typeof f?f:void 0,i-=u?1:0),c&&a(n[0],n[1],c)&&(u=3>i?void 0:u,i=1);++r0?t.videoWidth>0&&t.videoHeight>0?e():window.setTimeout(n,500):e("Unable to play video stream. Is webcam working?"),r--}var r=10;n()}function a(t,e,n){r(t,function(t){e.src=t,f&&e.removeEventListener("loadeddata",f,!1),f=o.bind(null,e,n),e.addEventListener("loadeddata",f,!1),e.play()},function(t){n(t)})}function i(t,e){var n={audio:!1,video:!0},r=s({width:640,height:480,minAspectRatio:0,maxAspectRatio:100,facing:"environment"},t);return"undefined"==typeof MediaStreamTrack||"undefined"==typeof MediaStreamTrack.getSources?(n.video={mediaSource:"camera",width:{min:r.width,max:r.width},height:{min:r.height,max:r.height},require:["width","height"]},e(n)):void MediaStreamTrack.getSources(function(t){for(var o,a=0;a1?a.size:Math.floor(e/o*a.size):e,r=a.size?e/o>1?Math.floor(o/e*a.size):a.size:o,f.x=n,f.y=r}var n,r,o={},a=null,i=["canrecord","ended"],u={},c={x:0,y:0},f={x:0,y:0};return o.getRealWidth=function(){return t.videoWidth},o.getRealHeight=function(){return t.videoHeight},o.getWidth=function(){return n},o.getHeight=function(){return r},o.setWidth=function(t){n=t},o.setHeight=function(t){r=t},o.setInputStream=function(e){a=e,t.src="undefined"!=typeof e.src?e.src:""},o.ended=function(){return t.ended},o.getConfig=function(){return a},o.setAttribute=function(e,n){t.setAttribute(e,n)},o.pause=function(){t.pause()},o.play=function(){t.play()},o.setCurrentTime=function(e){"LiveStream"!==a.type&&(t.currentTime=e)},o.addEventListener=function(e,n,r){-1!==i.indexOf(e)?(u[e]||(u[e]=[]),u[e].push(n)):t.addEventListener(e,n,r)},o.clearEventHandlers=function(){i.forEach(function(e){var n=u[e];n&&n.length>0&&n.forEach(function(n){t.removeEventListener(e,n)})})},o.trigger=function(t,n){var r,a=u[t];if("canrecord"===t&&e(),a&&a.length>0)for(r=0;r1?i.size:Math.floor(u/c*i.size):u,r=i.size?u/c>1?Math.floor(c/u*i.size):i.size:c,x.x=n,x.y=r,l=!0,f=0,setTimeout(function(){e("canrecord",[])},0)},p,h,i.sequence)}function e(t,e){var n,r=_[t];if(r&&r.length>0)for(n=0;nf?f++:setTimeout(function(){g=!0,e("ended",[])},0)),t):null},o},e["default"]=i,t.exports=e["default"]},function(t,e,n){"use strict";function r(t,e){t.onload=function(){e.loaded(this)}}Object.defineProperty(e,"__esModule",{value:!0});var o={};o.load=function(t,e,n,o,a){var i,u,c,f=new Array(o),s=new Array(f.length);if(a===!1)f[0]=t;else for(i=0;i=n&&parseInt(r[n],10)},detectBrowser:function(){var e={};if(e.browser=null,e.version=null,e.minVersion=null,"undefined"==typeof window||!window.navigator)return e.browser="Not a browser.",e;if(navigator.mozGetUserMedia)e.browser="firefox",e.version=this.extractVersion(navigator.userAgent,/Firefox\/([0-9]+)\./,1),e.minVersion=31;else if(navigator.webkitGetUserMedia&&window.webkitRTCPeerConnection)e.browser="chrome",e.version=this.extractVersion(navigator.userAgent,/Chrom(e|ium)\/([0-9]+)\./,2),e.minVersion=38;else{if(!navigator.mediaDevices||!navigator.userAgent.match(/Edge\/(\d+).(\d+)$/))return e.browser="Not a supported browser.",e;e.browser="edge",e.version=this.extractVersion(navigator.userAgent,/Edge\/(\d+).(\d+)$/,2),e.minVersion=10547}return e.versiona)return Number.MAX_VALUE;r+=o}return r/i},r.prototype._nextSet=function(e,t){var n;for(t=t||0,n=t;n1)for(n=0;nr?(u.start=n-a,u.end=n,u.counter=o,u):null;s++,o[s]=1,c=!c}}else for(o.push(0),n=a;ne?0:e,r=e;t>r;r++)if(this._row[r]!==n)return!1;return!0},r.prototype._fillCounters=function(e,t,n){var r,o=this,i=0,a=[];for(n="undefined"!=typeof n?n:!0,e="undefined"!=typeof e?e:o._nextUnset(o._row),t=t||o._row.length,a[i]=0,r=e;t>r;r++)o._row[r]^n?a[i]++:(i++,a[i]=1,n=!n);return a},Object.defineProperty(r.prototype,"FORMAT",{value:"unknown",writeable:!1}),r.DIRECTION={FORWARD:1,REVERSE:-1},r.Exception={StartNotFoundException:"Start-Info was not found!",CodeNotFoundException:"Code could not be found!",PatternNotFoundException:"Pattern could not be found!"},r.CONFIG_KEYS={},t.a=r},function(e,t,n){function r(e){var t=new Float32Array(2);return t[0]=e[0],t[1]=e[1],t}e.e=r},function(e,t,n){function r(e){return!!e&&"object"==typeof e}e.e=r},function(e,t,n){t.a={init:function(e,t){for(var n=e.length;n--;)e[n]=t},shuffle:function(e){var t,n,r=e.length-1;for(r;r>=0;r--)t=Math.floor(Math.random()*r),n=e[r],e[r]=e[t],e[t]=n;return e},toPointList:function(e){var t,n,r=[],o=[];for(t=0;t=t&&o.push(e[r]);return o},maxIndex:function(e){var t,n=0;for(t=0;te[n]&&(n=t);return n},max:function r(e){var t,r=0;for(t=0;tr&&(r=e[t]);return r},sum:function o(e){for(var t=e.length,o=0;t--;)o+=e[t];return o}}},function(e,t,n){t.a={drawRect:function(e,t,n,r){n.strokeStyle=r.color,n.fillStyle=r.color,n.lineWidth=1,n.beginPath(),n.strokeRect(e.x,e.y,t.x,t.y)},drawPath:function(e,t,n,r){n.strokeStyle=r.color,n.fillStyle=r.color,n.lineWidth=r.lineWidth,n.beginPath(),n.moveTo(e[0][t.x],e[0][t.y]);for(var o=1;or;r++)o=c._matchPattern(i,c.CODE_PATTERN[r]),oc.AVG_CODE_ERROR?null:d}}else f++;a[f]=1,u=!u}return null},r.prototype._findPattern=function(e,t,n,r,o){var i,a,c,s,u,f=[],d=this,l=0,p={error:Number.MAX_VALUE,code:-1,start:0,end:0};for(t||(t=d._nextSet(d._row)),void 0===n&&(n=!1),void 0===r&&(r=!0),void 0===o&&(o=d.AVG_CODE_ERROR),i=0;ia))return p.error=a,p.start=i-s,p.end=i,p;if(!r)return null;for(c=0;c=0&&n._matchRange(e,t.start,0))return t;r=t.end,t=null}},r.prototype._verifyTrailingWhitespace=function(e){var t,n=this;return t=e.end+(e.end-e.start),tr;r++){if(e=i._decodeCode(e.end),!e)return null;e.code>=i.CODE_G_START?(e.code=e.code-i.CODE_G_START,a|=1<<5-r):a|=0<<5-r,t.push(e.code),n.push(e)}if(o=i._calculateFirstDigit(a),null===o)return null;if(t.unshift(o),e=i._findPattern(i.MIDDLE_PATTERN,e.end,!0,!1),null===e)return null;for(n.push(e),r=0;6>r;r++){if(e=i._decodeCode(e.end,i.CODE_G_START),!e)return null;n.push(e),t.push(e.code)}return e},r.prototype._decode=function(){var e,t,n=this,r=[],o=[];return(e=n._findStart())?(t={code:e.code,start:e.start,end:e.end},o.push(t),(t=n._decodePayload(t,r,o))&&(t=n._findEnd(t.end,!1))?(o.push(t),n._checksum(r)?{code:r.join(""),start:e.start,end:t.end,codeset:"",startInfo:e,decodedCodes:o}:null):null):null},r.prototype._checksum=function(e){var t,n=0;for(t=e.length-2;t>=0;t-=2)n+=e[t];for(n*=3,t=e.length-1;t>=0;t-=2)n+=e[t];return n%10===0},t.a=r},function(e,t,n){function r(e,t){for(var n=e.length;n--;)if(o(e[n][0],t))return n;return-1}var o=n(15);e.e=r},function(e,t,n){function r(e,t){var n=e[t];return o(n)?n:void 0}var o=n(140);e.e=r},function(e,t,n){function r(e){var t=typeof e;return"number"==t||"boolean"==t||"string"==t&&"__proto__"!=e||null==e}e.e=r},function(e,t,n){var r=n(12),o=r(Object,"create");e.e=o},function(e,t,n){function r(e,t){return e===t||e!==e&&t!==t}e.e=r},function(e,t,n){function r(e){var t=o(e)?s.call(e):"";return t==i||t==a}var o=n(2),i="[object Function]",a="[object GeneratorFunction]",c=Object.prototype,s=c.toString;e.e=r},function(e,t,n){function r(e,t){var n={x:e,y:t,toVec2:function(){return w.clone([this.x,this.y])},toVec3:function(){return C.clone([this.x,this.y,1])},round:function(){return this.x=this.x>0?Math.floor(this.x+.5):Math.floor(this.x-.5),this.y=this.y>0?Math.floor(this.y+.5):Math.floor(this.y-.5),this}};return n}function o(e,t,n){n||(n=e);for(var r=e.data,o=r.length,i=n.data;o--;)i[o]=r[o]>o]++;return a}function a(e,t){function n(e,t){var n,r=0;for(n=e;t>=n;n++)r+=a[n];return r}function r(e,t){var n,r=0;for(n=e;t>=n;n++)r+=n*a[n];return r}function o(){var o,c,s,u,f,d,l,p=[0],h=(1<u;u++)o=n(0,u),c=n(u+1,h),s=o*c,0===s&&(s=1),f=r(0,u)*c,d=r(u+1,h)*o,l=f-d,p[u]=l*l/s;return _.a.maxIndex(p)}t||(t=8);var a,c,s=8-t;return c=o(),c<r;r++)u[r]={score:0,item:null};for(r=0;rs)for(i=u[c],i.score=o,i.item=e[r],s=Number.MAX_VALUE,a=0;t>a;a++)u[a].scorei;){for(r=0;c>r;r++)n[s]=Math.floor((.299*e[4*o+0]+.587*e[4*o+1]+.114*e[4*o+2]+(.299*e[4*(o+1)+0]+.587*e[4*(o+1)+1]+.114*e[4*(o+1)+2])+(.299*e[4*i+0]+.587*e[4*i+1]+.114*e[4*i+2])+(.299*e[4*(i+1)+0]+.587*e[4*(i+1)+1]+.114*e[4*(i+1)+2]))/4),s++,o+=2,i+=2;o+=u,i+=u}}function d(e,t,n){var r,o=e.length/4|0,i=n&&n.singleChannel===!0;if(i)for(r=0;o>r;r++)t[r]=e[4*r+0];else for(r=0;o>r;r++)t[r]=Math.floor(.299*e[4*r+0]+.587*e[4*r+1]+.114*e[4*r+2])}function l(e,t){for(var n=e.data,r=e.size.x,o=t.data,i=0,a=r,c=n.length,s=r/2,u=0;c>a;){for(var f=0;s>f;f++)o[u]=Math.floor((n[i]+n[i+1]+n[a]+n[a+1])/4),u++,i+=2,a+=2;i+=r,a+=r}}function p(e,t){var n=e[0],r=e[1],o=e[2],i=o*r,a=i*(1-Math.abs(n/60%2-1)),c=o-i,s=0,u=0,f=0;return t=t||[0,0,0],60>n?(s=i,u=a):120>n?(s=a,u=i):180>n?(u=i,f=a):240>n?(u=a,f=i):300>n?(s=a,f=i):360>n&&(s=i,f=a),t[0]=255*(s+c)|0,t[1]=255*(u+c)|0,t[2]=255*(f+c)|0,t}function h(e){var t,n=[],r=[];for(t=1;tt[r]?r++:n++;return o}function g(e,t){function n(e){for(var t=0,n=e[Math.floor(e.length/2)];t0&&(n=Math.abs(e[t]-l)>Math.abs(e[t-1]-l)?e[t-1]:e[t]),l/ns[f-1]/s[f]?{x:n,y:n}:null}var r,o=h(t.x),i=h(t.y),a=Math.max(t.x,t.y),c=v(o,i),s=[8,10,15,20,32,60,80],u={"x-small":5,small:4,medium:3,large:2,"x-large":1},f=u[e]||u.medium,d=s[f],l=Math.floor(a/d);return r=n(c),r||(r=n(h(a)),r||(r=n(h(l*d)))),r}function m(e){var t={value:parseFloat(e),unit:(e.indexOf("%")===e.length-1,"%")};return t}function y(e,t,n){var r={width:e,height:t},o=Object.keys(n).reduce(function(e,t){var o=n[t],i=m(o),a=E[t](i,r);return e[t]=a,e},{});return{sx:o.left,sy:o.top,sw:o.right-o.left,sh:o.bottom-o.top}}var b=n(51),_=n(8);t.f=r,t.c=c,t.d=s,t.e=u,t.i=f,t.j=d,t.g=l,t.a=p,t.b=g,t.h=y;var w={clone:n(6)},C={clone:n(78)},E={top:function(e,t){return"%"===e.unit?Math.floor(t.height*(e.value/100)):void 0},right:function(e,t){return"%"===e.unit?Math.floor(t.width-t.width*(e.value/100)):void 0},bottom:function(e,t){return"%"===e.unit?Math.floor(t.height-t.height*(e.value/100)):void 0},left:function(e,t){return"%"===e.unit?Math.floor(t.width*(e.value/100)):void 0}}},function(e,t,n){function r(e,t,n,r){t?this.data=t:n?(this.data=new n(e.x*e.y),n===Array&&r&&a.a.init(this.data,0)):(this.data=new Uint8Array(e.x*e.y),Uint8Array===Array&&r&&a.a.init(this.data,0)),this.size=e}var o=n(53),i=n(17),a=n(8),c={clone:n(6)};r.prototype.inImageWithBorder=function(e,t){return e.x>=t&&e.y>=t&&e.xn;n++)for(r=0;o>r;r++)e.data[r*i+n]=this.data[(t.y+r)*this.size.x+t.x+n]},r.prototype.copyTo=function(e){for(var t=this.data.length,n=this.data,r=e.data;t--;)r[t]=n[t]},r.prototype.get=function(e,t){return this.data[t*this.size.x+e]},r.prototype.getSafe=function(e,t){var n;if(!this.indexMapping){for(this.indexMapping={x:[],y:[]},n=0;ne;e++)r[e]=r[(n-1)*t+e]=0;for(e=1;n-1>e;e++)r[e*t]=r[e*t+(t-1)]=0},r.prototype.invert=function(){for(var e=this.data,t=e.length;t--;)e[t]=e[t]?0:1},r.prototype.convolve=function(e){var t,n,r,o,i=e.length/2|0,a=0;for(n=0;n=o;o++)for(r=-i;i>=r;r++)a+=e[o+i][r+i]*this.getSafe(t+r,n+o);this.data[n*this.size.x+t]=a}},r.prototype.moments=function(e){var t,n,r,o,i,a,s,u,f,d,l,p,h=this.data,v=this.size.y,g=this.size.x,m=[],y=[],b=Math.PI,_=b/4;if(0>=e)return y;for(i=0;e>i;i++)m[i]={m00:0,m01:0,m10:0,m11:0,m02:0,m20:0,theta:0,rad:0};for(n=0;v>n;n++)for(o=n*n,t=0;g>t;t++)r=h[n*g+t],r>0&&(a=m[r-1],a.m00+=1,a.m01+=n,a.m10+=t,a.m11+=t*n,a.m02+=o,a.m20+=t*t);for(i=0;e>i;i++)a=m[i],isNaN(a.m00)||0===a.m00||(d=a.m10/a.m00,l=a.m01/a.m00,s=a.m11/a.m00-d*l,u=a.m02/a.m00-l*l,f=a.m20/a.m00-d*d,p=(u-f)/(2*s),p=.5*Math.atan(p)+(s>=0?_:-_)+b,a.theta=(180*p/b+90)%180-90,a.theta<0&&(a.theta+=180),a.rad=p>b?p-b:p,a.vec=c.clone([Math.cos(p),Math.sin(p)]),y.push(a));return y},r.prototype.show=function(e,t){var n,r,o,i,a,c,s;for(t||(t=1),n=e.getContext("2d"),e.width=this.size.x,e.height=this.size.y,r=n.getImageData(0,0,e.width,e.height),o=r.data,i=0,s=0;st||t>360)&&(t=360);for(var r=[0,1,1],o=[0,0,0],a=[255,255,255],c=[0,0,0],s=[],u=e.getContext("2d"),f=u.getImageData(n.x,n.y,this.size.x,this.size.y),d=f.data,l=this.data.length;l--;)r[0]=this.data[l]*t,s=r[0]<=0?a:r[0]>=360?c:i.a.bind()(r,o),d[4*l+0]=s[0],d[4*l+1]=s[1],d[4*l+2]=s[2],d[4*l+3]=255;u.putImageData(f,n.x,n.y)},t.a=r},function(e,t,n){function r(e,t,n,r){var o=-1,i=e.length;for(r&&i&&(n=e[++o]);++o-1&&e%1==0&&t>e}var o=9007199254740991,i=/^(?:0|[1-9]\d*)$/;e.e=r},function(e,t,n){function r(e){var t=e&&e.constructor,n="function"==typeof t&&t.prototype||o;return e===n}var o=Object.prototype;e.e=r},function(e,t,n){function r(e){return o(e)&&c.call(e,"callee")&&(!u.call(e,"callee")||s.call(e)==i)}var o=n(26),i="[object Arguments]",a=Object.prototype,c=a.hasOwnProperty,s=a.toString,u=a.propertyIsEnumerable;e.e=r},function(e,t,n){function r(e){return null!=e&&a(o(e))&&!i(e)}var o=n(115),i=n(16),a=n(27);e.e=r},function(e,t,n){function r(e){return i(e)&&o(e)}var o=n(25),i=n(7);e.e=r},function(e,t,n){function r(e){return"number"==typeof e&&e>-1&&e%1==0&&o>=e}var o=9007199254740991;e.e=r},function(e,t,n){var r=n(99),o=n(113),i=o(function(e,t,n){r(e,t,n)});e.e=i},function(e,t,n){var r={searchDirections:[[0,1],[1,1],[1,0],[1,-1],[0,-1],[-1,-1],[-1,0],[-1,1]],create:function(e,t){function n(e,t,n,r){var o,f,d;for(o=0;7>o;o++){if(f=e.cy+s[e.dir][0],d=e.cx+s[e.dir][1],i=f*u+d,a[i]===t&&(0===c[i]||c[i]===n))return c[i]=n,e.cy=f,e.cx=d,!0;0===c[i]&&(c[i]=r),e.dir=(e.dir+1)%8}return!1}function r(e,t,n){return{dir:n,x:e,y:t,next:null,prev:null}}function o(e,t,o,i,a){var c,s,u,f=null,d={cx:t,cy:e,dir:0};if(n(d,i,o,a)){f=r(t,e,d.dir),c=f,u=d.dir,s=r(d.cx,d.cy,0),s.prev=c,c.next=s,s.next=null,c=s;do d.dir=(d.dir+6)%8,n(d,i,o,a),u!==d.dir?(c.dir=d.dir,s=r(d.cx,d.cy,0),s.prev=c,c.next=s,s.next=null,c=s):(c.dir=u,c.x=d.cx,c.y=d.cy),u=d.dir;while(d.cx!==t||d.cy!==e);f.prev=c.prev,c.prev.next=f}return f}var i,a=e.data,c=t.data,s=this.searchDirections,u=e.size.x;return{trace:function(e,t,r,o){return n(e,t,r,o)},contourTracing:function(e,t,n,r,i){return o(e,t,n,r,i)}}}};t.a=r},function(e,t,n){function r(){o.a.call(this)}var o=n(5),i=n(8),a={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:[52,289,97,352,49,304,112,37,292,100,265,73,328,25,280,88,13,268,76,28,259,67,322,19,274,82,7,262,70,22,385,193,448,145,400,208,133,388,196,148,168,162,138,42]},ASTERISK:{value:148},FORMAT:{value:"code_39",writeable:!1}};r.prototype=Object.create(o.a.prototype,a),r.prototype.constructor=r,r.prototype._toCounters=function(e,t){var n,r=this,o=t.length,a=r._row.length,c=!r._row[e],s=0;for(i.a.init(t,0),n=e;a>n;n++)if(r._row[n]^c)t[s]++;else{if(s++,s===o)break;t[s]=1,c=!c}return t},r.prototype._decode=function(){var e,t,n,r,o=this,a=[0,0,0,0,0,0,0,0,0],c=[],s=o._findStart();if(!s)return null;r=o._nextSet(o._row,s.end);do{if(a=o._toCounters(r,a),n=o._toPattern(a),0>n)return null;if(e=o._patternToChar(n),0>e)return null;c.push(e),t=r,r+=i.a.sum(a),r=o._nextSet(o._row,r)}while("*"!==e);return c.pop(),c.length&&o._verifyTrailingWhitespace(t,r,a)?{code:c.join(""),start:s.start,end:r,startInfo:s,decodedCodes:c}:null},r.prototype._verifyTrailingWhitespace=function(e,t,n){var r,o=i.a.sum(n);return r=t-e-o,3*r>=o},r.prototype._patternToChar=function(e){var t,n=this;for(t=0;tt&&(r=e[n]);return r},r.prototype._toPattern=function(e){for(var t,n,r=e.length,o=0,i=r,a=0,c=this;i>3;){for(o=c._findNextWidth(e,o),i=0,t=0,n=0;r>n;n++)e[n]>o&&(t|=1<n&&i>0;n++)if(e[n]>o&&(i--,2*e[n]>=a))return-1;return t}}return-1},r.prototype._findStart=function(){var e,t,n,r=this,o=r._nextSet(r._row),i=o,a=[0,0,0,0,0,0,0,0,0],c=0,s=!1;for(e=o;et;t++)a[t]=a[t+2];a[7]=0,a[8]=0,c--}else c++;a[c]=1,s=!s}return null},t.a=r},function(e,t,n){function r(e,t){return e[0]*t[0]+e[1]*t[1]}e.e=r},function(e,t,n){function r(e){var t=-1,n=e?e.length:0;for(this.clear();++tn)return!1;var r=e.length-1;return n==r?e.pop():a.call(e,n,1),!0}var o=n(11),i=Array.prototype,a=i.splice;e.e=r},function(e,t,n){function r(e,t){var n=o(e,t);return 0>n?void 0:e[n][1]}var o=n(11);e.e=r},function(e,t,n){function r(e,t){return o(e,t)>-1}var o=n(11);e.e=r},function(e,t,n){function r(e,t,n){var r=o(e,t);0>r?e.push([t,n]):e[r][1]=n}var o=n(11);e.e=r},function(e,t,n){function r(e){var t=new e.constructor(e.byteLength);return new o(t).set(new o(e)),t}var o=n(84);e.e=r},function(e,t,n){function r(e,t){var n=-1,r=e.length;for(t||(t=Array(r));++n0)for(r=0;r0){if(e=Y.filter(function(e){return!e.busy})[0],!e)return;M.attachData(e.imageData)}else M.attachData(k.data);M.grab()&&(e?(e.busy=!0,e.worker.postMessage({cmd:"process",imageData:e.imageData},[e.imageData.buffer])):g())}else g()}function y(){var e=null,t=1e3/(J.frequency||60);j=!1,function n(r){e=e||r,j||(r>=e&&(e+=t,m()),window.requestAnimFrame(n))}(performance.now())}function b(){K&&"LiveStream"===J.inputStream.type?y():m()}function _(e){var t,n={worker:void 0,imageData:new Uint8Array(A.getWidth()*A.getHeight()),busy:!0};t=C(),n.worker=new Worker(t),n.worker.onmessage=function(r){return"initialized"===r.data.event?(URL.revokeObjectURL(t),n.busy=!1,n.imageData=new Uint8Array(r.data.imageData),e(n)):void("processed"===r.data.event?(n.imageData=new Uint8Array(r.data.imageData),n.busy=!1,v(r.data.result,n.imageData)):"error"===r.data.event)},n.worker.postMessage({cmd:"init",size:{x:A.getWidth(),y:A.getHeight()},imageData:n.imageData,config:J},[n.imageData.buffer])}function w(e){function t(e){self.postMessage({event:"processed",imageData:o.data,result:e},[o.data.buffer])}function n(){self.postMessage({event:"initialized",imageData:o.data},[o.data.buffer])}if(e){var r=e()["default"];if(!r)return void self.postMessage({event:"error",message:"Quagga could not be created"})}var o;self.onmessage=function(e){if("init"===e.data.cmd){var i=e.data.config;i.numOfWorkers=0,o=new r.ImageWrapper({x:e.data.size.x,y:e.data.size.y},new Uint8Array(e.data.imageData)),r.init(i,n,o),r.onProcessed(t)}else"process"===e.data.cmd?(o.data=new Uint8Array(e.data.imageData),r.start()):"setReaders"===e.data.cmd&&r.setReaders(e.data.readers)}}function C(){var t,n;return"undefined"!=typeof e&&(n=e),t=new Blob(["("+w.toString()+")("+n+");"],{type:"text/javascript"}),window.URL.createObjectURL(t)}function E(e){z?z.setReaders(e):K&&Y.length>0&&Y.forEach(function(t){t.worker.postMessage({cmd:"setReaders",readers:e})})}function R(e,t){var n=e-Y.length;if(0===n)return t&&t();if(0>n){var r=Y.slice(n);return r.forEach(function(e){e.worker.terminate()}),Y=Y.slice(0,n),t&&t()}for(var o=function(n){Y.push(n),Y.length>=e&&t&&t()},i=0;n>i;i++)_(o)}var S=r(28),T=S&&S.__esModule?function(){return S["default"]}:function(){return S};Object.defineProperty(T,"a",{get:T});var x=r(54),O=x&&x.__esModule?function(){return x["default"]}:function(){return x};Object.defineProperty(O,"a",{get:O});var D=r(147),P=D&&D.__esModule?function(){return D["default"]}:function(){return D};Object.defineProperty(P,"a",{get:P});var A,M,j,k,I,z,L,N=r(18),U=r(63),F=r(57),G=r(52),B=r(59),W=r(9),V=r(50),H=r(55),q=r(62),X=r(60),$={clone:r(6)},Q={ctx:{image:null,overlay:null},dom:{image:null,overlay:null}},Y=[],K=!0,J={};n["default"]={init:function(e,t,n){return J=T.a.bind()({},H.a,e),n?(K=!1,o(n),t()):void i(t)},start:function(){b()},stop:function(){j=!0,R(0),"LiveStream"===J.inputStream.type&&(B.a.release(),A.clearEventHandlers())},pause:function(){j=!0},onDetected:function(e){G.a.subscribe("detected",e)},offDetected:function(e){G.a.unsubscribe("detected",e)},onProcessed:function(e){G.a.subscribe("processed",e)},offProcessed:function(e){G.a.unsubscribe("processed",e)},setReaders:function(e){E(e)},registerResultCollector:function(e){e&&"function"==typeof e.addResult&&(L=e)},canvas:Q,decodeSingle:function(e,t){var n=this;e=T.a.bind()({inputStream:{type:"ImageStream",sequence:!1,size:800,src:e.src},numOfWorkers:1,locator:{halfSample:!1}},e),this.init(e,function(){G.a.once("processed",function(e){n.stop(),t.call(null,e)},!0),b()})},ImageWrapper:N.a,ImageDebug:W.a,ResultCollector:V.a}},function(e,t,n){function r(e,t){return t?t.some(function(t){return Object.keys(t).every(function(n){return t[n]===e[n]})}):!1}function o(e,t){return"function"==typeof t?t(e):!0}var i=n(9);t.a={create:function(e){function t(t){return s&&t&&!r(t,e.blacklist)&&o(t,e.filter)}var n=document.createElement("canvas"),a=n.getContext("2d"),c=[],s=e.capacity||20,u=e.capture===!0; +return{addResult:function(e,r,o){var f={};t(o)&&(s--,f.codeResult=o,u&&(n.width=r.x,n.height=r.y,i.a.drawImage(e,r,a),f.frame=n.toDataURL()),c.push(f))},getResults:function(){return c}}}}},function(e,t,n){var r={clone:n(6),dot:n(31)};t.a={create:function(e,t){function n(){o(e),i()}function o(e){s[e.id]=e,a.push(e)}function i(){var e,t=0;for(e=0;et},getPoints:function(){return a},getCenter:function(){return c}}},createPoint:function(e,t,n){return{rad:e[n],point:e,id:t}}}},function(e,t,n){t.a=function(){function e(e){return o[e]||(o[e]={subscribers:[]}),o[e]}function t(){o={}}function n(e,t){e.async?setTimeout(function(){e.callback(t)},4):e.callback(t)}function r(t,n,r){var o;if("function"==typeof n)o={callback:n,async:r};else if(o=n,!o.callback)throw"Callback was not specified on options";e(t).subscribers.push(o)}var o={};return{subscribe:function(e,t,n){return r(e,t,n)},publish:function(t,r){var o=e(t),i=o.subscribers;o.subscribers=i.filter(function(e){return n(e,r),!e.once})},once:function(e,t,n){r(e,{callback:t,async:n,once:!0})},unsubscribe:function(n,r){var o;n?(o=e(n),o&&r?o.subscribers=o.subscribers.filter(function(e){return e.callback!==r}):o.subscribers=[]):t()}}}()},function(e,t,n){function r(e,t,n){n||(n={data:null,size:t}),this.data=n.data,this.originalSize=n.size,this.I=n,this.from=e,this.size=t}r.prototype.show=function(e,t){var n,r,o,i,a,c,s;for(t||(t=1),n=e.getContext("2d"),e.width=this.size.x,e.height=this.size.y,r=n.getImageData(0,0,e.width,e.height),o=r.data,i=0,a=0;a>>16&65535,r=65535&e,o=t>>>16&65535,i=65535&t;return r*i+(n*i+r*o<<16>>>0)|0}},function(e,t,n){var r=void 0;r=n(56),t.a=r},function(e,t,n){e.e={inputStream:{name:"Live",type:"LiveStream",constraints:{width:640,height:480,facingMode:"environment"},area:{top:"0%",right:"0%",left:"0%",bottom:"0%"},singleChannel:!1},locate:!0,numOfWorkers:4,decoder:{readers:["code_128_reader"]},locator:{halfSample:!0,patchSize:"medium"}}},function(e,t,n){var r=n(58),o=(n(9),n(67)),i=n(10),a=n(30),c=n(68),s=n(66),u=n(72),f=n(69),d=n(71),l=n(70),p="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},h={code_128_reader:o.a,ean_reader:i.a,ean_8_reader:f.a,code_39_reader:a.a,code_39_vin_reader:c.a,codabar_reader:s.a,upc_reader:u.a,upc_e_reader:d.a,i2of5_reader:l.a};t.a={create:function(e,t){function n(){}function o(){e.readers.forEach(function(e){var t,n={};"object"===("undefined"==typeof e?"undefined":p(e))?(t=e.format,n=e.config):"string"==typeof e&&(t=e),v.push(new h[t](n))})}function i(){}function a(e,n,r){function o(t){var r={y:t*Math.sin(n),x:t*Math.cos(n)};e[0].y-=r.y,e[0].x-=r.x,e[1].y+=r.y,e[1].x+=r.x}for(o(r);r>1&&(!t.inImageWithBorder(e[0],0)||!t.inImageWithBorder(e[1],0));)r-=Math.ceil(r/2),o(-r);return e}function c(e){return[{x:(e[1][0]-e[0][0])/2+e[0][0],y:(e[1][1]-e[0][1])/2+e[0][1]},{x:(e[3][0]-e[2][0])/2+e[2][0],y:(e[3][1]-e[2][1])/2+e[2][1]}]}function s(e){var n,o=null,i=r.a.getBarcodeLine(t,e[0],e[1]);for(r.a.toBinaryLine(i),n=0;nr&&null===u;r++)o=a/c*r*(r%2===0?-1:1),i={y:o*f,x:o*d},t[0].y+=i.x,t[0].x-=i.y,t[1].y+=i.x,t[1].x-=i.y,u=s(t);return u}function f(e){return Math.sqrt(Math.pow(Math.abs(e[1].y-e[0].y),2)+Math.pow(Math.abs(e[1].x-e[0].x),2))}function d(e){var t,n,r,o;l.ctx.overlay;return t=c(e),o=f(t),n=Math.atan2(t[1].y-t[0].y,t[1].x-t[0].x),t=a(t,n,Math.floor(.1*o)),null===t?null:(r=s(t),null===r&&(r=u(e,t,n)),null===r?null:{codeResult:r.codeResult,line:t,angle:n,pattern:r.barcodeLine.line,threshold:r.barcodeLine.threshold})}var l={ctx:{frequency:null,pattern:null,overlay:null},dom:{frequency:null,pattern:null,overlay:null}},v=[];return n(),o(),i(),{decodeFromBoundingBox:function(e){return d(e)},decodeFromBoundingBoxes:function(t){var n,r,o=[],i=e.multiple;for(n=0;nd?d:w,C=d>C?d:C,m.push(d)}var o,i,a,c,s,u,f,d,l=0|t.x,p=0|t.y,h=0|n.x,v=0|n.y,g=Math.abs(v-p)>Math.abs(h-l),m=[],y=e.data,b=e.size.x,_=0,w=255,C=0;for(g&&(u=l,l=p,p=u,u=h,h=v,v=u),l>h&&(u=l,l=h,h=u,u=p,p=v,v=u),o=h-l,i=Math.abs(v-p),a=o/2|0,s=p,c=v>p?1:-1,f=l;h>f;f++)g?r(s,f):r(f,s),a-=i,0>a&&(s+=c,a+=o);return{line:m,min:w,max:C}},r.toBinaryLine=function(e){var t,n,r,i,a,c,s=e.min,u=e.max,f=e.line,d=s+(u-s)/2,l=[],p=(u-s)/12,h=-p;for(r=f[0]>d?o.DIR.UP:o.DIR.DOWN,l.push({pos:0,val:f[0]}),a=0;at+n&&f[a+1]<1.5*d?o.DIR.DOWN:t+n>p&&f[a+1]>.5*d?o.DIR.UP:r,r!==i&&(l.push({pos:a,val:f[a]}),r=i);for(l.push({pos:f.length,val:f[f.length-1]}),c=l[0].pos;cd?0:1;for(a=1;al[a].val?l[a].val+(l[a+1].val-l[a].val)/3*2|0:l[a+1].val+(l[a].val-l[a+1].val)/3|0,c=l[a].pos;cp?0:1;return{line:f,threshold:p}},r.debug={printFrequency:function(e,t){var n,r=t.getContext("2d");for(t.width=e.length,t.height=256,r.beginPath(),r.strokeStyle="blue",n=0;n0?e.videoWidth>0&&e.videoHeight>0?t():window.setTimeout(r,500):n("Unable to play video stream. Is webcam working?"),o--}var o=10;r()})}function o(e,t){return navigator.mediaDevices.getUserMedia(t).then(function(t){return new Promise(function(n,r){l=t,e.src=window.URL.createObjectURL(t),e.onloadedmetadata=function(t){e.play(),n()}})}).then(r.bind(null,e))}function i(e){var t=u.a.bind()(e,["width","height","facingMode","aspectRatio","deviceId"]);return"undefined"!=typeof e.minAspectRatio&&e.minAspectRatio>0&&(t.aspectRatio=e.minAspectRatio,console.log("WARNING: Constraint 'minAspectRatio' is deprecated; Use 'aspectRatio' instead")),"undefined"!=typeof e.facing&&(t.facingMode=e.facing,console.log("WARNING: Constraint 'facing' is deprecated. Use 'facingMode' instead'")),t}function a(e,t){return"undefined"==typeof t.video.deviceId&&e?"undefined"!=typeof MediaStreamTrack&&"undefined"!=typeof MediaStreamTrack.getSources?new Promise(function(n,r){MediaStreamTrack.getSources(function(r){var o=r.filter(function(t){return"video"===t.kind&&t.facing===e})[0];return n(o?d.a.bind()({},t,{video:{deviceId:o.id}}):t)})}):Promise.resolve(d.a.bind()({},t,{video:{facingMode:e}})):Promise.resolve(t)}function c(e){var t={audio:!1,video:i(e)};return a(t.video.facingMode,t)}var s=n(143),u=s&&s.__esModule?function(){return s["default"]}:function(){return s};Object.defineProperty(u,"a",{get:u});var f=n(28),d=f&&f.__esModule?function(){return f["default"]}:function(){return f};Object.defineProperty(d,"a",{get:d});var l;t.a={request:function(e,t){return c(t).then(o.bind(null,e))},release:function(){var e=l&&l.getVideoTracks();e&&e.length&&e[0].stop(),l=null}}},function(e,t,n){var r=n(17),o={};o.create=function(e,t){var n,o={},i=e.getConfig(),a=(r.f.bind()(e.getRealWidth(),e.getRealHeight()),e.getCanvasSize()),c=r.f.bind()(e.getWidth(),e.getHeight()),s=e.getTopRight(),u=s.x,f=s.y,d=null,l=null;return n=t?t:document.createElement("canvas"),n.width=a.x,n.height=a.y,d=n.getContext("2d"),l=new Uint8Array(c.x*c.y),o.attachData=function(e){l=e},o.getData=function(){return l},o.grab=function(){var t,n=i.halfSample,o=e.getFrame();return o?(d.drawImage(o,0,0,a.x,a.y),t=d.getImageData(u,f,c.x,c.y).data,n?r.i.bind()(t,c,l):r.j.bind()(t,l,i),!0):!1},o.getSize=function(){return c},o},t.a=o},function(e,t,n){function r(e,t){e.onload=function(){t.loaded(this)}}var o={};o.load=function(e,t,n,o,i){var a,c,s,u=new Array(o),f=new Array(u.length);if(i===!1)u[0]=e;else for(a=0;a1?i.size:Math.floor(t/o*i.size):t,r=i.size?t/o>1?Math.floor(o/t*i.size):i.size:o,u.x=n,u.y=r}var n,r,o={},i=null,a=["canrecord","ended"],c={},s={x:0,y:0},u={x:0,y:0};return o.getRealWidth=function(){return e.videoWidth},o.getRealHeight=function(){return e.videoHeight},o.getWidth=function(){return n},o.getHeight=function(){return r},o.setWidth=function(e){n=e},o.setHeight=function(e){r=e},o.setInputStream=function(t){i=t,e.src="undefined"!=typeof t.src?t.src:""},o.ended=function(){return e.ended},o.getConfig=function(){return i},o.setAttribute=function(t,n){e.setAttribute(t,n)},o.pause=function(){e.pause()},o.play=function(){e.play()},o.setCurrentTime=function(t){"LiveStream"!==i.type&&(e.currentTime=t)},o.addEventListener=function(t,n,r){-1!==a.indexOf(t)?(c[t]||(c[t]=[]),c[t].push(n)):e.addEventListener(t,n,r)},o.clearEventHandlers=function(){a.forEach(function(t){var n=c[t];n&&n.length>0&&n.forEach(function(n){e.removeEventListener(t,n)})})},o.trigger=function(e,n){var r,i=c[e];if("canrecord"===e&&t(),i&&i.length>0)for(r=0;r1?a.size:Math.floor(c/s*a.size):c,o=a.size?c/s>1?Math.floor(s/c*a.size):a.size:s,_.x=n,_.y=o,d=!0,u=0,setTimeout(function(){t("canrecord",[])},0)},h,p,a.sequence)}function t(e,t){var n,r=y[e];if(r&&r.length>0)for(n=0;nu?u++:setTimeout(function(){g=!0,t("ended",[])},0)),e):null},i},t.a=o},function(e,t,n){(function(e){function r(){var t;v=h.halfSample?new T.a({x:R.size.x/2|0,y:R.size.y/2|0}):R,E=x.b.bind()(h.patchSize,v.size),I.x=v.size.x/E.x|0,I.y=v.size.y/E.y|0,C=new T.a(v.size,void 0,Uint8Array,!1),y=new T.a(E,void 0,Array,!0),t=new ArrayBuffer(65536),m=new T.a(E,new Uint8Array(t,0,E.x*E.y)),g=new T.a(E,new Uint8Array(t,E.x*E.y*3,E.x*E.y),void 0,!0),S=A.a.bind()("undefined"!=typeof window?window:"undefined"!=typeof self?self:e,{size:E.x},t),w=new T.a({x:v.size.x/m.size.x|0,y:v.size.y/m.size.y|0},void 0,Array,!0),b=new T.a(w.size,void 0,void 0,!0),_=new T.a(w.size,void 0,Int32Array,!0)}function o(){h.useWorker||"undefined"==typeof document||(k.dom.binary=document.createElement("canvas"),k.dom.binary.className="binaryBuffer",k.ctx.binary=k.dom.binary.getContext("2d"),k.dom.binary.width=C.size.x,k.dom.binary.height=C.size.y)}function i(e){var t,n,r,o,i,a,c,s=C.size.x,u=C.size.y,f=-C.size.x,d=-C.size.y;for(t=0,n=0;nt&&(t+=180),t=(180-t)*Math.PI/180,i=j.copy(j.create(),[Math.cos(t),Math.sin(t),-Math.sin(t),Math.cos(t)]),n=0;nr;r++)M.transformMat2(o.box[r],o.box[r],i);for(n=0;nr;r++)o.box[r][0]f&&(f=o.box[r][0]),o.box[r][1]d&&(d=o.box[r][1]);for(a=[[s,u],[f,u],[f,d],[s,d]],c=h.halfSample?2:1,i=j.invert(i,i),r=0;4>r;r++)M.transformMat2(a[r],a[r],i);for(r=0;4>r;r++)M.scale(a[r],a[r],c);return a}function a(){x.c.bind()(v,C),C.zeroBorder(),h.showCanvas&&C.show(k.dom.binary,255)}function c(){var e,t,n,r,o,i,a,c=[];for(e=0;et;t++)r.push(0);for(n=_.data.length;n--;)_.data[n]>0&&r[_.data[n]-1]++;return r=r.map(function(e,t){return{val:e,label:t+1}}),r.sort(function(e,t){return t.val-e.val}),o=r.filter(function(e){return e.val>=5})}function u(e,t){var n,r,o,a,c=[],s=[];for(n=0;n=2){for(o=0;od&&s.push(e[o]);if(s.length>=2){for(a=f(s),i=0,o=0;o1&&a.length>=s.length/4*3&&a.length>e.length/4&&(i/=a.length,c={index:t[1]*I.x+t[0],pos:{x:n,y:r},box:[M.clone([n,r]),M.clone([n+m.size.x,r]),M.clone([n+m.size.x,r+m.size.y]),M.clone([n,r+m.size.y])],moments:a,rad:i,vec:M.clone([Math.cos(i),Math.sin(i)])},u.push(c))}}return u}function p(e){function t(){var e;for(e=0;e<_.data.length;e++)if(0===_.data[e]&&1===b.data[e])return e;return _.length}function n(e){var t,r,o,c,s,u,f={x:e%_.size.x,y:e/_.size.x|0};if(e<_.data.length)for(o=w.data[e],_.data[e]=i,s=0;sa&&n(c)):_.data[c]=Number.MAX_VALUE}var r,o,i=0,a=.95,c=0;for(O.a.init(b.data,0),O.a.init(_.data,0),O.a.init(w.data,null),r=0;rr?null:(t=s(r),0===t.length?null:n=u(t,r))},checkImageConstraints:function(e,t){var n,r,o,i=e.getWidth(),a=e.getHeight(),c=t.halfSample?.5:1;if(e.getConfig().area&&(o=x.h.bind()(i,a,e.getConfig().area),e.setTopRight({x:o.sx,y:o.sy}),e.setCanvasSize({x:i,y:a}),i=o.sw,a=o.sh),r={x:Math.floor(i*c),y:Math.floor(a*c)},n=x.b.bind()(t.patchSize,r),e.setWidth(Math.floor(Math.floor(r.x/n.x)*(1/c)*n.x)),e.setHeight(Math.floor(Math.floor(r.y/n.y)*(1/c)*n.y)),e.getWidth()%n.x===0&&e.getHeight()%n.y===0)return!0;throw new Error("Image dimensions do not comply with the current settings: Width ("+i+" )and height ("+a+") must a multiple of "+n.x)}}}).call(t,function(){return this}())},function(e,t,n){var r=n(29),o={createContour2D:function(){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(e,t){var n=e.data,i=t.data,a=e.size.x,c=e.size.y,s=r.a.create(e,t);return{rasterize:function(e){var t,r,u,f,d,l,p,h,v,g,m,y,b=[],_=0;for(y=0;400>y;y++)b[y]=0;for(b[0]=n[0],v=null,l=1;c-1>l;l++)for(f=0,r=b[0],d=1;a-1>d;d++)if(m=l*a+d,0===i[m])if(t=n[m],t!==r){if(0===f)u=_+1,b[u]=t,r=t,p=s.contourTracing(l,d,u,t,o.DIR.OUTSIDE_EDGE),null!==p&&(_++,f=u,h=o.createContour2D(),h.dir=o.CONTOUR_DIR.CW_DIR,h.index=f,h.firstVertex=p,h.nextpeer=v,h.insideContours=null,null!==v&&(v.prevpeer=h),v=h);else if(p=s.contourTracing(l,d,o.DIR.INSIDE_EDGE,t,f),null!==p){for(h=o.createContour2D(),h.firstVertex=p,h.insideContours=null,0===e?h.dir=o.CONTOUR_DIR.CCW_DIR:h.dir=o.CONTOUR_DIR.CW_DIR,h.index=e,g=v;null!==g&&g.index!==f;)g=g.nextpeer;null!==g&&(h.nextpeer=g.insideContours,null!==g.insideContours&&(g.insideContours.prevpeer=h),g.insideContours=h)}}else i[m]=f;else i[m]===o.DIR.OUTSIDE_EDGE||i[m]===o.DIR.INSIDE_EDGE?(f=0,r=i[m]===o.DIR.INSIDE_EDGE?n[m]:b[0]):(f=i[m],r=b[f]);for(g=v;null!==g;)g.index=e,g=g.nextpeer;return{cc:v,count:_}},debug:{drawContour:function(e,t){var n,r,i,a=e.getContext("2d"),c=t;for(a.strokeStyle="red",a.fillStyle="red",a.lineWidth=1,n=null!==c?c.insideContours:null;null!==c;){switch(null!==n?(r=n,n=n.nextpeer):(r=c,c=c.nextpeer,n=null!==c?c.insideContours:null),r.dir){case o.CONTOUR_DIR.CW_DIR:a.strokeStyle="red";break;case o.CONTOUR_DIR.CCW_DIR:a.strokeStyle="blue";break;case o.CONTOUR_DIR.UNKNOWN_DIR:a.strokeStyle="green"}i=r.firstVertex,a.beginPath(),a.moveTo(i.x,i.y);do i=i.next,a.lineTo(i.x,i.y);while(i!==r.firstVertex);a.stroke()}}}}}};t.a=o},function(module, exports, __webpack_require__) {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(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};} exports["a"]=Skeletonizer; },function(e,t,n){function r(){o.a.call(this),this._counters=[]}var o=n(5),i={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:[3,6,9,96,18,66,33,36,48,72,12,24,69,81,84,21,26,41,11,14]},START_END:{value:[26,41,11,14]},MIN_ENCODED_CHARS:{value:4},MAX_ACCEPTABLE:{value:2},PADDING:{value:1.5},FORMAT:{value:"codabar",writeable:!1}};r.prototype=Object.create(o.a.prototype,i),r.prototype.constructor=r,r.prototype._decode=function(){var e,t,n,r,o,i=this,a=[];if(this._counters=i._fillCounters(),e=i._findStart(),!e)return null;r=e.startCounter;do{if(n=i._toPattern(r),0>n)return null;if(t=i._patternToChar(n),0>t)return null;if(a.push(t),r+=8,a.length>1&&i._isStartEnd(n))break}while(ri._counters.length?i._counters.length:r,o=e.start+i._sumCounters(e.startCounter,r-8),{code:a.join(""),start:e.start,end:o,startInfo:e,decodedCodes:a}):null},r.prototype._verifyWhitespace=function(e,t){return(0>=e-1||this._counters[e-1]>=this._calculatePatternLength(e)/2)&&(t+8>=this._counters.length||this._counters[t+7]>=this._calculatePatternLength(t)/2)},r.prototype._calculatePatternLength=function(e){var t,n=0;for(t=e;e+7>t;t++)n+=this._counters[t];return n},r.prototype._thresholdResultPattern=function(e,t){var n,r,o,i,a,c=this,s={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}}},u=t;for(o=0;o=0;i--)n=2===(1&i)?s.bar:s.space,r=1===(1&a)?n.wide:n.narrow,r.size+=c._counters[u+i],r.counts++,a>>=1;u+=8}return["space","bar"].forEach(function(e){var t=s[e];t.wide.min=Math.floor((t.narrow.size/t.narrow.counts+t.wide.size/t.wide.counts)/2),t.narrow.max=Math.ceil(t.wide.min),t.wide.max=Math.ceil((t.wide.size*c.MAX_ACCEPTABLE+c.PADDING)/t.wide.counts)}),s},r.prototype._charToPattern=function(e){var t,n=this,r=e.charCodeAt(0);for(t=0;t=0;r--){if(o=0===(1&r)?u.bar:u.space,i=1===(1&c)?o.wide:o.narrow,a=s._counters[f+r],ai.max)return!1;c>>=1}f+=8}return!0},r.prototype._patternToChar=function(e){var t,n=this;for(t=0;tn;n+=2)r=this._counters[n],r>i&&(i=r),o>r&&(o=r);return(o+i)/2|0},r.prototype._toPattern=function(e){var t,n,r,o,i=7,a=e+i,c=1<this._counters.length)return-1;for(t=this._computeAlternatingThreshold(e,a),n=this._computeAlternatingThreshold(e+1,a),r=0;i>r;r++)o=0===(1&r)?t:n,this._counters[e+r]>o&&(s|=c),c>>=1;return s},r.prototype._isStartEnd=function(e){var t;for(t=0;tn;n++)r+=this._counters[n];return r},r.prototype._findStart=function(){var e,t,n,r=this,o=r._nextUnset(r._row);for(e=1;er;r++)a[r]=a[r+2];a[4]=0,a[5]=0,f--}else f++;a[f]=1,u=!u}return null},r.prototype._decode=function(){var e,t,n=this,r=n._findStart(),o=null,i=!1,a=[],c=0,s=0,u=[],f=[],d=!1,l=!0;if(null===r)return null;switch(o={code:r.code,start:r.start,end:r.end},f.push(o),s=o.code,o.code){case n.START_CODE_A:e=n.CODE_A;break;case n.START_CODE_B:e=n.CODE_B;break;case n.START_CODE_C:e=n.CODE_C;break;default:return null}for(;!i;){if(t=d,d=!1,o=n._decodeCode(o.end),null!==o)switch(o.code!==n.STOP_CODE&&(l=!0),o.code!==n.STOP_CODE&&(u.push(o.code),c++,s+=c*o.code),f.push(o),e){case n.CODE_A:if(o.code<64)a.push(String.fromCharCode(32+o.code));else if(o.code<96)a.push(String.fromCharCode(o.code-64));else switch(o.code!==n.STOP_CODE&&(l=!1),o.code){case n.CODE_SHIFT:d=!0,e=n.CODE_B;break;case n.CODE_B:e=n.CODE_B;break;case n.CODE_C:e=n.CODE_C;break;case n.STOP_CODE:i=!0}break;case n.CODE_B:if(o.code<96)a.push(String.fromCharCode(32+o.code));else switch(o.code!==n.STOP_CODE&&(l=!1),o.code){case n.CODE_SHIFT:d=!0,e=n.CODE_A;break;case n.CODE_A:e=n.CODE_A;break;case n.CODE_C:e=n.CODE_C;break;case n.STOP_CODE:i=!0}break;case n.CODE_C:if(o.code<100)a.push(o.code<10?"0"+o.code:o.code);else switch(o.code!==n.STOP_CODE&&(l=!1),o.code){case n.CODE_A:e=n.CODE_A;break;case n.CODE_B:e=n.CODE_B;break;case n.STOP_CODE:i=!0}}else i=!0;t&&(e=e===n.CODE_A?n.CODE_B:n.CODE_A)}return null===o?null:(o.end=n._nextUnset(n._row,o.end),n._verifyTrailingWhitespace(o)?(s-=c*u[u.length-1],s%103!==u[u.length-1]?null:a.length?(l&&a.splice(a.length-1,1),{code:a.join(""),start:r.start,end:o.end,codeset:e,startInfo:r,decodedCodes:f,endInfo:o}):null):null)},o.a.prototype._verifyTrailingWhitespace=function(e){var t,n=this;return t=e.end+(e.end-e.start)/2,tr;r++){if(e=o._decodeCode(e.end,o.CODE_G_START),!e)return null;t.push(e.code),n.push(e)}if(e=o._findPattern(o.MIDDLE_PATTERN,e.end,!0,!1),null===e)return null;for(n.push(e),r=0;4>r;r++){if(e=o._decodeCode(e.end,o.CODE_G_START),!e)return null;n.push(e),t.push(e.code)}return e},t.a=r},function(e,t,n){function r(e){e=a.a.bind()(o(),e),c.a.call(this,e),this.barSpaceRatio=[1,1],e.normalizeBarSpaceWidth&&(this.SINGLE_CODE_ERROR=.38,this.AVG_CODE_ERROR=.09)}function o(){var e={};return Object.keys(r.CONFIG_KEYS).forEach(function(t){e[t]=r.CONFIG_KEYS[t]["default"]}),e}var i=n(28),a=i&&i.__esModule?function(){return i["default"]}:function(){return i};Object.defineProperty(a,"a",{get:a});var c=n(5),s=1,u=3,f={MODULO:{value:10},START_PATTERN:{value:[2.5*s,2.5*s,2.5*s,2.5*s]},STOP_PATTERN:{value:[2*s,2*s,2*u]},CODE_PATTERN:{value:[[s,s,u,u,s],[u,s,s,s,u],[s,u,s,s,u],[u,u,s,s,s],[s,s,u,s,u],[u,s,u,s,s],[s,u,u,s,s],[s,s,s,u,u],[u,s,s,u,s],[s,u,s,u,s]]},SINGLE_CODE_ERROR:{value:.78,writable:!0},AVG_CODE_ERROR:{value:.38,writable:!0},MAX_CORRECTION_FACTOR:{value:5},FORMAT:{value:"i2of5"}};r.prototype=Object.create(c.a.prototype,f),r.prototype.constructor=r,r.prototype._matchPattern=function(e,t){if(this.config.normalizeBarSpaceWidth){var n,r=[0,0],o=[0,0],i=[0,0],a=this.MAX_CORRECTION_FACTOR,s=1/a;for(n=0;ni))return l.error=i,l.start=o-c,l.end=o,l;if(!r)return null;for(a=0;a=0&&n._matchRange(e,t.start,0))return t;r=t.end,t=null}},r.prototype._verifyTrailingWhitespace=function(e){var t,n=this;return t=e.end+(e.end-e.start)/2,ta;){for(r=0;5>r;r++)s[0][r]=e[a]*this.barSpaceRatio[0],s[1][r]=e[a+1]*this.barSpaceRatio[1],a+=2;if(o=i._decodePair(s),!o)return null;for(r=0;rr;r++){if(e=o._decodeCode(e.end),!e)return null;e.code>=o.CODE_G_START&&(e.code=e.code-o.CODE_G_START,i|=1<<5-r),t.push(e.code),n.push(e)}return o._determineParity(i,t)?e:null},r.prototype._determineParity=function(e,t){var n,r;for(r=0;r=n?t.concat(e.slice(1,3)).concat([n,0,0,0,0]).concat(e.slice(3,6)):3===n?t.concat(e.slice(1,4)).concat([0,0,0,0,0]).concat(e.slice(4,6)):4===n?t.concat(e.slice(1,5)).concat([0,0,0,0,0,e[5]]):t.concat(e.slice(1,6)).concat([0,0,0,0,n]),t.push(e[e.length-1]),t},r.prototype._checksum=function(e){return o.a.prototype._checksum.call(this,this._convertToUPCA(e))},r.prototype._findEnd=function(e,t){return t=!0,o.a.prototype._findEnd.call(this,e,t)},r.prototype._verifyTrailingWhitespace=function(e){var t,n=this;return t=e.end+(e.end-e.start)/2,t0&&c(d)&&(n||a(d)||i(d))?t>1?r(d,t-1,n,s):o(s,d):n||(s[s.length]=d)}return s}var o=n(89),i=n(24),a=n(4),c=n(26);e.e=r},function(e,t,n){var r=n(114),o=r();e.e=o},function(e,t,n){function r(e,t){return e&&o(e,t,i)}var o=n(94),i=n(45);e.e=r},function(e,t,n){function r(e,t){return i.call(e,t)||"object"==typeof e&&t in e&&null===a(e)}var o=Object.prototype,i=o.hasOwnProperty,a=Object.getPrototypeOf;e.e=r},function(e,t,n){function r(e){return o(Object(e))}var o=Object.keys;e.e=r},function(e,t,n){function r(e){e=null==e?e:Object(e);var t=[];for(var n in e)t.push(n);return t}var o=n(81),i=n(125),a=Object.prototype,c=o?o.enumerate:void 0,s=a.propertyIsEnumerable;c&&!s.call({valueOf:1},"valueOf")&&(r=function(e){return i(c(e))}),e.e=r},function(e,t,n){function r(e,t,n,l,p){if(e!==t){var h=s(t)||f(t)?void 0:d(t);i(h||t,function(i,s){if(h&&(s=i,i=t[s]),u(i))p||(p=new o),c(e,t,s,n,r,l,p);else{var f=l?l(e[s],i,s+"",e,t,p):void 0;void 0===f&&(f=i),a(e,s,f)}})}}var o=n(32),i=n(33),a=n(34),c=n(100),s=n(4),u=n(2),f=n(44),d=n(46);e.e=r},function(e,t,n){function r(e,t,n,r,v,g,m){var y=e[n],b=t[n],_=m.get(b);if(_)return void o(e,n,_);var w=g?g(y,b,n+"",e,t,m):void 0,C=void 0===w;C&&(w=b,s(b)||p(b)?s(y)?w=y:u(y)?w=a(y):(C=!1,w=i(b,!g)):l(b)||c(b)?c(y)?w=h(y):!d(y)||r&&f(y)?(C=!1,w=i(b,!g)):w=y:C=!1),m.set(b,w),C&&v(w,b,r,g,m),m["delete"](b),o(e,n,w)}var o=n(34),i=n(91),a=n(41),c=n(24),s=n(4),u=n(26),f=n(16),d=n(2),l=n(141),p=n(44),h=n(146);e.e=r},function(e,t,n){function r(e,t){return e=Object(e),o(t,function(t,n){return n in e&&(t[n]=e[n]),t},{})}var o=n(19);e.e=r},function(e,t,n){function r(e){return function(t){return null==t?void 0:t[e]}}e.e=r},function(e,t,n){function r(e,t){for(var n=-1,r=Array(e);++n1?n[i-1]:void 0,c=i>2?n[2]:void 0;for(a="function"==typeof a?(i--,a):void 0,c&&o(n[0],n[1],c)&&(a=3>i?void 0:a,i=1),t=Object(t);++re?-1:1;return t*a}var n=e%1;return e===e?n?e-n:e:0}var o=n(145),i=1/0,a=1.7976931348623157e308;e.e=r},function(e,t,n){function r(e){if(i(e)){var t=o(e.valueOf)?e.valueOf():e;e=i(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=e.replace(c,"");var n=u.test(e);return n||f.test(e)?d(e.slice(2),n?2:8):s.test(e)?a:+e}var o=n(16),i=n(2),a=NaN,c=/^\s+|\s+$/g,s=/^[-+]0x[0-9a-f]+$/i,u=/^0b[01]+$/i,f=/^0o[0-7]+$/i,d=parseInt;e.e=r},function(e,t,n){function r(e){return o(e,i(e))}var o=n(20),i=n(46);e.e=r},function(e,t,n){"use strict";!function(){var t=n(0).log,r=n(0).browserDetails;e.e.browserDetails=r,e.e.extractVersion=n(0).extractVersion,e.e.disableLog=n(0).disableLog;var o=n(148)||null,i=n(151)||null,a=n(152)||null;switch(r.browser){case"chrome":if(!o||!o.shimPeerConnection)return void t("Chrome shim is not included in this adapter release.");t("adapter.js shimming chrome!"),e.e.browserShim=o,o.shimGetUserMedia(),o.shimSourceObject(),o.shimPeerConnection(),o.shimOnTrack();break;case"edge":if(!i||!i.shimPeerConnection)return void t("MS edge shim is not included in this adapter release.");t("adapter.js shimming edge!"),e.e.browserShim=i,i.shimPeerConnection();break;case"firefox":if(!a||!a.shimPeerConnection)return void t("Firefox shim is not included in this adapter release.");t("adapter.js shimming firefox!"),e.e.browserShim=a,a.shimGetUserMedia(),a.shimSourceObject(),a.shimPeerConnection(),a.shimOnTrack();break;default:t("Unsupported browser!")}}()},function(e,t,n){"use strict";var r=n(0).log,o=n(0).browserDetails,i={shimOnTrack:function(){"object"!=typeof window||!window.RTCPeerConnection||"ontrack"in window.RTCPeerConnection.prototype||Object.defineProperty(window.RTCPeerConnection.prototype,"ontrack",{get:function(){return this._ontrack},set:function(e){var t=this;this._ontrack&&(this.removeEventListener("track",this._ontrack),this.removeEventListener("addstream",this._ontrackpoly)),this.addEventListener("track",this._ontrack=e),this.addEventListener("addstream",this._ontrackpoly=function(e){e.stream.addEventListener("addtrack",function(n){var r=new Event("track");r.track=n.track,r.receiver={track:n.track},r.streams=[e.stream],t.dispatchEvent(r)}),e.stream.getTracks().forEach(function(t){var n=new Event("track");n.track=t,n.receiver={track:t},n.streams=[e.stream],this.dispatchEvent(n)}.bind(this))}.bind(this))}})},shimSourceObject:function(){"object"==typeof window&&(!window.HTMLMediaElement||"srcObject"in window.HTMLMediaElement.prototype||Object.defineProperty(window.HTMLMediaElement.prototype,"srcObject",{get:function(){return this._srcObject},set:function(e){var t=this;return this._srcObject=e,this.src&&URL.revokeObjectURL(this.src),e?(this.src=URL.createObjectURL(e),e.addEventListener("addtrack",function(){t.src&&URL.revokeObjectURL(t.src),t.src=URL.createObjectURL(e)}),void e.addEventListener("removetrack",function(){t.src&&URL.revokeObjectURL(t.src),t.src=URL.createObjectURL(e)})):void(this.src="")}}))},shimPeerConnection:function(){window.RTCPeerConnection=function(e,t){r("PeerConnection"),e&&e.iceTransportPolicy&&(e.iceTransports=e.iceTransportPolicy);var n=new webkitRTCPeerConnection(e,t),o=n.getStats.bind(n);return n.getStats=function(e,t,n){var r=this,i=arguments;if(arguments.length>0&&"function"==typeof e)return o(e,t);var a=function(e){var t={},n=e.result();return n.forEach(function(e){var n={id:e.id,timestamp:e.timestamp,type:e.type};e.names().forEach(function(t){n[t]=e.stat(t)}),t[n.id]=n}),t};if(arguments.length>=2){var c=function(e){i[1](a(e))};return o.apply(this,[c,arguments[0]])}return new Promise(function(t,n){1===i.length&&null===e?o.apply(r,[function(e){t.apply(null,[a(e)])},n]):o.apply(r,[t,n])})},n},window.RTCPeerConnection.prototype=webkitRTCPeerConnection.prototype,webkitRTCPeerConnection.generateCertificate&&Object.defineProperty(window.RTCPeerConnection,"generateCertificate",{get:function(){return arguments.length?webkitRTCPeerConnection.generateCertificate.apply(null,arguments):webkitRTCPeerConnection.generateCertificate}}),["createOffer","createAnswer"].forEach(function(e){var t=webkitRTCPeerConnection.prototype[e];webkitRTCPeerConnection.prototype[e]=function(){var e=this;if(arguments.length<1||1===arguments.length&&"object"==typeof arguments[0]){var n=1===arguments.length?arguments[0]:void 0;return new Promise(function(r,o){t.apply(e,[r,o,n])})}return t.apply(this,arguments)}}),["setLocalDescription","setRemoteDescription","addIceCandidate"].forEach(function(e){var t=webkitRTCPeerConnection.prototype[e];webkitRTCPeerConnection.prototype[e]=function(){var e=arguments,n=this;return new Promise(function(r,o){t.apply(n,[e[0],function(){r(),e.length>=2&&e[1].apply(null,[])},function(t){o(t),e.length>=3&&e[2].apply(null,[t])}])})}})},attachMediaStream:function(e,t){r("DEPRECATED, attachMediaStream will soon be removed."),o.version>=43?e.srcObject=t:"undefined"!=typeof e.src?e.src=URL.createObjectURL(t):r("Error attaching stream to element.")},reattachMediaStream:function(e,t){r("DEPRECATED, reattachMediaStream will soon be removed."),o.version>=43?e.srcObject=t.srcObject:e.src=t.src}};e.e={shimOnTrack:i.shimOnTrack,shimSourceObject:i.shimSourceObject,shimPeerConnection:i.shimPeerConnection,shimGetUserMedia:n(149),attachMediaStream:i.attachMediaStream,reattachMediaStream:i.reattachMediaStream}},function(e,t,n){"use strict";var r=n(0).log;e.e=function(){var e=function(e){if("object"!=typeof e||e.mandatory||e.optional)return e; +var t={};return Object.keys(e).forEach(function(n){if("require"!==n&&"advanced"!==n&&"mediaSource"!==n){var r="object"==typeof e[n]?e[n]:{ideal:e[n]};void 0!==r.exact&&"number"==typeof r.exact&&(r.min=r.max=r.exact);var o=function(e,t){return e?e+t.charAt(0).toUpperCase()+t.slice(1):"deviceId"===t?"sourceId":t};if(void 0!==r.ideal){t.optional=t.optional||[];var i={};"number"==typeof r.ideal?(i[o("min",n)]=r.ideal,t.optional.push(i),i={},i[o("max",n)]=r.ideal,t.optional.push(i)):(i[o("",n)]=r.ideal,t.optional.push(i))}void 0!==r.exact&&"number"!=typeof r.exact?(t.mandatory=t.mandatory||{},t.mandatory[o("",n)]=r.exact):["min","max"].forEach(function(e){void 0!==r[e]&&(t.mandatory=t.mandatory||{},t.mandatory[o(e,n)]=r[e])})}}),e.advanced&&(t.optional=(t.optional||[]).concat(e.advanced)),t},t=function(t,n,o){return t.audio&&(t.audio=e(t.audio)),t.video&&(t.video=e(t.video)),r("chrome: "+JSON.stringify(t)),navigator.webkitGetUserMedia(t,n,o)};navigator.getUserMedia=t;var n=function(e){return new Promise(function(t,n){navigator.getUserMedia(e,t,n)})};if(navigator.mediaDevices||(navigator.mediaDevices={getUserMedia:n,enumerateDevices:function(){return new Promise(function(e){var t={audio:"audioinput",video:"videoinput"};return MediaStreamTrack.getSources(function(n){e(n.map(function(e){return{label:e.label,kind:t[e.kind],deviceId:e.id,groupId:""}}))})})}}),navigator.mediaDevices.getUserMedia){var o=navigator.mediaDevices.getUserMedia.bind(navigator.mediaDevices);navigator.mediaDevices.getUserMedia=function(t){return t&&(r("spec: "+JSON.stringify(t)),t.audio=e(t.audio),t.video=e(t.video),r("chrome: "+JSON.stringify(t))),o(t)}.bind(this)}else navigator.mediaDevices.getUserMedia=function(e){return n(e)};"undefined"==typeof navigator.mediaDevices.addEventListener&&(navigator.mediaDevices.addEventListener=function(){r("Dummy mediaDevices.addEventListener called.")}),"undefined"==typeof navigator.mediaDevices.removeEventListener&&(navigator.mediaDevices.removeEventListener=function(){r("Dummy mediaDevices.removeEventListener called.")})}},function(e,t,n){"use strict";var r={};r.generateIdentifier=function(){return Math.random().toString(36).substr(2,10)},r.localCName=r.generateIdentifier(),r.splitLines=function(e){return e.trim().split("\n").map(function(e){return e.trim()})},r.splitSections=function(e){var t=e.split("\r\nm=");return t.map(function(e,t){return(t>0?"m="+e:e).trim()+"\r\n"})},r.matchPrefix=function(e,t){return r.splitLines(e).filter(function(e){return 0===e.indexOf(t)})},r.parseCandidate=function(e){var t;t=0===e.indexOf("a=candidate:")?e.substring(12).split(" "):e.substring(10).split(" ");for(var n={foundation:t[0],component:t[1],protocol:t[2].toLowerCase(),priority:parseInt(t[3],10),ip:t[4],port:parseInt(t[5],10),type:t[7]},r=8;r-1?(n.attribute=e.substr(t+1,r-t-1),n.value=e.substr(r+1)):n.attribute=e.substr(t+1),n},r.getDtlsParameters=function(e,t){var n=r.splitLines(e);n=n.concat(r.splitLines(t));var o=n.filter(function(e){return 0===e.indexOf("a=fingerprint:")})[0].substr(14),i={role:"auto",fingerprints:[{algorithm:o.split(" ")[0],value:o.split(" ")[1]}]};return i},r.writeDtlsParameters=function(e,t){var n="a=setup:"+t+"\r\n";return e.fingerprints.forEach(function(e){n+="a=fingerprint:"+e.algorithm+" "+e.value+"\r\n"}),n},r.getIceParameters=function(e,t){var n=r.splitLines(e);n=n.concat(r.splitLines(t));var o={usernameFragment:n.filter(function(e){return 0===e.indexOf("a=ice-ufrag:")})[0].substr(12),password:n.filter(function(e){return 0===e.indexOf("a=ice-pwd:")})[0].substr(10)};return o},r.writeIceParameters=function(e){return"a=ice-ufrag:"+e.usernameFragment+"\r\na=ice-pwd:"+e.password+"\r\n"},r.parseRtpParameters=function(e){for(var t={codecs:[],headerExtensions:[],fecMechanisms:[],rtcp:[]},n=r.splitLines(e),o=n[0].split(" "),i=3;i0?"9":"0",n+=" UDP/TLS/RTP/SAVPF ",n+=t.codecs.map(function(e){return void 0!==e.preferredPayloadType?e.preferredPayloadType:e.payloadType}).join(" ")+"\r\n",n+="c=IN IP4 0.0.0.0\r\n",n+="a=rtcp:9 IN IP4 0.0.0.0\r\n",t.codecs.forEach(function(e){n+=r.writeRtpMap(e),n+=r.writeFtmp(e),n+=r.writeRtcpFb(e)}),n+="a=rtcp-mux\r\n"},r.writeSessionBoilerplate=function(){return"v=0\r\no=thisisadapterortc 8169639915646943137 2 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\n"},r.writeMediaSection=function(e,t,n,o){var i=r.writeRtpDescription(e.kind,t);if(i+=r.writeIceParameters(e.iceGatherer.getLocalParameters()),i+=r.writeDtlsParameters(e.dtlsTransport.getLocalParameters(),"offer"===n?"actpass":"active"),i+="a=mid:"+e.mid+"\r\n",i+=e.rtpSender&&e.rtpReceiver?"a=sendrecv\r\n":e.rtpSender?"a=sendonly\r\n":e.rtpReceiver?"a=recvonly\r\n":"a=inactive\r\n",e.rtpSender){var a="msid:"+o.id+" "+e.rtpSender.track.id+"\r\n";i+="a="+a,i+="a=ssrc:"+e.sendSsrc+" "+a}return i+="a=ssrc:"+e.sendSsrc+" cname:"+r.localCName+"\r\n"},r.getDirection=function(e,t){for(var n=r.splitLines(e),o=0;o-1&&(this.localStreams.splice(t,1),this._maybeFireNegotiationNeeded())},window.RTCPeerConnection.prototype._getCommonCapabilities=function(e,t){var n={codecs:[],headerExtensions:[],fecMechanisms:[]};return e.codecs.forEach(function(e){for(var r=0;r0,!1)}})}switch(this.localDescription={type:e.type,sdp:e.sdp},e.type){case"offer":this._updateSignalingState("have-local-offer");break;case"answer":this._updateSignalingState("stable");break;default:throw new TypeError('unsupported type "'+e.type+'"')}var i=arguments.length>1&&"function"==typeof arguments[1];if(i){var a=arguments[1];window.setTimeout(function(){a(),"new"===t.iceGatheringState&&(t.iceGatheringState="gathering"),t._emitBufferedCandidates()},0)}var c=Promise.resolve();return c.then(function(){i||("new"===t.iceGatheringState&&(t.iceGatheringState="gathering"),window.setTimeout(t._emitBufferedCandidates.bind(t),500))}),c},window.RTCPeerConnection.prototype.setRemoteDescription=function(e){var t=this,n=new MediaStream,o=[],i=r.splitSections(e.sdp),a=i.shift();switch(i.forEach(function(i,c){var s,u,f,d,l,p,h,v,g,m,y,b,_=r.splitLines(i),w=_[0].substr(2).split(" "),C=w[0],E="0"===w[1],R=r.getDirection(i,a),S=r.parseRtpParameters(i);E||(y=r.getIceParameters(i,a),b=r.getDtlsParameters(i,a));var T,x=r.matchPrefix(i,"a=mid:")[0].substr(6),O=r.matchPrefix(i,"a=ssrc:").map(function(e){return r.parseSsrcMedia(e)}).filter(function(e){return"cname"===e.attribute})[0];if(O&&(v=parseInt(O.ssrc,10),T=O.value),"offer"===e.type){var D=t._createIceAndDtlsTransports(x,c);if(g=RTCRtpReceiver.getCapabilities(C),h=1001*(2*c+2),p=new RTCRtpReceiver(D.dtlsTransport,C),m=p.track,o.push([m,p]),n.addTrack(m),t.localStreams.length>0&&t.localStreams[0].getTracks().length>=c){var P=t.localStreams[0].getTracks()[c];l=new RTCRtpSender(P,D.dtlsTransport)}t.transceivers[c]={iceGatherer:D.iceGatherer,iceTransport:D.iceTransport,dtlsTransport:D.dtlsTransport,localCapabilities:g,remoteCapabilities:S,rtpSender:l,rtpReceiver:p,kind:C,mid:x,cname:T,sendSsrc:h,recvSsrc:v},t._transceive(t.transceivers[c],!1,"sendrecv"===R||"sendonly"===R)}else"answer"!==e.type||E||(s=t.transceivers[c],u=s.iceGatherer,f=s.iceTransport,d=s.dtlsTransport,l=s.rtpSender,p=s.rtpReceiver,h=s.sendSsrc,g=s.localCapabilities,t.transceivers[c].recvSsrc=v,t.transceivers[c].remoteCapabilities=S,t.transceivers[c].cname=T,f.start(u,y,"controlling"),d.start(b),t._transceive(s,"sendrecv"===R||"recvonly"===R,"sendrecv"===R||"sendonly"===R),!p||"sendrecv"!==R&&"sendonly"!==R?delete s.rtpReceiver:(m=p.track,o.push([m,p]),n.addTrack(m)))}),this.remoteDescription={type:e.type,sdp:e.sdp},e.type){case"offer":this._updateSignalingState("have-remote-offer");break;case"answer":this._updateSignalingState("stable");break;default:throw new TypeError('unsupported type "'+e.type+'"')}return n.getTracks().length&&(t.remoteStreams.push(n),window.setTimeout(function(){var e=new Event("addstream");e.stream=n,t.dispatchEvent(e),null!==t.onaddstream&&window.setTimeout(function(){t.onaddstream(e)},0),o.forEach(function(e){var r=e[0],o=e[1],i=new Event("track");i.track=r,i.receiver=o,i.streams=[n],t.dispatchEvent(i),null!==t.ontrack&&window.setTimeout(function(){t.ontrack(i)},0)})},0)),arguments.length>1&&"function"==typeof arguments[1]&&window.setTimeout(arguments[1],0),Promise.resolve()},window.RTCPeerConnection.prototype.close=function(){this.transceivers.forEach(function(e){e.iceTransport&&e.iceTransport.stop(),e.dtlsTransport&&e.dtlsTransport.stop(),e.rtpSender&&e.rtpSender.stop(),e.rtpReceiver&&e.rtpReceiver.stop()}),this._updateSignalingState("closed")},window.RTCPeerConnection.prototype._updateSignalingState=function(e){this.signalingState=e;var t=new Event("signalingstatechange");this.dispatchEvent(t),null!==this.onsignalingstatechange&&this.onsignalingstatechange(t)},window.RTCPeerConnection.prototype._maybeFireNegotiationNeeded=function(){var e=new Event("negotiationneeded");this.dispatchEvent(e),null!==this.onnegotiationneeded&&this.onnegotiationneeded(e)},window.RTCPeerConnection.prototype._updateConnectionState=function(){var e,t=this,n={"new":0,closed:0,connecting:0,checking:0,connected:0,completed:0,failed:0};if(this.transceivers.forEach(function(e){n[e.iceTransport.state]++,n[e.dtlsTransport.state]++}),n.connected+=n.completed,e="new",n.failed>0?e="failed":n.connecting>0||n.checking>0?e="connecting":n.disconnected>0?e="disconnected":n["new"]>0?e="new":(n.connecting>0||n.completed>0)&&(e="connected"),e!==t.iceConnectionState){t.iceConnectionState=e;var r=new Event("iceconnectionstatechange");this.dispatchEvent(r),null!==this.oniceconnectionstatechange&&this.oniceconnectionstatechange(r)}},window.RTCPeerConnection.prototype.createOffer=function(){var e=this;if(this._pendingOffer)throw new Error("createOffer called while there is a pending offer.");var t;1===arguments.length&&"function"!=typeof arguments[0]?t=arguments[0]:3===arguments.length&&(t=arguments[2]);var n=[],o=0,i=0;if(this.localStreams.length&&(o=this.localStreams[0].getAudioTracks().length,i=this.localStreams[0].getVideoTracks().length),t){if(t.mandatory||t.optional)throw new TypeError("Legacy mandatory/optional constraints not supported.");void 0!==t.offerToReceiveAudio&&(o=t.offerToReceiveAudio),void 0!==t.offerToReceiveVideo&&(i=t.offerToReceiveVideo)}for(this.localStreams.length&&this.localStreams[0].getTracks().forEach(function(e){n.push({kind:e.kind,track:e,wantReceive:"audio"===e.kind?o>0:i>0}),"audio"===e.kind?o--:"video"===e.kind&&i--});o>0||i>0;)o>0&&(n.push({kind:"audio",wantReceive:!0}),o--),i>0&&(n.push({kind:"video",wantReceive:!0}),i--);var a=r.writeSessionBoilerplate(),c=[];n.forEach(function(t,n){var o,i,s=t.track,u=t.kind,f=r.generateIdentifier(),d=e._createIceAndDtlsTransports(f,n),l=RTCRtpSender.getCapabilities(u),p=1001*(2*n+1);s&&(o=new RTCRtpSender(s,d.dtlsTransport)),t.wantReceive&&(i=new RTCRtpReceiver(d.dtlsTransport,u)),c[n]={iceGatherer:d.iceGatherer,iceTransport:d.iceTransport,dtlsTransport:d.dtlsTransport,localCapabilities:l,remoteCapabilities:null,rtpSender:o,rtpReceiver:i,kind:u,mid:f,sendSsrc:p,recvSsrc:null};var h=c[n];a+=r.writeMediaSection(h,h.localCapabilities,"offer",e.localStreams[0])}),this._pendingOffer=c;var s=new RTCSessionDescription({type:"offer",sdp:a});return arguments.length&&"function"==typeof arguments[0]&&window.setTimeout(arguments[0],0,s),Promise.resolve(s)},window.RTCPeerConnection.prototype.createAnswer=function(){var e,t=this;1===arguments.length&&"function"!=typeof arguments[0]?e=arguments[0]:3===arguments.length&&(e=arguments[2]);var n=r.writeSessionBoilerplate();this.transceivers.forEach(function(e){var o=t._getCommonCapabilities(e.localCapabilities,e.remoteCapabilities);n+=r.writeMediaSection(e,o,"answer",t.localStreams[0])});var o=new RTCSessionDescription({type:"answer",sdp:n});return arguments.length&&"function"==typeof arguments[0]&&window.setTimeout(arguments[0],0,o),Promise.resolve(o)},window.RTCPeerConnection.prototype.addIceCandidate=function(e){var t=e.sdpMLineIndex;if(e.sdpMid)for(var n=0;n0?r.parseCandidate(e.candidate):{};if("tcp"===i.protocol&&0===i.port)return;if("1"!==i.component)return;"endOfCandidates"===i.type&&(i={}),o.iceTransport.addRemoteCandidate(i);var a=r.splitSections(this.remoteDescription.sdp);a[t+1]+=(i.type?e.candidate.trim():"a=end-of-candidates")+"\r\n",this.remoteDescription.sdp=a.join("")}return arguments.length>1&&"function"==typeof arguments[1]&&window.setTimeout(arguments[1],0),Promise.resolve()},window.RTCPeerConnection.prototype.getStats=function(){var e=[];this.transceivers.forEach(function(t){["rtpSender","rtpReceiver","iceGatherer","iceTransport","dtlsTransport"].forEach(function(n){t[n]&&e.push(t[n].getStats())})});var t=arguments.length>1&&"function"==typeof arguments[1]&&arguments[1];return new Promise(function(n){var r={};Promise.all(e).then(function(e){e.forEach(function(e){Object.keys(e).forEach(function(t){r[t]=e[t]})}),t&&window.setTimeout(t,0,r),n(r)})})}},attachMediaStream:function(e,t){o("DEPRECATED, attachMediaStream will soon be removed."),e.srcObject=t},reattachMediaStream:function(e,t){o("DEPRECATED, reattachMediaStream will soon be removed."),e.srcObject=t.srcObject}});e.e={shimPeerConnection:i.shimPeerConnection,attachMediaStream:i.attachMediaStream,reattachMediaStream:i.reattachMediaStream}},function(e,t,n){"use strict";var r=n(0).log,o=n(0).browserDetails,i={shimOnTrack:function(){"object"!=typeof window||!window.RTCPeerConnection||"ontrack"in window.RTCPeerConnection.prototype||Object.defineProperty(window.RTCPeerConnection.prototype,"ontrack",{get:function(){return this._ontrack},set:function(e){this._ontrack&&(this.removeEventListener("track",this._ontrack),this.removeEventListener("addstream",this._ontrackpoly)),this.addEventListener("track",this._ontrack=e),this.addEventListener("addstream",this._ontrackpoly=function(e){e.stream.getTracks().forEach(function(t){var n=new Event("track");n.track=t,n.receiver={track:t},n.streams=[e.stream],this.dispatchEvent(n)}.bind(this))}.bind(this))}})},shimSourceObject:function(){"object"==typeof window&&(!window.HTMLMediaElement||"srcObject"in window.HTMLMediaElement.prototype||Object.defineProperty(window.HTMLMediaElement.prototype,"srcObject",{get:function(){return this.mozSrcObject},set:function(e){this.mozSrcObject=e}}))},shimPeerConnection:function(){window.RTCPeerConnection||(window.RTCPeerConnection=function(e,t){if(o.version<38&&e&&e.iceServers){for(var n=[],r=0;r= pos && parseInt(match[pos], 10); + }, + + /** + * Browser detector. + * @return {object} result containing browser, version and minVersion + * properties. + */ + detectBrowser: function() { + // Returned result object. + var result = {}; + result.browser = null; + result.version = null; + result.minVersion = null; + + if (typeof window === 'undefined' || !window.navigator) { + result.browser = 'Not a browser.'; + return result; + } else if (navigator.mozGetUserMedia) { + // Firefox. + result.browser = 'firefox'; + result.version = this.extractVersion(navigator.userAgent, + /Firefox\/([0-9]+)\./, 1); + result.minVersion = 31; + } else if (navigator.webkitGetUserMedia && window.webkitRTCPeerConnection) { + // Chrome, Chromium, WebView, Opera and other WebKit browsers. + result.browser = 'chrome'; + result.version = this.extractVersion(navigator.userAgent, + /Chrom(e|ium)\/([0-9]+)\./, 2); + result.minVersion = 38; + } else if(navigator.mediaDevices && + navigator.userAgent.match(/Edge\/(\d+).(\d+)$/)) { + // Edge. + result.browser = 'edge'; + result.version = this.extractVersion(navigator.userAgent, + /Edge\/(\d+).(\d+)$/, 2); + result.minVersion = 10547; + } else { + result.browser = 'Not a supported browser.'; + return result; + } - var _commonImage_wrapper2 = _interopRequireDefault(_commonImage_wrapper); + // Warn if version is less than minVersion. + if (result.version < result.minVersion) { + utils.log('Browser: ' + result.browser + ' Version: ' + result.version + + ' < minimum supported version: ' + result.minVersion + + '\n some things might not work!'); + } - var _locatorBarcode_locator = __webpack_require__(9); + return result; + } + }; - var _locatorBarcode_locator2 = _interopRequireDefault(_locatorBarcode_locator); + // Export. + module.e = { + log: utils.log, + disableLog: utils.disableLog, + browserDetails: utils.detectBrowser(), + extractVersion: utils.extractVersion + }; + + +/***/ }, +/* 1 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(module, global) {var checkGlobal = __webpack_require__(103); - var _decoderBarcode_decoder = __webpack_require__(14); + /** Used to determine if values are of the language type `Object`. */ + var objectTypes = { + 'function': true, + 'object': true + }; - var _decoderBarcode_decoder2 = _interopRequireDefault(_decoderBarcode_decoder); + /** Detect free variable `exports`. */ + var freeExports = (objectTypes[typeof exports] && exports && !exports.nodeType) + ? exports + : undefined; - var _commonEvents = __webpack_require__(59); + /** Detect free variable `module`. */ + var freeModule = (objectTypes[typeof module] && module && !module.nodeType) + ? module + : undefined; - var _commonEvents2 = _interopRequireDefault(_commonEvents); + /** Detect free variable `global` from Node.js. */ + var freeGlobal = checkGlobal(freeExports && freeModule && typeof global == 'object' && global); - var _inputCamera_access = __webpack_require__(60); + /** Detect free variable `self`. */ + var freeSelf = checkGlobal(objectTypes[typeof self] && self); - var _inputCamera_access2 = _interopRequireDefault(_inputCamera_access); + /** Detect free variable `window`. */ + var freeWindow = checkGlobal(objectTypes[typeof window] && window); - var _commonImage_debug = __webpack_require__(10); + /** Detect `this` as the global object. */ + var thisGlobal = checkGlobal(objectTypes[typeof this] && this); - var _commonImage_debug2 = _interopRequireDefault(_commonImage_debug); + /** + * Used as a reference to the global object. + * + * The `this` value is used if it's the global object to avoid Greasemonkey's + * restricted `window` object, otherwise the `window` object is used. + */ + var root = freeGlobal || + ((freeWindow !== (thisGlobal && thisGlobal.window)) && freeWindow) || + freeSelf || thisGlobal || Function('return this')(); - var _glMatrix = __webpack_require__(7); + module.e = root; - var _analyticsResult_collector = __webpack_require__(61); + /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(48)(module), (function() { return this; }()))) + +/***/ }, +/* 2 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. + * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @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 && (type == 'object' || type == 'function'); + } - var _analyticsResult_collector2 = _interopRequireDefault(_analyticsResult_collector); + module.e = isObject; + + +/***/ }, +/* 3 */ +/***/ function(module, exports, __webpack_require__) { + + var getNative = __webpack_require__(12), + root = __webpack_require__(1); - var _configConfig = __webpack_require__(62); + /* Built-in method references that are verified to be native. */ + var Map = getNative(root, 'Map'); - var _configConfig2 = _interopRequireDefault(_configConfig); + module.e = Map; + + +/***/ }, +/* 4 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @type {Function} + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ + var isArray = Array.isArray; - var _input_stream = __webpack_require__(64); + module.e = isArray; + + +/***/ }, +/* 5 */ +/***/ function(module, exports) { + + 'use strict'; - var _input_stream2 = _interopRequireDefault(_input_stream); + exports.__esModule = true; + function BarcodeReader(config) { + this._row = []; + this.config = config || {}; + return this; + } - var _frame_grabber = __webpack_require__(66); + BarcodeReader.prototype._nextUnset = function (line, start) { + var i; - var _frame_grabber2 = _interopRequireDefault(_frame_grabber); + if (start === undefined) { + start = 0; + } + for (i = start; i < line.length; i++) { + if (!line[i]) { + return i; + } + } + return line.length; + }; - var merge = __webpack_require__(26); + BarcodeReader.prototype._matchPattern = function (counter, code) { + var i, + error = 0, + singleError = 0, + modulo = this.MODULO, + maxSingleError = this.SINGLE_CODE_ERROR || 1; - var _inputStream, - _framegrabber, - _stopped, - _canvasContainer = { - ctx: { - image: null, - overlay: null - }, - dom: { - image: null, - overlay: null + for (i = 0; i < counter.length; i++) { + singleError = Math.abs(code[i] - counter[i]); + if (singleError > maxSingleError) { + return Number.MAX_VALUE; + } + error += singleError; } - }, - _inputImageWrapper, - _boxSize, - _decoder, - _workerPool = [], - _onUIThread = true, - _resultCollector, - _config = {}; + return error / modulo; + }; - function initializeData(imageWrapper) { - initBuffers(imageWrapper); - _decoder = _decoderBarcode_decoder2['default'].create(_config.decoder, _inputImageWrapper); - } + BarcodeReader.prototype._nextSet = function (line, offset) { + var i; - 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); - } + offset = offset || 0; + for (i = offset; i < line.length; i++) { + if (line[i]) { + return i; } - _inputStream = _input_stream2['default'].createLiveStream(video); - _inputCamera_access2['default'].request(video, _config.inputStream.constraints, function (err) { - if (!err) { - _inputStream.trigger("canrecord"); - } else { - return cb(err); - } - }); } + return line.length; + }; - _inputStream.setAttribute("preload", "auto"); - _inputStream.setAttribute("autoplay", true); - _inputStream.setInputStream(_config.inputStream); - _inputStream.addEventListener("canrecord", canRecord.bind(undefined, cb)); - } + BarcodeReader.prototype._normalize = function (counter, modulo) { + var i, + self = this, + sum = 0, + ratio, + numOnes = 0, + normalized = [], + norm = 0; - function getViewPort() { - var target = _config.inputStream.target; - // Check if target is already a DOM element - if (target && target.nodeName && target.nodeType === 1) { - return target; + if (!modulo) { + modulo = self.MODULO; + } + for (i = 0; i < counter.length; i++) { + if (counter[i] === 1) { + numOnes++; + } else { + sum += counter[i]; + } + } + ratio = sum / (modulo - numOnes); + if (ratio > 1.0) { + for (i = 0; i < counter.length; i++) { + norm = counter[i] === 1 ? counter[i] : counter[i] / ratio; + normalized.push(norm); + } } else { - // Use '#interactive.viewport' as a fallback selector (backwards compatibility) - var selector = typeof target === 'string' ? target : '#interactive.viewport'; - return document.querySelector(selector); + ratio = (sum + numOnes) / modulo; + for (i = 0; i < counter.length; i++) { + norm = counter[i] / ratio; + normalized.push(norm); + } } - } + return normalized; + }; - function canRecord(cb) { - _locatorBarcode_locator2['default'].checkImageConstraints(_inputStream, _config.locator); - initCanvas(_config); - _framegrabber = _frame_grabber2['default'].create(_inputStream, _canvasContainer.dom.image); + 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; - adjustWorkerPool(_config.numOfWorkers, function () { - if (_config.numOfWorkers === 0) { - initializeData(); + if (cmpCounter) { + for (i = 0; i < cmpCounter.length; i++) { + counter.push(0); } - ready(cb); - }); - } + 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); - 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); + 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; } } - _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); + } 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; } } - _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 _commonImage_wrapper2['default']({ - x: _inputStream.getWidth(), - y: _inputStream.getHeight() - }); - } - - if (false) { - console.log(_inputImageWrapper.size); - } - _boxSize = [_glMatrix.vec2.clone([0, 0]), _glMatrix.vec2.clone([0, _inputImageWrapper.size.y]), _glMatrix.vec2.clone([_inputImageWrapper.size.x, _inputImageWrapper.size.y]), _glMatrix.vec2.clone([_inputImageWrapper.size.x, 0])]; - _locatorBarcode_locator2['default'].init(_inputImageWrapper, _config.locator); - } - - function getBoundingBoxes() { - if (_config.locate) { - return _locatorBarcode_locator2['default'].locate(); - } else { - return [[_glMatrix.vec2.clone(_boxSize[0]), _glMatrix.vec2.clone(_boxSize[1]), _glMatrix.vec2.clone(_boxSize[2]), _glMatrix.vec2.clone(_boxSize[3])]]; } - } - function transformResult(result) { - var topRight = _inputStream.getTopRight(), - xOffset = topRight.x, - yOffset = topRight.y, - i; + // if cmpCounter was not given + bestMatch.start = offset; + bestMatch.end = self._row.length - 1; + bestMatch.counter = counter; + return bestMatch; + }; - if (xOffset === 0 && yOffset === 0) { - return; - } + BarcodeReader.prototype.decodePattern = function (pattern) { + var self = this, + result; - if (result.barcodes) { - for (i = 0; i < result.barcodes.length; i++) { - transformResult(result.barcodes[i]); + 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.line && result.line.length === 2) { - moveLine(result.line); + if (result) { + result.format = self.FORMAT; } + return result; + }; - if (result.box) { - moveBox(result.box); - } + BarcodeReader.prototype._matchRange = function (start, end, value) { + var i; - if (result.boxes && result.boxes.length > 0) { - for (i = 0; i < result.boxes.length; i++) { - moveBox(result.boxes[i]); + start = start < 0 ? 0 : start; + for (i = start; i < end; i++) { + if (this._row[i] !== value) { + return false; } } + return true; + }; - function moveBox(box) { - var corner = box.length; + BarcodeReader.prototype._fillCounters = function (offset, end, isWhite) { + var self = this, + counterPos = 0, + i, + counters = []; - while (corner--) { - box[corner][0] += xOffset; - box[corner][1] += yOffset; - } - } + isWhite = typeof isWhite !== 'undefined' ? isWhite : true; + offset = typeof offset !== 'undefined' ? offset : self._nextUnset(self._row); + end = end || self._row.length; - function moveLine(line) { - line[0].x += xOffset; - line[0].y += yOffset; - line[1].x += xOffset; - line[1].y += yOffset; + 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; + }; - function addResult(result, imageData) { - if (!imageData || !_resultCollector) { - return; - } + Object.defineProperty(BarcodeReader.prototype, "FORMAT", { + value: 'unknown', + writeable: false + }); - 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); - } - } + BarcodeReader.DIRECTION = { + FORWARD: 1, + REVERSE: -1 + }; - function hasCodeResult(result) { - return result && (result.barcodes ? result.barcodes.some(function (barcode) { - return barcode.codeResult; - }) : result.codeResult); - } + BarcodeReader.Exception = { + StartNotFoundException: "Start-Info was not found!", + CodeNotFoundException: "Code could not be found!", + PatternNotFoundException: "Pattern could not be found!" + }; - function publishResult(result, imageData) { - var resultToPublish = result && (result.barcodes || result); + BarcodeReader.CONFIG_KEYS = {}; - if (result && _onUIThread) { - transformResult(result); - addResult(result, imageData); - } + exports.default = BarcodeReader; + +/***/ }, +/* 6 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = clone - _commonEvents2['default'].publish("processed", resultToPublish); - if (hasCodeResult(result)) { - _commonEvents2['default'].publish("detected", resultToPublish); - } + /** + * 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 } - - function locateAndDecode() { - var result, boxes; - - boxes = getBoundingBoxes(); - if (boxes) { - result = _decoder.decodeFromBoundingBoxes(boxes); - result = result || {}; - result.boxes = boxes; - publishResult(result, _inputImageWrapper.data); - } else { - publishResult(); - } + +/***/ }, +/* 7 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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 _ + * @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 && typeof value == 'object'; } - function update() { - var availableWorker; + module.e = isObjectLike; + + +/***/ }, +/* 8 */ +/***/ function(module, exports) { + + "use strict"; - 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(); - } + exports.__esModule = true; + exports.default = { + init: function init(arr, val) { + var l = arr.length; + while (l--) { + arr[l] = val; } - } else { - locateAndDecode(); - } - } + }, - function startContinuousUpdate() { - var next = null, - delay = 1000 / (_config.frequency || 60); + /** + * 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; + }, - _stopped = false; - (function frame(timestamp) { - next = next || timestamp; - if (!_stopped) { - if (timestamp >= next) { - next += delay; - update(); + 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]; } - window.requestAnimFrame(frame); + rows[i] = "[" + row.join(",") + "]"; } - })(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 - }; + return "[" + rows.join(",\r\n") + "]"; + }, - blobURL = generateWorkerBlob(); - workerThread.worker = new Worker(blobURL); + /** + * 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; + }, - 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"); + maxIndex: function maxIndex(arr) { + var i, + max = 0; + for (i = 0; i < arr.length; i++) { + if (arr[i] > arr[max]) { + max = i; } - 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); + } + 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; + }, - workerThread.worker.postMessage({ - cmd: 'init', - size: { x: _inputStream.getWidth(), y: _inputStream.getHeight() }, - imageData: workerThread.imageData, - config: _config - }, [workerThread.imageData.buffer]); - } + sum: function sum(arr) { + var length = arr.length, + sum = 0; - function workerInterface(factory) { - /* eslint-disable no-undef*/ - if (factory) { - var Quagga = factory(); - if (!Quagga) { - self.postMessage({ 'event': 'error', message: 'Quagga could not be created' }); - return; + while (length--) { + sum += arr[length]; } + return sum; } - var imageWrapper; + }; + +/***/ }, +/* 9 */ +/***/ function(module, exports) { + + "use strict"; - 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); + 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]); } - }; - - function onProcessed(result) { - self.postMessage({ - 'event': 'processed', - imageData: imageWrapper.data, - result: result - }, [imageWrapper.data.buffer]); - } + 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; - function ready() { - // eslint-disable-line - self.postMessage({ 'event': 'initialized', imageData: imageWrapper.data }, [imageWrapper.data.buffer]); + 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__) { + + "use strict"; - /* eslint-enable */ - } + exports.__esModule = true; - function generateWorkerBlob() { - var blob, factorySource; + var _barcode_reader = __webpack_require__(5); - /* jshint ignore:start */ - if (typeof __factorySource__ !== 'undefined') { - factorySource = __factorySource__; // eslint-disable-line no-undef - } - /* jshint ignore:end */ + var _barcode_reader2 = _interopRequireDefault(_barcode_reader); - blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'], { type: 'text/javascript' }); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - return window.URL.createObjectURL(blob); + function EANReader(opts) { + _barcode_reader2.default.call(this, opts); } - 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 }); - }); - } - } + var properties = { + CODE_L_START: { value: 0 }, + MODULO: { value: 7 }, + CODE_G_START: { value: 10 }, + START_PATTERN: { value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7] }, + STOP_PATTERN: { value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7] }, + MIDDLE_PATTERN: { value: [1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7] }, + 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.67 }, + AVG_CODE_ERROR: { value: 0.27 }, + FORMAT: { value: "ean_13", writeable: false } + }; - 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(); - } - }; + EANReader.prototype = Object.create(_barcode_reader2.default.prototype, properties); + EANReader.prototype.constructor = EANReader; - for (var i = 0; i < increaseBy; i++) { - initWorker(workerInitialized); - } + 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, + normalized; + + if (!coderange) { + coderange = self.CODE_PATTERN.length; } - } - exports['default'] = { - init: function init(config, cb, imageWrapper) { - _config = merge({}, _configConfig2['default'], config); - if (imageWrapper) { - _onUIThread = false; - initializeData(imageWrapper); - return cb(); + for (i = offset; i < self._row.length; i++) { + if (self._row[i] ^ isWhite) { + counter[counterPos]++; } else { - initInputStream(cb); - } - }, - start: function start() { - _start(); - }, - stop: function stop() { - _stopped = true; - adjustWorkerPool(0); - if (_config.inputStream.type === "LiveStream") { - _inputCamera_access2['default'].release(); - _inputStream.clearEventHandlers(); - } - }, - pause: function pause() { - _stopped = true; - }, - onDetected: function onDetected(callback) { - _commonEvents2['default'].subscribe("detected", callback); - }, - offDetected: function offDetected(callback) { - _commonEvents2['default'].unsubscribe("detected", callback); - }, - onProcessed: function onProcessed(callback) { - _commonEvents2['default'].subscribe("processed", callback); - }, - offProcessed: function offProcessed(callback) { - _commonEvents2['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) { - config = merge({ - inputStream: { - type: "ImageStream", - sequence: false, - size: 800, - src: config.src - }, - numOfWorkers: false ? 0 : 1, - locator: { - halfSample: false + if (counterPos === counter.length - 1) { + normalized = self._normalize(counter); + if (normalized) { + for (code = 0; code < coderange; code++) { + error = self._matchPattern(normalized, 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++; } - }, config); - this.init(config, function () { - _commonEvents2['default'].once("processed", function (result) { - _stopped = true; - resultCallback.call(null, result); - }, true); - _start(); - }); - }, - ImageWrapper: _commonImage_wrapper2['default'], - ImageDebug: _commonImage_debug2['default'], - ResultCollector: _analyticsResult_collector2['default'] - }; - module.exports = exports['default']; - -/***/ }, -/* 2 */ -/***/ function(module, exports) { - - /* - * typedefs.js - * Normalizes browser-specific prefixes - */ - - 'use strict'; - - 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); - }; - })(); - - navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia; - window.URL = window.URL || window.webkitURL || window.mozURL || window.msURL; - } - 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; + counter[counterPos] = 1; + isWhite = !isWhite; + } + } + return null; }; - -/***/ }, -/* 3 */ -/***/ function(module, exports, __webpack_require__) { - - 'use strict'; - Object.defineProperty(exports, '__esModule', { - value: true - }); + 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, + normalized; - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + if (!offset) { + offset = self._nextSet(self._row); + } - var _subImage = __webpack_require__(4); + if (isWhite === undefined) { + isWhite = false; + } - var _subImage2 = _interopRequireDefault(_subImage); + if (tryHarder === undefined) { + tryHarder = true; + } - var _commonCv_utils = __webpack_require__(5); + if (epsilon === undefined) { + epsilon = self.AVG_CODE_ERROR; + } - var _commonCv_utils2 = _interopRequireDefault(_commonCv_utils); + for (i = 0; i < pattern.length; i++) { + counter[i] = 0; + } - var _commonArray_helper = __webpack_require__(8); + 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]; + } + normalized = self._normalize(counter); + if (normalized) { + error = self._matchPattern(normalized, pattern); - var _commonArray_helper2 = _interopRequireDefault(_commonArray_helper); + 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; + }; - var _glMatrix = __webpack_require__(7); + EANReader.prototype._findStart = function () { + var self = this, + leadingWhitespaceStart, + offset = self._nextSet(self._row), + startInfo; - /** - * 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) { - _commonArray_helper2['default'].init(this.data, 0); - } - } else { - this.data = new Uint8Array(size.x * size.y); - if (Uint8Array === Array && initialize) { - _commonArray_helper2['default'].init(this.data, 0); + 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; } } - } else { - this.data = data; + offset = startInfo.end; + startInfo = null; } - 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; - }; + EANReader.prototype._verifyTrailingWhitespace = function (endInfo) { + var self = this, + trailingWhitespaceEnd; - /** - * 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; + trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start); + if (trailingWhitespaceEnd < self._row.length) { + if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { + return endInfo; + } } + return null; }; - /** - * 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); + 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; }; - /** - * 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]; + 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; }; - ImageWrapper.prototype.copyTo = function (imageWrapper) { - var length = this.data.length, - srcData = this.data, - dstData = imageWrapper.data; + EANReader.prototype._decodePayload = function (code, result, decodedCodes) { + var i, + self = this, + codeFrequency = 0x0, + firstDigit; - while (length--) { - dstData[length] = srcData[length]; + 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); } - }; - /** - * 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]; - }; + firstDigit = self._calculateFirstDigit(codeFrequency); + if (firstDigit === null) { + return null; + } + result.unshift(firstDigit); - /** - * 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; + code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); + if (code === null) { + return null; + } + decodedCodes.push(code); - 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; + 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 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; + return code; }; - /** - * 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; + EANReader.prototype._decode = function () { + var startInfo, + self = this, + code, + result = [], + decodedCodes = []; + + startInfo = self._findStart(); + if (!startInfo) { + return null; } - for (i = 1; i < height - 1; i++) { - data[i * width] = data[i * width + (width - 1)] = 0; + 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; } - }; - /** - * Inverts a binary image in place - */ - ImageWrapper.prototype.invert = function () { - var data = this.data, - length = data.length; + decodedCodes.push(code); - while (length--) { - data[length] = data[length] ? 0 : 1; + // Checksum + if (!self._checksum(result)) { + return null; } + + return { + code: result.join(""), + start: startInfo.start, + end: code.end, + codeset: "", + startInfo: startInfo, + decodedCodes: decodedCodes + }; }; - 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; + EANReader.prototype._checksum = function (result) { + var sum = 0, + i; - if (labelcount <= 0) { - return result; + for (i = result.length - 2; i >= 0; i -= 2) { + sum += result[i]; } - - for (i = 0; i < labelcount; i++) { - labelsum[i] = { - m00: 0, - m01: 0, - m10: 0, - m11: 0, - m02: 0, - m20: 0, - theta: 0, - rad: 0 - }; + sum *= 3; + for (i = result.length - 1; i >= 0; i -= 2) { + sum += result[i]; } + return sum % 10 === 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; - } - } - } + exports.default = EANReader; + +/***/ }, +/* 11 */ +/***/ function(module, exports, __webpack_require__) { + + var eq = __webpack_require__(15); - 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 = _glMatrix.vec2.clone([Math.cos(tmp), Math.sin(tmp)]); - result.push(label); - } + /** + * Gets the index at which the first occurrence of `key` is found in `array` + * of key-value pairs. + * + * @private + * @param {Array} array The array to search. + * @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; + } - return result; - }; + module.e = assocIndexOf; + + +/***/ }, +/* 12 */ +/***/ function(module, exports, __webpack_require__) { + + var isNative = __webpack_require__(139); /** - * 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 + * 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`. */ - 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); - }; + function getNative(object, key) { + var value = object[key]; + return isNative(value) ? value : undefined; + } + module.e = getNative; + + +/***/ }, +/* 13 */ +/***/ function(module, exports, __webpack_require__) { + /** - * 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 + * 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`. */ - 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 : _commonCv_utils2['default'].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); - }; + function isKeyable(value) { + var type = typeof value; + return type == 'number' || type == 'boolean' || + (type == 'string' && value != '__proto__') || value == null; + } - exports['default'] = ImageWrapper; - module.exports = exports['default']; + module.e = isKeyable; + /***/ }, -/* 4 */ -/***/ function(module, exports) { +/* 14 */ +/***/ function(module, exports, __webpack_require__) { + + var getNative = __webpack_require__(12); + + /* Built-in method references that are verified to be native. */ + var nativeCreate = getNative(Object, 'create'); + + module.e = nativeCreate; + + +/***/ }, +/* 15 */ +/***/ function(module, exports, __webpack_require__) { /** - * 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 + * Performs a [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero) + * comparison between two values to determine if they are equivalent. + * + * @static + * @memberOf _ + * @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 = { 'user': 'fred' }; + * var other = { 'user': 'fred' }; + * + * _.eq(object, object); + * // => true + * + * _.eq(object, other); + * // => false + * + * _.eq('a', 'a'); + * // => true + * + * _.eq('a', Object('a')); + * // => false + * + * _.eq(NaN, NaN); + * // => true */ - 'use strict'; + function eq(value, other) { + return value === other || (value !== value && other !== other); + } - Object.defineProperty(exports, '__esModule', { - value: true - }); - function SubImage(from, size, I) { - if (!I) { - I = { - data: null, - size: size - }; - } - this.data = I.data; - this.originalSize = I.size; - this.I = I; + module.e = eq; + + +/***/ }, +/* 16 */ +/***/ function(module, exports, __webpack_require__) { + + var isObject = __webpack_require__(2); - this.from = from; - this.size = size; - } + /** `Object#toString` result references. */ + var funcTag = '[object Function]', + genTag = '[object GeneratorFunction]'; + + /** Used for built-in method references. */ + var objectProto = Object.prototype; /** - * 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 + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. */ - 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; - }; + var objectToString = objectProto.toString; /** - * Updates the position of the shared area - * @param from {x,y} The new location - * @returns {SubImage} returns {this} for possible chaining + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false */ - SubImage.prototype.updateFrom = function (from) { - this.from = from; - return this; - }; + function isFunction(value) { + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 8 which returns 'object' for typed array and weak map constructors, + // and PhantomJS 1.9 which returns 'function' for `NodeList` instances. + var tag = isObject(value) ? objectToString.call(value) : ''; + return tag == funcTag || tag == genTag; + } - exports['default'] = SubImage; - module.exports = exports['default']; + module.e = isFunction; + /***/ }, -/* 5 */ +/* 17 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _cluster = __webpack_require__(6); + 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); @@ -1140,24 +1245,29 @@ module.exports = var _array_helper2 = _interopRequireDefault(_array_helper); - var _glMatrix = __webpack_require__(7); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - var CVUtils = {}; + var vec2 = { + clone: __webpack_require__(6) + }; + var vec3 = { + clone: __webpack_require__(77) + }; /** * @param x x-coordinate * @param y y-coordinate * @return ImageReference {x,y} Coordinate */ - CVUtils.imageRef = function (x, y) { + function imageRef(x, y) { var that = { x: x, y: y, toVec2: function toVec2() { - return _glMatrix.vec2.clone([this.x, this.y]); + return vec2.clone([this.x, this.y]); }, toVec3: function toVec3() { - return _glMatrix.vec3.clone([this.x, this.y, 1]); + 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); @@ -1172,7 +1282,7 @@ module.exports = * Computes an integral image of a given grayscale image. * @param imageDataContainer {ImageDataContainer} the image to be integrated */ - CVUtils.computeIntegralImage2 = function (imageWrapper, integralWrapper) { + function computeIntegralImage2(imageWrapper, integralWrapper) { var imageData = imageWrapper.data; var width = imageWrapper.size.x; var height = imageWrapper.size.y; @@ -1220,7 +1330,7 @@ module.exports = } }; - CVUtils.computeIntegralImage = function (imageWrapper, integralWrapper) { + function computeIntegralImage(imageWrapper, integralWrapper) { var imageData = imageWrapper.data; var width = imageWrapper.size.x; var height = imageWrapper.size.y; @@ -1242,7 +1352,7 @@ module.exports = } }; - CVUtils.thresholdImage = function (imageWrapper, threshold, targetWrapper) { + function thresholdImage(imageWrapper, threshold, targetWrapper) { if (!targetWrapper) { targetWrapper = imageWrapper; } @@ -1255,7 +1365,7 @@ module.exports = } }; - CVUtils.computeHistogram = function (imageWrapper, bitsPerPixel) { + function computeHistogram(imageWrapper, bitsPerPixel) { if (!bitsPerPixel) { bitsPerPixel = 8; } @@ -1271,7 +1381,7 @@ module.exports = return hist; }; - CVUtils.sharpenLine = function (line) { + function sharpenLine(line) { var i, length = line.length, left = line[0], @@ -1288,7 +1398,7 @@ module.exports = return line; }; - CVUtils.determineOtsuThreshold = function (imageWrapper, bitsPerPixel) { + function determineOtsuThreshold(imageWrapper, bitsPerPixel) { if (!bitsPerPixel) { bitsPerPixel = 8; } @@ -1327,7 +1437,7 @@ module.exports = m12, max = (1 << bitsPerPixel) - 1; - hist = CVUtils.computeHistogram(imageWrapper, bitsPerPixel); + hist = computeHistogram(imageWrapper, bitsPerPixel); for (k = 1; k < max; k++) { p1 = px(0, k); p2 = px(k + 1, max); @@ -1340,23 +1450,23 @@ module.exports = m12 = m1 - m2; vet[k] = m12 * m12 / p12; } - return _array_helper2['default'].maxIndex(vet); + return _array_helper2.default.maxIndex(vet); } threshold = determineThreshold(); return threshold << bitShift; }; - CVUtils.otsuThreshold = function (imageWrapper, targetWrapper) { - var threshold = CVUtils.determineOtsuThreshold(imageWrapper); + function otsuThreshold(imageWrapper, targetWrapper) { + var threshold = determineOtsuThreshold(imageWrapper); - CVUtils.thresholdImage(imageWrapper, threshold, targetWrapper); + thresholdImage(imageWrapper, threshold, targetWrapper); return threshold; }; // local thresholding - CVUtils.computeBinaryImage = function (imageWrapper, integralWrapper, targetWrapper) { - CVUtils.computeIntegralImage(imageWrapper, integralWrapper); + function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) { + computeIntegralImage(imageWrapper, integralWrapper); if (!targetWrapper) { targetWrapper = imageWrapper; @@ -1406,7 +1516,7 @@ module.exports = } }; - CVUtils.cluster = function (points, threshold, property) { + function cluster(points, threshold, property) { var i, k, cluster, @@ -1431,15 +1541,15 @@ module.exports = // iterate over each cloud for (i = 0; i < points.length; i++) { - point = _cluster2['default'].createPoint(points[i], i, property); + point = _cluster2.default.createPoint(points[i], i, property); if (!addToCluster(point)) { - clusters.push(_cluster2['default'].create(point, threshold)); + clusters.push(_cluster2.default.create(point, threshold)); } } return clusters; }; - CVUtils.Tracer = { + var Tracer = exports.Tracer = { trace: function trace(points, vec) { var iteration, maxIterations = 10, @@ -1517,10 +1627,10 @@ module.exports = } }; - CVUtils.DILATE = 1; - CVUtils.ERODE = 2; + var DILATE = exports.DILATE = 1; + var ERODE = exports.ERODE = 2; - CVUtils.dilate = function (inImageWrapper, outImageWrapper) { + function dilate(inImageWrapper, outImageWrapper) { var v, u, inImageData = inImageWrapper.data, @@ -1545,7 +1655,7 @@ module.exports = } }; - CVUtils.erode = function (inImageWrapper, outImageWrapper) { + function erode(inImageWrapper, outImageWrapper) { var v, u, inImageData = inImageWrapper.data, @@ -1570,7 +1680,7 @@ module.exports = } }; - CVUtils.subtract = function (aImageWrapper, bImageWrapper, resultImageWrapper) { + function subtract(aImageWrapper, bImageWrapper, resultImageWrapper) { if (!resultImageWrapper) { resultImageWrapper = aImageWrapper; } @@ -1584,7 +1694,7 @@ module.exports = } }; - CVUtils.bitwiseOr = function (aImageWrapper, bImageWrapper, resultImageWrapper) { + function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) { if (!resultImageWrapper) { resultImageWrapper = aImageWrapper; } @@ -1598,7 +1708,7 @@ module.exports = } }; - CVUtils.countNonZero = function (imageWrapper) { + function countNonZero(imageWrapper) { var length = imageWrapper.data.length, data = imageWrapper.data, sum = 0; @@ -1609,7 +1719,7 @@ module.exports = return sum; }; - CVUtils.topGeneric = function (list, top, scoreFunc) { + function topGeneric(list, top, scoreFunc) { var i, minIdx = 0, min = 0, @@ -1644,18 +1754,18 @@ module.exports = return queue; }; - CVUtils.grayArrayFromImage = function (htmlImage, offsetX, ctx, array) { + 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; - CVUtils.computeGray(ctxData, array); + computeGray(ctxData, array); }; - CVUtils.grayArrayFromContext = function (ctx, size, offset, array) { + function grayArrayFromContext(ctx, size, offset, array) { var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data; - CVUtils.computeGray(ctxData, array); + computeGray(ctxData, array); }; - CVUtils.grayAndHalfSampleFromCanvasData = function (canvasData, size, outArray) { + function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) { var topRowIdx = 0; var bottomRowIdx = size.x; var endIdx = Math.floor(canvasData.length / 4); @@ -1676,7 +1786,7 @@ module.exports = } }; - CVUtils.computeGray = function (imageData, outArray, config) { + function computeGray(imageData, outArray, config) { var l = imageData.length / 4 | 0, i, singleChannel = config && config.singleChannel === true; @@ -1692,7 +1802,7 @@ module.exports = } }; - CVUtils.loadImageArray = function (src, callback, canvas) { + function loadImageArray(src, callback, canvas) { if (!canvas) { canvas = document.createElement('canvas'); } @@ -1706,7 +1816,7 @@ module.exports = var array = new Uint8Array(this.width * this.height); ctx.drawImage(this, 0, 0); var data = ctx.getImageData(0, 0, this.width, this.height).data; - CVUtils.computeGray(data, array); + computeGray(data, array); this.callback(array, { x: this.width, y: this.height @@ -1719,7 +1829,7 @@ module.exports = * @param inImg {ImageWrapper} input image to be sampled * @param outImg {ImageWrapper} to be stored in */ - CVUtils.halfSample = function (inImgWrapper, outImgWrapper) { + function halfSample(inImgWrapper, outImgWrapper) { var inImg = inImgWrapper.data; var inWidth = inImgWrapper.size.x; var outImg = outImgWrapper.data; @@ -1740,7 +1850,7 @@ module.exports = } }; - CVUtils.hsv2rgb = function (hsv, rgb) { + function hsv2rgb(hsv, rgb) { var h = hsv[0], s = hsv[1], v = hsv[2], @@ -1778,7 +1888,7 @@ module.exports = return rgb; }; - CVUtils._computeDivisors = function (n) { + function _computeDivisors(n) { var largeDivisors = [], divisors = [], i; @@ -1794,7 +1904,7 @@ module.exports = return divisors.concat(largeDivisors); }; - CVUtils._computeIntersection = function (arr1, arr2) { + function _computeIntersection(arr1, arr2) { var i = 0, j = 0, result = []; @@ -1813,11 +1923,11 @@ module.exports = return result; }; - CVUtils.calculatePatchSize = function (patchSize, imgSize) { - var divisorsX = this._computeDivisors(imgSize.x), - divisorsY = this._computeDivisors(imgSize.y), + function calculatePatchSize(patchSize, imgSize) { + var divisorsX = _computeDivisors(imgSize.x), + divisorsY = _computeDivisors(imgSize.y), wideSide = Math.max(imgSize.x, imgSize.y), - common = this._computeIntersection(divisorsX, divisorsY), + common = _computeIntersection(divisorsX, divisorsY), nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80], nrOfPatchesMap = { "x-small": 5, @@ -1853,15 +1963,15 @@ module.exports = optimalPatchSize = findPatchSizeForDivisors(common); if (!optimalPatchSize) { - optimalPatchSize = findPatchSizeForDivisors(this._computeDivisors(wideSide)); + optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide)); if (!optimalPatchSize) { - optimalPatchSize = findPatchSizeForDivisors(this._computeDivisors(desiredPatchSize * nrOfPatches)); + optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(desiredPatchSize * nrOfPatches)); } } return optimalPatchSize; }; - CVUtils._parseCSSDimensionValues = function (value) { + function _parseCSSDimensionValues(value) { var dimension = { value: parseFloat(value), unit: value.indexOf("%") === value.length - 1 ? "%" : "%" @@ -1870,7 +1980,7 @@ module.exports = return dimension; }; - CVUtils._dimensionsConverters = { + var _dimensionsConverters = exports._dimensionsConverters = { top: function top(dimension, context) { if (dimension.unit === "%") { return Math.floor(context.height * (dimension.value / 100)); @@ -1893,13 +2003,13 @@ module.exports = } }; - CVUtils.computeImageArea = function (inputWidth, inputHeight, area) { + 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 = CVUtils._parseCSSDimensionValues(value), - calculated = CVUtils._dimensionsConverters[key](parsed, context); + parsed = _parseCSSDimensionValues(value), + calculated = _dimensionsConverters[key](parsed, context); result[key] = calculated; return result; @@ -1912,2565 +2022,4979 @@ module.exports = sh: parsedArea.bottom - parsedArea.top }; }; - - exports['default'] = CVUtils; - module.exports = exports['default']; /***/ }, -/* 6 */ +/* 18 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; - Object.defineProperty(exports, '__esModule', { - value: true - }); + exports.__esModule = true; - var _glMatrix = __webpack_require__(7); + var _subImage = __webpack_require__(55); - /** - * Creates a cluster for grouping similar orientations of datapoints - */ - exports['default'] = { - create: function create(point, threshold) { - var points = [], - center = { - rad: 0, - vec: _glMatrix.vec2.clone([0, 0]) - }, - pointMap = {}; + var _subImage2 = _interopRequireDefault(_subImage); - function init() { - _add(point); - updateCenter(); - } + var _cv_utils = __webpack_require__(17); - function _add(pointToAdd) { - pointMap[pointToAdd.id] = pointToAdd; - points.push(pointToAdd); - } + var _array_helper = __webpack_require__(8); - function updateCenter() { - var i, - sum = 0; - for (i = 0; i < points.length; i++) { - sum += points[i].rad; + var _array_helper2 = _interopRequireDefault(_array_helper); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + var vec2 = { + clone: __webpack_require__(6) + }; + + /** + * 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); } - center.rad = sum / points.length; - center.vec = _glMatrix.vec2.clone([Math.cos(center.rad), Math.sin(center.rad)]); } + } else { + this.data = data; + } + this.size = size; + } - init(); + /** + * 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; + }; - 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(_glMatrix.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 - }; + /** + * 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; } }; - module.exports = exports['default']; - -/***/ }, -/* 7 */ -/***/ function(module, exports) { - - module.exports = require("gl-matrix"); - -/***/ }, -/* 8 */ -/***/ function(module, exports) { - - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports["default"] = { - init: function init(arr, val) { - var l = arr.length; - while (l--) { - arr[l] = val; - } - }, + /** + * 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); + }; - /** - * 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; + /** + * 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]; } - 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; - }, + ImageWrapper.prototype.copyTo = function (imageWrapper) { + var length = this.data.length, + srcData = this.data, + dstData = imageWrapper.data; - maxIndex: function maxIndex(arr) { - var i, - max = 0; - for (i = 0; i < arr.length; i++) { - if (arr[i] > arr[max]) { - max = i; - } - } - return max; - }, + while (length--) { + dstData[length] = srcData[length]; + } + }; - max: function max(arr) { - var i, - max = 0; - for (i = 0; i < arr.length; i++) { - if (arr[i] > max) { - max = arr[i]; - } - } - return max; - }, + /** + * 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]; + }; - sum: function sum(arr) { - var length = arr.length, - sum = 0; + /** + * 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; - while (length--) { - sum += arr[length]; + 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 sum; } + return this.data[this.indexMapping.y[y + this.size.y] * this.size.x + this.indexMapping.x[x + this.size.x]]; }; - module.exports = exports["default"]; - -/***/ }, -/* 9 */ -/***/ function(module, exports, __webpack_require__) { - - /* WEBPACK VAR INJECTION */(function(global) {'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _commonImage_wrapper = __webpack_require__(3); - - var _commonImage_wrapper2 = _interopRequireDefault(_commonImage_wrapper); - var _commonCv_utils = __webpack_require__(5); - - var _commonCv_utils2 = _interopRequireDefault(_commonCv_utils); + /** + * 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; + }; - var _commonArray_helper = __webpack_require__(8); + /** + * 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; + } + }; - var _commonArray_helper2 = _interopRequireDefault(_commonArray_helper); + /** + * Inverts a binary image in place + */ + ImageWrapper.prototype.invert = function () { + var data = this.data, + length = data.length; - var _commonImage_debug = __webpack_require__(10); + while (length--) { + data[length] = data[length] ? 0 : 1; + } + }; - var _commonImage_debug2 = _interopRequireDefault(_commonImage_debug); + 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; + } + } + }; - var _rasterizer = __webpack_require__(11); + 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; - var _rasterizer2 = _interopRequireDefault(_rasterizer); + if (labelcount <= 0) { + return result; + } - var _tracer = __webpack_require__(12); + for (i = 0; i < labelcount; i++) { + labelsum[i] = { + m00: 0, + m01: 0, + m10: 0, + m11: 0, + m02: 0, + m20: 0, + theta: 0, + rad: 0 + }; + } - var _tracer2 = _interopRequireDefault(_tracer); + 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; + } + } + } - var _skeletonizer2 = __webpack_require__(13); + 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); + } + } - var _skeletonizer3 = _interopRequireDefault(_skeletonizer2); + return result; + }; - var _glMatrix = __webpack_require__(7); + /** + * 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; - var _config, - _currentImageWrapper, - _skelImageWrapper, - _subImageWrapper, - _labelImageWrapper, - _patchGrid, - _patchLabelGrid, - _imageToPatchGrid, - _binaryImageWrapper, - _patchSize, - _canvasContainer = { - ctx: { - binary: null - }, - dom: { - binary: null + if (!scale) { + scale = 1.0; } - }, - _numPatches = { x: 0, y: 0 }, - _inputImageWrapper, - _skeletonizer; - - function initBuffers() { - var skeletonImageData; - - if (_config.halfSample) { - _currentImageWrapper = new _commonImage_wrapper2['default']({ - x: _inputImageWrapper.size.x / 2 | 0, - y: _inputImageWrapper.size.y / 2 | 0 - }); - } else { - _currentImageWrapper = _inputImageWrapper; + 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); + }; - _patchSize = _commonCv_utils2['default'].calculatePatchSize(_config.patchSize, _currentImageWrapper.size); - - _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0; - _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0; - - _binaryImageWrapper = new _commonImage_wrapper2['default'](_currentImageWrapper.size, undefined, Uint8Array, false); - - _labelImageWrapper = new _commonImage_wrapper2['default'](_patchSize, undefined, Array, true); + /** + * 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); + }; - skeletonImageData = new ArrayBuffer(64 * 1024); - _subImageWrapper = new _commonImage_wrapper2['default'](_patchSize, new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y)); - _skelImageWrapper = new _commonImage_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); + exports.default = ImageWrapper; + +/***/ }, +/* 19 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * A specialized version of `_.reduce` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @param {boolean} [initAccum] Specify using the first element of `array` as the initial value. + * @returns {*} Returns the accumulated value. + */ + function arrayReduce(array, iteratee, accumulator, initAccum) { + var index = -1, + length = array.length; - _imageToPatchGrid = new _commonImage_wrapper2['default']({ - x: _currentImageWrapper.size.x / _subImageWrapper.size.x | 0, - y: _currentImageWrapper.size.y / _subImageWrapper.size.y | 0 - }, undefined, Array, true); - _patchGrid = new _commonImage_wrapper2['default'](_imageToPatchGrid.size, undefined, undefined, true); - _patchLabelGrid = new _commonImage_wrapper2['default'](_imageToPatchGrid.size, undefined, Int32Array, true); + if (initAccum && length) { + accumulator = array[++index]; + } + while (++index < length) { + accumulator = iteratee(accumulator, array[index], index, array); + } + return accumulator; } - 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; - } + module.e = arrayReduce; + + +/***/ }, +/* 20 */ +/***/ function(module, exports, __webpack_require__) { + + var copyObjectWith = __webpack_require__(110); /** - * Creates a bounding box which encloses all the given patches - * @returns {Array} The minimal bounding box + * Copies properties of `source` to `object`. + * + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property names to copy. + * @param {Object} [object={}] The object to copy properties to. + * @returns {Object} Returns `object`. */ - 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) { - _commonImage_debug2['default'].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "red" }); - } - } + function copyObject(source, props, object) { + return copyObjectWith(source, props, object); + } - overAvg /= patches.length; - overAvg = (overAvg * 180 / Math.PI + 90) % 180 - 90; - if (overAvg < 0) { - overAvg += 180; - } + module.e = copyObject; + + +/***/ }, +/* 21 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Checks if `value` is a host object in IE < 9. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a host object, else `false`. + */ + function isHostObject(value) { + // Many host objects are `Object` objects that can coerce to strings + // despite having improperly defined `toString` methods. + var result = false; + if (value != null && typeof value.toString != 'function') { + try { + result = !!(value + ''); + } catch (e) {} + } + return result; + } - overAvg = (180 - overAvg) * Math.PI / 180; - transMat = _glMatrix.mat2.clone([Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]); + module.e = isHostObject; + + +/***/ }, +/* 22 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used as references for various `Number` constants. */ + var MAX_SAFE_INTEGER = 9007199254740991; - // iterate over patches and rotate by angle - for (i = 0; i < patches.length; i++) { - patch = patches[i]; - for (j = 0; j < 4; j++) { - _glMatrix.vec2.transformMat2(patch.box[j], patch.box[j], transMat); - } + /** Used to detect unsigned integer values. */ + var reIsUint = /^(?:0|[1-9]\d*)$/; - if (false) { - _commonImage_debug2['default'].drawPath(patch.box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#99ff00', lineWidth: 2 }); - } - } + /** + * 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) { + value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1; + length = length == null ? MAX_SAFE_INTEGER : length; + return value > -1 && value % 1 == 0 && value < length; + } - // 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]; - } - } - } + module.e = isIndex; + + +/***/ }, +/* 23 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used for built-in method references. */ + var objectProto = Object.prototype; - box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]]; + /** + * 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; - if (false) { - _commonImage_debug2['default'].drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); - } + return value === proto; + } - scale = _config.halfSample ? 2 : 1; - // reverse rotation; - transMat = _glMatrix.mat2.invert(transMat, transMat); - for (j = 0; j < 4; j++) { - _glMatrix.vec2.transformMat2(box[j], box[j], transMat); - } + module.e = isPrototype; + + +/***/ }, +/* 24 */ +/***/ function(module, exports, __webpack_require__) { + + var isArrayLikeObject = __webpack_require__(26); - if (false) { - _commonImage_debug2['default'].drawPath(box, { x: 0, y: 1 }, _canvasContainer.ctx.binary, { color: '#ff0000', lineWidth: 2 }); - } + /** `Object#toString` result references. */ + var argsTag = '[object Arguments]'; - for (j = 0; j < 4; j++) { - _glMatrix.vec2.scale(box[j], box[j], scale); - } + /** Used for built-in method references. */ + var objectProto = Object.prototype; - return box; - } + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; /** - * Creates a binary image of the current image + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. */ - function binarizeImage() { - _commonCv_utils2['default'].otsuThreshold(_currentImageWrapper, _binaryImageWrapper); - _binaryImageWrapper.zeroBorder(); - if (_config.showCanvas) { - _binaryImageWrapper.show(_canvasContainer.dom.binary, 255); - } - } + var objectToString = objectProto.toString; + + /** Built-in value references. */ + var propertyIsEnumerable = objectProto.propertyIsEnumerable; /** - * 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(); - _commonArray_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)); - } - } + * Checks if `value` is likely an `arguments` object. + * + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example + * + * _.isArguments(function() { return arguments; }()); + * // => true + * + * _.isArguments([1, 2, 3]); + * // => false + */ + function isArguments(value) { + // Safari 8.1 incorrectly makes `arguments.callee` enumerable in strict mode. + return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') && + (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag); + } - if (false) { - for (i = 0; i < patchesFound.length; i++) { - patch = patchesFound[i]; - _commonImage_debug2['default'].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "#99ff00", lineWidth: 2 }); - } - } + module.e = isArguments; + + +/***/ }, +/* 25 */ +/***/ function(module, exports, __webpack_require__) { + + var getLength = __webpack_require__(114), + isFunction = __webpack_require__(16), + isLength = __webpack_require__(27); - return patchesFound; + /** + * 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 _ + * @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(getLength(value)) && !isFunction(value); } + module.e = isArrayLike; + + +/***/ }, +/* 26 */ +/***/ function(module, exports, __webpack_require__) { + + var isArrayLike = __webpack_require__(25), + isObjectLike = __webpack_require__(7); + /** - * Finds those connected areas which contain at least 6 patches - * and returns them ordered DESC by the number of contained patches - * @param {Number} maxLabel + * This method is like `_.isArrayLike` except that it also checks if `value` + * is an object. + * + * @static + * @memberOf _ + * @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 findBiggestConnectedAreas(maxLabel) { - var i, - sum, - labelHist = [], - topLabels = []; + function isArrayLikeObject(value) { + return isObjectLike(value) && isArrayLike(value); + } - 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]++; - } - } + module.e = isArrayLikeObject; + + +/***/ }, +/* 27 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used as references for various `Number` constants. */ + var MAX_SAFE_INTEGER = 9007199254740991; - labelHist = labelHist.map(function (val, idx) { - return { - val: val, - label: idx + 1 - }; - }); + /** + * Checks if `value` is a valid array-like length. + * + * **Note:** This function is loosely based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). + * + * @static + * @memberOf _ + * @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; + } - labelHist.sort(function (a, b) { - return b.val - a.val; - }); + module.e = isLength; + + +/***/ }, +/* 28 */ +/***/ function(module, exports, __webpack_require__) { + + var baseMerge = __webpack_require__(98), + createAssigner = __webpack_require__(112); - // extract top areas with at least 6 patches present - topLabels = labelHist.filter(function (el) { - return el.val >= 5; - }); + /** + * This method is like `_.assign` except that it recursively merges own and + * inherited enumerable 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 _ + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @example + * + * var users = { + * 'data': [{ 'user': 'barney' }, { 'user': 'fred' }] + * }; + * + * var ages = { + * 'data': [{ 'age': 36 }, { 'age': 40 }] + * }; + * + * _.merge(users, ages); + * // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] } + */ + var merge = createAssigner(function(object, source, srcIndex) { + baseMerge(object, source, srcIndex); + }); - return topLabels; - } + module.e = merge; + + +/***/ }, +/* 29 */ +/***/ function(module, exports) { + + "use strict"; + exports.__esModule = true; /** - * + * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization */ - function findBoxes(topLabels, maxLabel) { - var i, - j, - sum, - patches = [], - patch, - box, - boxes = [], - hsv = [0, 1, 1], - rgb = [0, 0, 0]; + 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; - 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); + function _trace(current, color, label, edgelabel) { + var i, y, x; - // 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; - _commonCv_utils2['default'].hsv2rgb(hsv, rgb); - _commonImage_debug2['default'].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "rgb(" + rgb.join(",") + ")", lineWidth: 2 }); + 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; } - } - return boxes; - } - /** - * Find similar moments (via cluster) - * @param {Object} moments - */ - function similarMoments(moments) { - var clusters = _commonCv_utils2['default'].cluster(moments, 0.90); - var topCluster = _commonCv_utils2['default'].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); + function vertex2D(x, y, dir) { + return { + dir: dir, + x: x, + y: y, + next: null, + prev: null + }; } - } - return result; - } - - function skeletonize(x, y) { - _binaryImageWrapper.subImageAsCopy(_subImageWrapper, _commonCv_utils2['default'].imageRef(x, y)); - _skeletonizer.skeletonize(); - - // Show skeleton if requested - if (false) { - _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, _commonCv_utils2['default'].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); + function _contourTracing(sy, sx, label, color, edgelabel) { + var Fv = null, + Cv, + P, + ldir, + current = { + cx: sx, + cy: sy, + dir: 0 + }; - 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 (_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; } - // 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: [_glMatrix.vec2.clone([x, y]), _glMatrix.vec2.clone([x + _subImageWrapper.size.x, y]), _glMatrix.vec2.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]), _glMatrix.vec2.clone([x, y + _subImageWrapper.size.y])], - moments: matchingMoments, - rad: avg, - vec: _glMatrix.vec2.clone([Math.cos(avg), Math.sin(avg)]) - }; - patchesFound.push(patch); + 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); } - } + }; } - 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]; + exports.default = Tracer; + +/***/ }, +/* 30 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; - 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; - } + exports.__esModule = true; - function trace(currentIdx) { - var x, - y, - currentPatch, - idx, - dir, - current = { - x: currentIdx % _patchLabelGrid.size.x, - y: currentIdx / _patchLabelGrid.size.x | 0 - }, - similarity; + var _barcode_reader = __webpack_require__(5); - 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; + var _barcode_reader2 = _interopRequireDefault(_barcode_reader); - // continue if patch empty - if (_patchGrid.data[idx] === 0) { - _patchLabelGrid.data[idx] = Number.MAX_VALUE; - continue; - } + var _array_helper = __webpack_require__(8); - if (_patchLabelGrid.data[idx] === 0) { - similarity = Math.abs(_glMatrix.vec2.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec)); - if (similarity > threshold) { - trace(idx); - } - } - } - } - } + var _array_helper2 = _interopRequireDefault(_array_helper); - // prepare for finding the right patches - _commonArray_helper2['default'].init(_patchGrid.data, 0); - _commonArray_helper2['default'].init(_patchLabelGrid.data, 0); - _commonArray_helper2['default'].init(_imageToPatchGrid.data, null); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - for (j = 0; j < patchesFound.length; j++) { - patch = patchesFound[j]; - _imageToPatchGrid.data[patch.index] = patch; - _patchGrid.data[patch.index] = 1; - } + function Code39Reader() { + _barcode_reader2.default.call(this); + } - // rasterize the patches found to determine area - _patchGrid.zeroBorder(); + 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 } + }; - while ((currIdx = notYetProcessed()) < _patchLabelGrid.data.length) { - label++; - trace(currIdx); - } + Code39Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties); + Code39Reader.prototype.constructor = Code39Reader; - // 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; - _commonCv_utils2['default'].hsv2rgb(hsv, rgb); - _commonImage_debug2['default'].drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, { color: "rgb(" + rgb.join(",") + ")", lineWidth: 2 }); + Code39Reader.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 label; - } - - exports['default'] = { - init: function init(inputImageWrapper, config) { - _config = config; - _inputImageWrapper = inputImageWrapper; - - initBuffers(); - initCanvas(); - }, + return counter; + }; - locate: function locate() { - var patchesFound, topLabels, boxes; + 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 (_config.halfSample) { - _commonCv_utils2['default'].halfSample(_inputImageWrapper, _currentImageWrapper); - } + if (!start) { + return null; + } + nextStart = self._nextSet(self._row, start.end); - binarizeImage(); - patchesFound = findPatches(); - // return unless 5% or more patches are found - if (patchesFound.length < _numPatches.x * _numPatches.y * 0.05) { + do { + counters = self._toCounters(nextStart, counters); + pattern = self._toPattern(counters); + if (pattern < 0) { return null; } - - // rasterrize area by comparing angular similarity; - var maxLabel = rasterizeAngularSimilarity(patchesFound); - if (maxLabel < 1) { + 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(); - // search for area with the most patches (biggest connected area) - topLabels = findBiggestConnectedAreas(maxLabel); - if (topLabels.length === 0) { - return null; - } + if (!result.length) { + return null; + } - boxes = findBoxes(topLabels, maxLabel); - return boxes; - }, + if (!self._verifyTrailingWhitespace(lastStart, nextStart, counters)) { + return null; + } - checkImageConstraints: function checkImageConstraints(inputStream, config) { - var patchSize, - width = inputStream.getWidth(), - height = inputStream.getHeight(), - halfSample = config.halfSample ? 0.5 : 1, - size, - area; + return { + code: result.join(""), + start: start.start, + end: nextStart, + startInfo: start, + decodedCodes: result + }; + }; - // calculate width and height based on area - if (inputStream.getConfig().area) { - area = _commonCv_utils2['default'].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; - } + Code39Reader.prototype._verifyTrailingWhitespace = function (lastStart, nextStart, counters) { + var trailingWhitespaceEnd, + patternSize = _array_helper2.default.sum(counters); - size = { - x: Math.floor(width * halfSample), - y: Math.floor(height * halfSample) - }; + trailingWhitespaceEnd = nextStart - lastStart - patternSize; + if (trailingWhitespaceEnd * 3 >= patternSize) { + return true; + } + return false; + }; - patchSize = _commonCv_utils2['default'].calculatePatchSize(config.patchSize, size); - if (false) { - console.log("Patch-Size: " + JSON.stringify(patchSize)); + 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; + }; - 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)); + Code39Reader.prototype._findNextWidth = function (counters, current) { + var i, + minWidth = Number.MAX_VALUE; - if (inputStream.getWidth() % patchSize.x === 0 && inputStream.getHeight() % patchSize.y === 0) { - return true; + for (i = 0; i < counters.length; i++) { + if (counters[i] < minWidth && counters[i] > current) { + minWidth = counters[i]; } - - throw new Error("Image dimensions do not comply with the current settings: Width (" + width + " )and height (" + height + ") must a multiple of " + patchSize.x); } + + return minWidth; }; - module.exports = exports['default']; - /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) - -/***/ }, -/* 10 */ -/***/ function(module, exports) { - - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: 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]); + 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]; + } } - 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; + 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; } - while (imageDataPos--) { - value = imageData[imageDataPos]; - data[--canvasDataPos] = 255; - data[--canvasDataPos] = value; - data[--canvasDataPos] = value; - data[--canvasDataPos] = value; + } + 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; } - ctx.putImageData(canvasData, 0, 0); - return true; } + return null; }; - module.exports = exports["default"]; + + exports.default = Code39Reader; /***/ }, -/* 11 */ +/* 31 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; + module.e = dot - Object.defineProperty(exports, "__esModule", { - value: true - }); + /** + * 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] + } + +/***/ }, +/* 32 */ +/***/ function(module, exports, __webpack_require__) { + + var stackClear = __webpack_require__(132), + stackDelete = __webpack_require__(133), + stackGet = __webpack_require__(134), + stackHas = __webpack_require__(135), + stackSet = __webpack_require__(136); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + /** + * Creates a stack cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [values] The values to cache. + */ + function Stack(values) { + var index = -1, + length = values ? values.length : 0; - var _tracer = __webpack_require__(12); + this.clear(); + while (++index < length) { + var entry = values[index]; + this.set(entry[0], entry[1]); + } + } - var _tracer2 = _interopRequireDefault(_tracer); + // Add functions to the `Stack` cache. + Stack.prototype.clear = stackClear; + Stack.prototype['delete'] = stackDelete; + Stack.prototype.get = stackGet; + Stack.prototype.has = stackHas; + Stack.prototype.set = stackSet; + module.e = Stack; + + +/***/ }, +/* 33 */ +/***/ function(module, exports, __webpack_require__) { + /** - * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization + * A specialized version of `_.forEach` 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 `array`. */ - 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); + function arrayEach(array, iteratee) { + var index = -1, + length = array.length; - return { - rasterize: function rasterize(depthlabel) { - var color, - bc, - lc, - labelindex, - cx, - cy, - colorMap = [], - vertex, - p, - cc, - sc, - pos, - connectedCount = 0, - i; + while (++index < length) { + if (iteratee(array[index], index, array) === false) { + break; + } + } + return array; + } - for (i = 0; i < 400; i++) { - colorMap[i] = 0; - } + module.e = arrayEach; + + +/***/ }, +/* 34 */ +/***/ function(module, exports, __webpack_require__) { + + var eq = __webpack_require__(15); - 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; + /** + * 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)) || + (typeof key == 'number' && value === undefined && !(key in object))) { + object[key] = value; + } + } - ctx.strokeStyle = "red"; - ctx.fillStyle = "red"; - ctx.lineWidth = 1; + module.e = assignMergeValue; + + +/***/ }, +/* 35 */ +/***/ function(module, exports, __webpack_require__) { + + var eq = __webpack_require__(15); - if (pq !== null) { - iq = pq.insideContours; - } else { - iq = null; - } + /** Used for built-in method references. */ + var objectProto = Object.prototype; - 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; - } - } + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; - 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; - } + /** + * Assigns `value` to `key` of `object` if the existing value is not equivalent + * using [`SameValueZero`](http://ecma-international.org/ecma-262/6.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))) { + object[key] = value; + } + } - 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(); - } - } - } - }; - } - }; + module.e = assignValue; + + +/***/ }, +/* 36 */ +/***/ function(module, exports, __webpack_require__) { + + var assocIndexOf = __webpack_require__(11); + + /** 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 associative array. + * + * @private + * @param {Array} array The array to query. + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function assocDelete(array, key) { + var index = assocIndexOf(array, key); + if (index < 0) { + return false; + } + var lastIndex = array.length - 1; + if (index == lastIndex) { + array.pop(); + } else { + splice.call(array, index, 1); + } + return true; + } - exports["default"] = Rasterizer; - module.exports = exports["default"]; + module.e = assocDelete; + /***/ }, -/* 12 */ -/***/ function(module, exports) { +/* 37 */ +/***/ function(module, exports, __webpack_require__) { + var assocIndexOf = __webpack_require__(11); + /** - * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization + * Gets the associative array value for `key`. + * + * @private + * @param {Array} array The array to query. + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. */ - "use strict"; + function assocGet(array, key) { + var index = assocIndexOf(array, key); + return index < 0 ? undefined : array[index][1]; + } - Object.defineProperty(exports, "__esModule", { - value: true - }); - 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; + module.e = assocGet; + + +/***/ }, +/* 38 */ +/***/ function(module, exports, __webpack_require__) { + + var assocIndexOf = __webpack_require__(11); - function _trace(current, color, label, edgelabel) { - var i, y, x; + /** + * Checks if an associative array value for `key` exists. + * + * @private + * @param {Array} array The array to query. + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function assocHas(array, key) { + return assocIndexOf(array, key) > -1; + } - 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 - }; - } + module.e = assocHas; + + +/***/ }, +/* 39 */ +/***/ function(module, exports, __webpack_require__) { + + var assocIndexOf = __webpack_require__(11); - function _contourTracing(sy, sx, label, color, edgelabel) { - var Fv = null, - Cv, - P, - ldir, - current = { - cx: sx, - cy: sy, - dir: 0 - }; + /** + * Sets the associative array `key` to `value`. + * + * @private + * @param {Array} array The array to modify. + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + */ + function assocSet(array, key, value) { + var index = assocIndexOf(array, key); + if (index < 0) { + array.push([key, value]); + } else { + array[index][1] = value; + } + } - 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; - } + module.e = assocSet; + + +/***/ }, +/* 40 */ +/***/ function(module, exports, __webpack_require__) { + + var Uint8Array = __webpack_require__(83); - 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); - } - }; - } - }; + /** + * 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; + } - exports["default"] = Tracer; - module.exports = exports["default"]; + module.e = cloneArrayBuffer; + /***/ }, -/* 13 */ -/***/ function(module, exports) { +/* 41 */ +/***/ function(module, exports, __webpack_require__) { - /* @preserve ASM BEGIN */ - /* eslint-disable eqeqeq*/ - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - function Skeletonizer(stdlib, foreign, buffer) { - "use asm"; + /** + * 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; - var images = new stdlib.Uint8Array(buffer), - size = foreign.size | 0, - imul = stdlib.Math.imul; + array || (array = Array(length)); + while (++index < length) { + array[index] = source[index]; + } + return array; + } - function erode(inImagePtr, outImagePtr) { - inImagePtr = inImagePtr | 0; - outImagePtr = outImagePtr | 0; + module.e = copyArray; + + +/***/ }, +/* 42 */ +/***/ function(module, exports, __webpack_require__) { + + var nativeCreate = __webpack_require__(14); - var v = 0, - u = 0, - sum = 0, - yStart1 = 0, - yStart2 = 0, - xStart1 = 0, - xStart2 = 0, - offset = 0; + /** Used for built-in method references. */ + var objectProto = Object.prototype; - 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; - } + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; - function subtract(aImagePtr, bImagePtr, outImagePtr) { - aImagePtr = aImagePtr | 0; - bImagePtr = bImagePtr | 0; - outImagePtr = outImagePtr | 0; + /** + * Checks if a hash value for `key` exists. + * + * @private + * @param {Object} hash The hash to query. + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function hashHas(hash, key) { + return nativeCreate ? hash[key] !== undefined : hasOwnProperty.call(hash, key); + } - var length = 0; + module.e = hashHas; + + +/***/ }, +/* 43 */ +/***/ function(module, exports, __webpack_require__) { + + var baseTimes = __webpack_require__(102), + isArguments = __webpack_require__(24), + isArray = __webpack_require__(4), + isLength = __webpack_require__(27), + isString = __webpack_require__(141); - length = imul(size, size) | 0; + /** + * Creates an array of index keys for `object` values of arrays, + * `arguments` objects, and strings, otherwise `null` is returned. + * + * @private + * @param {Object} object The object to query. + * @returns {Array|null} Returns index keys, else `null`. + */ + function indexKeys(object) { + var length = object ? object.length : undefined; + if (isLength(length) && + (isArray(object) || isString(object) || isArguments(object))) { + return baseTimes(length, String); + } + return null; + } - while ((length | 0) > 0) { - length = length - 1 | 0; - images[outImagePtr + length | 0] = (images[aImagePtr + length | 0] | 0) - (images[bImagePtr + length | 0] | 0) | 0; - } - } + module.e = indexKeys; + + +/***/ }, +/* 44 */ +/***/ function(module, exports, __webpack_require__) { + + var isLength = __webpack_require__(27), + isObjectLike = __webpack_require__(7); - function bitwiseOr(aImagePtr, bImagePtr, outImagePtr) { - aImagePtr = aImagePtr | 0; - bImagePtr = bImagePtr | 0; - outImagePtr = outImagePtr | 0; + /** `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 length = 0; + var arrayBufferTag = '[object ArrayBuffer]', + 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]'; - length = imul(size, size) | 0; + /** 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[dateTag] = typedArrayTags[errorTag] = + typedArrayTags[funcTag] = typedArrayTags[mapTag] = + typedArrayTags[numberTag] = typedArrayTags[objectTag] = + typedArrayTags[regexpTag] = typedArrayTags[setTag] = + typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false; - while ((length | 0) > 0) { - length = length - 1 | 0; - images[outImagePtr + length | 0] = images[aImagePtr + length | 0] | 0 | (images[bImagePtr + length | 0] | 0) | 0; - } - } + /** Used for built-in method references. */ + var objectProto = Object.prototype; - function countNonZero(imagePtr) { - imagePtr = imagePtr | 0; + /** + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; - var sum = 0, - length = 0; + /** + * Checks if `value` is classified as a typed array. + * + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example + * + * _.isTypedArray(new Uint8Array); + * // => true + * + * _.isTypedArray([]); + * // => false + */ + function isTypedArray(value) { + return isObjectLike(value) && + isLength(value.length) && !!typedArrayTags[objectToString.call(value)]; + } - length = imul(size, size) | 0; + module.e = isTypedArray; + + +/***/ }, +/* 45 */ +/***/ function(module, exports, __webpack_require__) { + + var baseHas = __webpack_require__(95), + baseKeys = __webpack_require__(96), + indexKeys = __webpack_require__(43), + isArrayLike = __webpack_require__(25), + isIndex = __webpack_require__(22), + isPrototype = __webpack_require__(23); - while ((length | 0) > 0) { - length = length - 1 | 0; - sum = (sum | 0) + (images[imagePtr + length | 0] | 0) | 0; - } + /** + * Creates an array of the own enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. See the + * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys) + * for more details. + * + * @static + * @memberOf _ + * @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; + * + * _.keys(new Foo); + * // => ['a', 'b'] (iteration order is not guaranteed) + * + * _.keys('hi'); + * // => ['0', '1'] + */ + function keys(object) { + var isProto = isPrototype(object); + if (!(isProto || isArrayLike(object))) { + return baseKeys(object); + } + var indexes = indexKeys(object), + skipIndexes = !!indexes, + result = indexes || [], + length = result.length; - return sum | 0; + for (var key in object) { + if (baseHas(object, key) && + !(skipIndexes && (key == 'length' || isIndex(key, length))) && + !(isProto && key == 'constructor')) { + result.push(key); } + } + return result; + } - function init(imagePtr, value) { - imagePtr = imagePtr | 0; - value = value | 0; + module.e = keys; + + +/***/ }, +/* 46 */ +/***/ function(module, exports, __webpack_require__) { + + var baseKeysIn = __webpack_require__(97), + indexKeys = __webpack_require__(43), + isIndex = __webpack_require__(22), + isPrototype = __webpack_require__(23); - var length = 0; + /** Used for built-in method references. */ + var objectProto = Object.prototype; - length = imul(size, size) | 0; + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; - while ((length | 0) > 0) { - length = length - 1 | 0; - images[imagePtr + length | 0] = value; - } + /** + * Creates an array of the own and inherited enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @memberOf _ + * @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) { + var index = -1, + isProto = isPrototype(object), + props = baseKeysIn(object), + propsLength = props.length, + indexes = indexKeys(object), + skipIndexes = !!indexes, + result = indexes || [], + length = result.length; + + while (++index < propsLength) { + var key = props[index]; + if (!(skipIndexes && (key == 'length' || isIndex(key, length))) && + !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { + result.push(key); } + } + return result; + } - function dilate(inImagePtr, outImagePtr) { - inImagePtr = inImagePtr | 0; - outImagePtr = outImagePtr | 0; + module.e = keysIn; + + +/***/ }, +/* 47 */ +/***/ function(module, exports, __webpack_require__) { + + var apply = __webpack_require__(87), + toInteger = __webpack_require__(143); - var v = 0, - u = 0, - sum = 0, - yStart1 = 0, - yStart2 = 0, - xStart1 = 0, - xStart2 = 0, - offset = 0; + /** Used as the `TypeError` message for "Functions" methods. */ + var FUNC_ERROR_TEXT = 'Expected a function'; - 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; + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeMax = Math.max; + + /** + * Creates a function that invokes `func` with the `this` binding of the + * created function and arguments from `start` and beyond provided as an array. + * + * **Note:** This method is based on the [rest parameter](https://mdn.io/rest_parameters). + * + * @static + * @memberOf _ + * @category Function + * @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. + * @example + * + * var say = _.rest(function(what, names) { + * return what + ' ' + _.initial(names).join(', ') + + * (_.size(names) > 1 ? ', & ' : '') + _.last(names); + * }); + * + * say('hello', 'fred', 'barney', 'pebbles'); + * // => 'hello fred, barney, & pebbles' + */ + function rest(func, start) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + start = nativeMax(start === undefined ? (func.length - 1) : toInteger(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]; + } + switch (start) { + case 0: return func.call(this, array); + case 1: return func.call(this, args[0], array); + case 2: return func.call(this, args[0], args[1], array); + } + var otherArgs = Array(start + 1); + index = -1; + while (++index < start) { + otherArgs[index] = args[index]; } + otherArgs[start] = array; + return apply(func, this, otherArgs); + }; + } - function memcpy(srcImagePtr, dstImagePtr) { - srcImagePtr = srcImagePtr | 0; - dstImagePtr = dstImagePtr | 0; + module.e = rest; + + +/***/ }, +/* 48 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = function(module) { + if(!module.webpackPolyfill) { + module.deprecate = function() {}; + module.paths = []; + // module.parent = undefined by default + module.children = []; + Object.defineProperty(module, "exports", { + enumerable: true, + configurable: false, + get: function() { return module.e; }, + set: function(v) { return module.e = v; } + }); + Object.defineProperty(module, "loaded", { + enumerable: true, + configurable: false, + get: function() { return module.l; } + }); + Object.defineProperty(module, "id", { + enumerable: true, + configurable: false, + get: function() { return module.i; } + }); + module.webpackPolyfill = 1; + } + return module; + } + + +/***/ }, +/* 49 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; - var length = 0; + exports.__esModule = true; - length = imul(size, size) | 0; + var _merge2 = __webpack_require__(28); - while ((length | 0) > 0) { - length = length - 1 | 0; - images[dstImagePtr + length | 0] = images[srcImagePtr + length | 0] | 0; - } - } + var _merge3 = _interopRequireDefault(_merge2); - function zeroBorder(imagePtr) { - imagePtr = imagePtr | 0; + var _typedefs = __webpack_require__(56); - var x = 0, - y = 0; + var _typedefs2 = _interopRequireDefault(_typedefs); - 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; - } - } + var _webrtcAdapter = __webpack_require__(146); - function skeletonize() { - var subImagePtr = 0, - erodedImagePtr = 0, - tempImagePtr = 0, - skelImagePtr = 0, - sum = 0, - done = 0; + var _webrtcAdapter2 = _interopRequireDefault(_webrtcAdapter); - erodedImagePtr = imul(size, size) | 0; - tempImagePtr = erodedImagePtr + erodedImagePtr | 0; - skelImagePtr = tempImagePtr + erodedImagePtr | 0; + var _image_wrapper = __webpack_require__(18); - // init skel-image - init(skelImagePtr, 0); - zeroBorder(subImagePtr); + var _image_wrapper2 = _interopRequireDefault(_image_wrapper); - 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); - } + var _barcode_locator = __webpack_require__(62); - return { - skeletonize: skeletonize - }; - } - - exports["default"] = Skeletonizer; - - /* eslint-enable eqeqeq*/ - /* @preserve ASM END */ - module.exports = exports["default"]; - -/***/ }, -/* 14 */ -/***/ function(module, exports, __webpack_require__) { - - 'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + var _barcode_locator2 = _interopRequireDefault(_barcode_locator); - var _bresenham = __webpack_require__(15); + var _barcode_decoder = __webpack_require__(59); - var _bresenham2 = _interopRequireDefault(_bresenham); + var _barcode_decoder2 = _interopRequireDefault(_barcode_decoder); - var _commonImage_debug = __webpack_require__(10); + var _events = __webpack_require__(54); - var _commonImage_debug2 = _interopRequireDefault(_commonImage_debug); + var _events2 = _interopRequireDefault(_events); - var _readerCode_128_reader = __webpack_require__(16); + var _camera_access = __webpack_require__(61); - var _readerCode_128_reader2 = _interopRequireDefault(_readerCode_128_reader); + var _camera_access2 = _interopRequireDefault(_camera_access); - var _readerEan_reader = __webpack_require__(18); + var _image_debug = __webpack_require__(9); - var _readerEan_reader2 = _interopRequireDefault(_readerEan_reader); + var _image_debug2 = _interopRequireDefault(_image_debug); - var _readerCode_39_reader = __webpack_require__(19); + var _result_collector = __webpack_require__(52); - var _readerCode_39_reader2 = _interopRequireDefault(_readerCode_39_reader); + var _result_collector2 = _interopRequireDefault(_result_collector); - var _readerCode_39_vin_reader = __webpack_require__(20); + var _config2 = __webpack_require__(57); - var _readerCode_39_vin_reader2 = _interopRequireDefault(_readerCode_39_vin_reader); + var _config3 = _interopRequireDefault(_config2); - var _readerCodabar_reader = __webpack_require__(21); + var _input_stream = __webpack_require__(51); - var _readerCodabar_reader2 = _interopRequireDefault(_readerCodabar_reader); + var _input_stream2 = _interopRequireDefault(_input_stream); - var _readerUpc_reader = __webpack_require__(22); + var _frame_grabber = __webpack_require__(50); - var _readerUpc_reader2 = _interopRequireDefault(_readerUpc_reader); + var _frame_grabber2 = _interopRequireDefault(_frame_grabber); - var _readerEan_8_reader = __webpack_require__(23); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - var _readerEan_8_reader2 = _interopRequireDefault(_readerEan_8_reader); + // eslint-disable-line no-unused-vars - var _readerUpc_e_reader = __webpack_require__(24); + var vec2 = { + clone: __webpack_require__(6) + }; // eslint-disable-line no-unused-vars - var _readerUpc_e_reader2 = _interopRequireDefault(_readerUpc_e_reader); - var _readerI2of5_reader = __webpack_require__(25); + var _inputStream, + _framegrabber, + _stopped, + _canvasContainer = { + ctx: { + image: null, + overlay: null + }, + dom: { + image: null, + overlay: null + } + }, + _inputImageWrapper, + _boxSize, + _decoder, + _workerPool = [], + _onUIThread = true, + _resultCollector, + _config = {}; - var _readerI2of5_reader2 = _interopRequireDefault(_readerI2of5_reader); + function initializeData(imageWrapper) { + initBuffers(imageWrapper); + _decoder = _barcode_decoder2.default.create(_config.decoder, _inputImageWrapper); + } - var READERS = { - code_128_reader: _readerCode_128_reader2['default'], - ean_reader: _readerEan_reader2['default'], - ean_8_reader: _readerEan_8_reader2['default'], - code_39_reader: _readerCode_39_reader2['default'], - code_39_vin_reader: _readerCode_39_vin_reader2['default'], - codabar_reader: _readerCodabar_reader2['default'], - upc_reader: _readerUpc_reader2['default'], - upc_e_reader: _readerUpc_e_reader2['default'], - i2of5_reader: _readerI2of5_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 + 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); } - }, - _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"); + } + _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); + }); + } - _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"); + _inputStream.setAttribute("preload", "auto"); + _inputStream.setAttribute("autoplay", true); + _inputStream.setInputStream(_config.inputStream); + _inputStream.addEventListener("canrecord", canRecord.bind(undefined, cb)); + } - _canvas.dom.overlay = document.querySelector("canvas.drawingBuffer"); - if (_canvas.dom.overlay) { - _canvas.ctx.overlay = _canvas.dom.overlay.getContext("2d"); - } - } - } + 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 initReaders() { - config.readers.forEach(function (readerConfig) { - var reader, - configuration = {}; + function canRecord(cb) { + _barcode_locator2.default.checkImageConstraints(_inputStream, _config.locator); + initCanvas(_config); + _framegrabber = _frame_grabber2.default.create(_inputStream, _canvasContainer.dom.image); - if (typeof readerConfig === 'object') { - reader = readerConfig.format; - configuration = readerConfig.config; - } else if (typeof readerConfig === 'string') { - reader = readerConfig; - } - if (false) { - console.log("Before registering reader: ", reader); - } - _barcodeReaders.push(new READERS[reader](configuration)); - }); - if (false) { - console.log("Registered Readers: " + _barcodeReaders.map(function (reader) { - return JSON.stringify({ format: reader.FORMAT, config: reader.config }); - }).join(', ')); - } + adjustWorkerPool(_config.numOfWorkers, function () { + if (_config.numOfWorkers === 0) { + initializeData(); } + ready(cb); + }); + } - function initConfig() { - if (false) { - var i, - vis = [{ - node: _canvas.dom.frequency, - prop: config.debug.showFrequency - }, { - node: _canvas.dom.pattern, - prop: config.debug.showPattern - }]; + function ready(cb) { + _inputStream.play(); + cb(); + } - 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"; - } - } + 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; - /** - * 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; + _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); } - - // 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); + var clearFix = document.createElement("br"); + clearFix.setAttribute("clear", "all"); + if ($viewport) { + $viewport.appendChild(clearFix); } - 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] - }]; } + _canvasContainer.ctx.overlay = _canvasContainer.dom.overlay.getContext("2d"); + _canvasContainer.dom.overlay.width = _inputStream.getCanvasSize().x; + _canvasContainer.dom.overlay.height = _inputStream.getCanvasSize().y; + } + } - function tryDecode(line) { - var result = null, - i, - barcodeLine = _bresenham2['default'].getBarcodeLine(inputImageWrapper, line[0], line[1]); + function initBuffers(imageWrapper) { + if (imageWrapper) { + _inputImageWrapper = imageWrapper; + } else { + _inputImageWrapper = new _image_wrapper2.default({ + x: _inputStream.getWidth(), + y: _inputStream.getHeight() + }); + } - if (false) { - _commonImage_debug2['default'].drawPath(line, { x: 'x', y: 'y' }, _canvas.ctx.overlay, { color: 'red', lineWidth: 3 }); - _bresenham2['default'].debug.printFrequency(barcodeLine.line, _canvas.dom.frequency); - } + 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); + } - _bresenham2['default'].toBinaryLine(barcodeLine); + 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])]]; + } + } - if (false) { - _bresenham2['default'].debug.printPattern(barcodeLine.line, _canvas.dom.pattern); - } + function transformResult(result) { + var topRight = _inputStream.getTopRight(), + xOffset = topRight.x, + yOffset = topRight.y, + i; - 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 - }; + if (xOffset === 0 && yOffset === 0) { + return; + } + + if (result.barcodes) { + for (i = 0; i < result.barcodes.length; i++) { + transformResult(result.barcodes[i]); } + } - /** - * 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); + if (result.line && result.line.length === 2) { + moveLine(result.line); + } - 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; + if (result.box) { + moveBox(result.box); + } - result = tryDecode(line); - } - return result; + if (result.boxes && result.boxes.length > 0) { + for (i = 0; i < result.boxes.length; i++) { + moveBox(result.boxes[i]); } + } - function getLineLength(line) { - return Math.sqrt(Math.pow(Math.abs(line[1].y - line[0].y), 2) + Math.pow(Math.abs(line[1].x - line[0].x), 2)); + function moveBox(box) { + var corner = box.length; + + while (corner--) { + box[corner][0] += xOffset; + box[corner][1] += yOffset; } + } - /** - * 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; + function moveLine(line) { + line[0].x += xOffset; + line[0].y += yOffset; + line[1].x += xOffset; + line[1].y += yOffset; + } + } - if (false) { - if (config.debug.drawBoundingBox && ctx) { - _commonImage_debug2['default'].drawPath(box, { x: 0, y: 1 }, ctx, { color: "blue", lineWidth: 2 }); - } - } + function addResult(result, imageData) { + if (!imageData || !_resultCollector) { + return; + } - 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; - } + 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); + } + } - result = tryDecode(line); - if (result === null) { - result = tryDecodeBruteForce(box, line, lineAngle); + function hasCodeResult(result) { + return result && (result.barcodes ? result.barcodes.some(function (barcode) { + return barcode.codeResult; + }) : result.codeResult); + } + + function publishResult(result, imageData) { + var resultToPublish = result && (result.barcodes || result); + + if (result && _onUIThread) { + transformResult(result); + addResult(result, imageData); + } + + _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(); + } + } - if (result === null) { - return null; + 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) { - _commonImage_debug2['default'].drawPath(line, { x: 'x', y: 'y' }, ctx, { color: 'red', lineWidth: 3 }); + console.log("Worker error: " + e.data.message); } + } + }; - return { - codeResult: result.codeResult, - line: line, - angle: lineAngle, - pattern: result.barcodeLine.line, - threshold: result.barcodeLine.threshold - }; + workerThread.worker.postMessage({ + cmd: 'init', + size: { x: _inputStream.getWidth(), y: _inputStream.getHeight() }, + imageData: workerThread.imageData, + config: _config + }, [workerThread.imageData.buffer]); + } + + 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; - return { - decodeFromBoundingBox: function decodeFromBoundingBox(box) { - return _decodeFromBoundingBox(box); - }, - decodeFromBoundingBoxes: function decodeFromBoundingBoxes(boxes) { + 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 + }; + +/***/ }, +/* 50 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; + + var CVUtils = __webpack_require__(17), + Ndarray = __webpack_require__(154), + Interp2D = __webpack_require__(155).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.e = FrameGrabber; + +/***/ }, +/* 51 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + var GetPixels = __webpack_require__(153); + + 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, 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.e = 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__(6), + dot: __webpack_require__(31) + }; + /** + * 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) { + + "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; + + event.subscribers = subscribers.filter(function (subscriber) { + publishSubscription(subscriber, data); + return !subscriber.once; + }); + }, + 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) { + + '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; + +/***/ }, +/* 56 */ +/***/ function(module, exports) { + + '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; + }; + +/***/ }, +/* 57 */ +/***/ 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__(58); + } else { + config = require('./config.prod.js'); + } + + exports.default = config; + +/***/ }, +/* 58 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; + + module.e = { + 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 + } + }; + +/***/ }, +/* 59 */ +/***/ 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 ? "symbol" : typeof obj; }; + + var _bresenham = __webpack_require__(60); + + var _bresenham2 = _interopRequireDefault(_bresenham); + + var _image_debug = __webpack_require__(9); + + var _image_debug2 = _interopRequireDefault(_image_debug); + + var _code_128_reader = __webpack_require__(66); + + var _code_128_reader2 = _interopRequireDefault(_code_128_reader); + + var _ean_reader = __webpack_require__(10); + + var _ean_reader2 = _interopRequireDefault(_ean_reader); + + var _code_39_reader = __webpack_require__(30); + + var _code_39_reader2 = _interopRequireDefault(_code_39_reader); + + var _code_39_vin_reader = __webpack_require__(67); + + var _code_39_vin_reader2 = _interopRequireDefault(_code_39_vin_reader); + + var _codabar_reader = __webpack_require__(65); + + var _codabar_reader2 = _interopRequireDefault(_codabar_reader); + + var _upc_reader = __webpack_require__(71); + + var _upc_reader2 = _interopRequireDefault(_upc_reader); + + var _ean_8_reader = __webpack_require__(68); + + var _ean_8_reader2 = _interopRequireDefault(_ean_8_reader); + + var _upc_e_reader = __webpack_require__(70); + + var _upc_e_reader2 = _interopRequireDefault(_upc_e_reader); + + var _i2of5_reader = __webpack_require__(69); + + var _i2of5_reader2 = _interopRequireDefault(_i2of5_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_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 + }; + 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 = {}; + + 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); + } + _barcodeReaders.push(new READERS[reader](configuration)); + }); + 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; + 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(); + } + }; + } + }; + +/***/ }, +/* 60 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; + + exports.__esModule = true; + + var _image_wrapper = __webpack_require__(18); + + 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; + +/***/ }, +/* 61 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; + + exports.__esModule = true; + + var _pick2 = __webpack_require__(142); + + var _pick3 = _interopRequireDefault(_pick2); + + var _merge2 = __webpack_require__(28); + + var _merge3 = _interopRequireDefault(_merge2); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + var streamRef, loadedDataHandler; + + function waitForVideo(video) { + return new Promise(function (resolve, reject) { + var attempts = 10; + + function checkVideo() { + if (attempts > 0) { + if (video.videoWidth > 0 && video.videoHeight > 0) { + 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 navigator.mediaDevices.getUserMedia(constraints).then(function (stream) { + return new Promise(function (resolve, reject) { + streamRef = stream; + video.src = window.URL.createObjectURL(stream); + video.onloadedmetadata = function (e) { + 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 applyCameraFacing(facing, constraints) { + if (typeof constraints.video.deviceId !== 'undefined' || !facing) { + return Promise.resolve(constraints); + } + if (typeof MediaStreamTrack !== 'undefined' && typeof MediaStreamTrack.getSources !== 'undefined') { + return new Promise(function (resolve, reject) { + MediaStreamTrack.getSources(function (sourceInfos) { + var videoSource = sourceInfos.filter(function (sourceInfo) { + return sourceInfo.kind === "video" && sourceInfo.facing === facing; + })[0]; + if (videoSource) { + return resolve((0, _merge3.default)({}, constraints, { video: { deviceId: videoSource.id } })); + } + return resolve(constraints); + }); + }); + } + return Promise.resolve((0, _merge3.default)({}, constraints, { video: { facingMode: facing } })); + } + + function pickConstraints(videoConstraints) { + var constraints = { + audio: false, + video: deprecatedConstraints(videoConstraints) + }; + return applyCameraFacing(constraints.video.facingMode, constraints); + } + + 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; + } + }; + +/***/ }, +/* 62 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(global) {'use strict'; + + exports.__esModule = true; + + var _image_wrapper = __webpack_require__(18); + + var _image_wrapper2 = _interopRequireDefault(_image_wrapper); + + var _cv_utils = __webpack_require__(17); + + var _array_helper = __webpack_require__(8); + + var _array_helper2 = _interopRequireDefault(_array_helper); + + var _image_debug = __webpack_require__(9); + + var _image_debug2 = _interopRequireDefault(_image_debug); + + var _rasterizer = __webpack_require__(63); + + var _rasterizer2 = _interopRequireDefault(_rasterizer); + + var _tracer = __webpack_require__(29); + + var _tracer2 = _interopRequireDefault(_tracer); + + var _skeletonizer2 = __webpack_require__(64); + + var _skeletonizer3 = _interopRequireDefault(_skeletonizer2); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + var vec2 = { + clone: __webpack_require__(6), + dot: __webpack_require__(31), + scale: __webpack_require__(75), + transformMat2: __webpack_require__(76) + }; + var mat2 = { + copy: __webpack_require__(72), + create: __webpack_require__(73), + invert: __webpack_require__(74) + }; + + 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 (_config.showCanvas) { + _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, (function() { return this; }()))) + +/***/ }, +/* 63 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; + + exports.__esModule = true; + + var _tracer = __webpack_require__(29); + + 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; + } - if (multiple) { - barcodes.push(result); - } else if (result.codeResult) { - return result; + 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(); } } - - if (multiple) { - return { - barcodes: barcodes - }; - } - }, - setReaders: function setReaders(readers) { - config.readers = readers; - _barcodeReaders.length = 0; - initReaders(); } }; } }; - module.exports = exports['default']; + + exports.default = Rasterizer; /***/ }, -/* 15 */ -/***/ function(module, exports, __webpack_require__) { +/* 64 */ +/***/ function(module, exports) { - 'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _commonCv_utils = __webpack_require__(5); + "use strict"; - var _commonCv_utils2 = _interopRequireDefault(_commonCv_utils); + exports.__esModule = true; + /* @preserve ASM BEGIN */ + /* eslint-disable eqeqeq*/ + function Skeletonizer(stdlib, foreign, buffer) { + "use asm"; - var _commonImage_wrapper = __webpack_require__(3); + var images = new stdlib.Uint8Array(buffer), + size = foreign.size | 0, + imul = stdlib.Math.imul; - var _commonImage_wrapper2 = _interopRequireDefault(_commonImage_wrapper); + function erode(inImagePtr, outImagePtr) { + inImagePtr = inImagePtr | 0; + outImagePtr = outImagePtr | 0; - var Bresenham = {}; + var v = 0, + u = 0, + sum = 0, + yStart1 = 0, + yStart2 = 0, + xStart1 = 0, + xStart2 = 0, + offset = 0; - var Slope = { - DIR: { - UP: 1, - DOWN: -1 + 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; } - }; - /** - * 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); - } + function subtract(aImagePtr, bImagePtr, outImagePtr) { + aImagePtr = aImagePtr | 0; + bImagePtr = bImagePtr | 0; + outImagePtr = outImagePtr | 0; - if (steep) { - tmp = x0; - x0 = y0; - y0 = tmp; + var length = 0; - tmp = x1; - x1 = y1; - y1 = tmp; - } - if (x0 > x1) { - tmp = x0; - x0 = x1; - x1 = tmp; + length = imul(size, size) | 0; - 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; + while ((length | 0) > 0) { + length = length - 1 | 0; + images[outImagePtr + length | 0] = (images[aImagePtr + length | 0] | 0) - (images[bImagePtr + length | 0] | 0) | 0; } } - return { - line: line, - min: min, - max: max - }; - }; - - Bresenham.toOtsuBinaryLine = function (result) { - var line = result.line, - image = new _commonImage_wrapper2['default']({ x: line.length - 1, y: 1 }, line), - threshold = _commonCv_utils2['default'].determineOtsuThreshold(image, 5); - - line = _commonCv_utils2['default'].sharpenLine(line); - _commonCv_utils2['default'].thresholdImage(image, threshold); - - return { - line: line, - threshold: threshold - }; - }; + function bitwiseOr(aImagePtr, bImagePtr, outImagePtr) { + aImagePtr = aImagePtr | 0; + bImagePtr = bImagePtr | 0; + outImagePtr = outImagePtr | 0; - /** - * 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; + var length = 0; - // 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; - } + length = imul(size, size) | 0; - if (currentDir !== dir) { - extrema.push({ - pos: i, - val: line[i] - }); - currentDir = dir; + while ((length | 0) > 0) { + length = length - 1 | 0; + images[outImagePtr + length | 0] = images[aImagePtr + length | 0] | 0 | (images[bImagePtr + length | 0] | 0) | 0; } } - 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; - } + function countNonZero(imagePtr) { + imagePtr = imagePtr | 0; - // 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; - } + var sum = 0, + length = 0; - for (j = extrema[i].pos; j < extrema[i + 1].pos; j++) { - line[j] = line[j] > threshold ? 0 : 1; + 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; } - return { - line: line, - threshold: threshold - }; - }; + function init(imagePtr, value) { + imagePtr = imagePtr | 0; + value = value | 0; - /** - * Used for development only - */ - Bresenham.debug = { - printFrequency: function printFrequency(line, canvas) { - var i, - ctx = canvas.getContext("2d"); - canvas.width = line.length; - canvas.height = 256; + var length = 0; - ctx.beginPath(); - ctx.strokeStyle = "blue"; - for (i = 0; i < line.length; i++) { - ctx.moveTo(i, 255); - ctx.lineTo(i, 255 - line[i]); + length = imul(size, size) | 0; + + while ((length | 0) > 0) { + length = length - 1 | 0; + images[imagePtr + length | 0] = value; } - ctx.stroke(); - ctx.closePath(); - }, + } - printPattern: function printPattern(line, canvas) { - var ctx = canvas.getContext("2d"), - i; + function dilate(inImagePtr, outImagePtr) { + inImagePtr = inImagePtr | 0; + outImagePtr = outImagePtr | 0; - canvas.width = line.length; - ctx.fillColor = "black"; - for (i = 0; i < line.length; i++) { - if (line[i] === 1) { - ctx.fillRect(i, 0, 1, 100); + 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; } - }; - exports['default'] = Bresenham; - module.exports = exports['default']; - -/***/ }, -/* 16 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; + function memcpy(srcImagePtr, dstImagePtr) { + srcImagePtr = srcImagePtr | 0; + dstImagePtr = dstImagePtr | 0; - Object.defineProperty(exports, "__esModule", { - value: true - }); + var length = 0; - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + length = imul(size, size) | 0; - var _barcode_reader = __webpack_require__(17); + while ((length | 0) > 0) { + length = length - 1 | 0; + images[dstImagePtr + length | 0] = images[srcImagePtr + length | 0] | 0; + } + } - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); + function zeroBorder(imagePtr) { + imagePtr = imagePtr | 0; - function Code128Reader() { - _barcode_reader2["default"].call(this); - } + var x = 0, + y = 0; - 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 }, - MODULO: { value: 11 }, - 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: 1 }, - AVG_CODE_ERROR: { value: 0.5 }, - FORMAT: { value: "code_128", writeable: false } - }; + 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; + } + } - Code128Reader.prototype = Object.create(_barcode_reader2["default"].prototype, properties); - Code128Reader.prototype.constructor = Code128Reader; + function skeletonize() { + var subImagePtr = 0, + erodedImagePtr = 0, + tempImagePtr = 0, + skelImagePtr = 0, + sum = 0, + done = 0; - Code128Reader.prototype._decodeCode = function (start) { - 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 - }, - code, - error, - normalized; + erodedImagePtr = imul(size, size) | 0; + tempImagePtr = erodedImagePtr + erodedImagePtr | 0; + skelImagePtr = tempImagePtr + erodedImagePtr | 0; - for (i = offset; i < self._row.length; i++) { - if (self._row[i] ^ isWhite) { - counter[counterPos]++; - } else { - if (counterPos === counter.length - 1) { - normalized = self._normalize(counter); - if (normalized) { - for (code = 0; code < self.CODE_PATTERN.length; code++) { - error = self._matchPattern(normalized, self.CODE_PATTERN[code]); - if (error < bestMatch.error) { - bestMatch.code = code; - bestMatch.error = error; - } - } - bestMatch.end = i; - return bestMatch; - } - } else { - counterPos++; - } - counter[counterPos] = 1; - isWhite = !isWhite; - } + // 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 null; - }; + return { + skeletonize: skeletonize + }; + } + /* @preserve ASM END */ + exports.default = Skeletonizer; + /* eslint-enable eqeqeq*/ + +/***/ }, +/* 65 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; - 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 - }, - code, - error, - j, - sum, - normalized; + exports.__esModule = true; - 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]; - } - normalized = self._normalize(counter); - if (normalized) { - for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) { - error = self._matchPattern(normalized, 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; - return bestMatch; - } - } + var _barcode_reader = __webpack_require__(5); - 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; + 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 } }; - Code128Reader.prototype._decode = function () { + CodabarReader.prototype = Object.create(_barcode_reader2.default.prototype, properties); + CodabarReader.prototype.constructor = CodabarReader; + + CodabarReader.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; + start, + decodedChar, + pattern, + nextStart, + end; - if (startInfo === null) { + this._counters = self._fillCounters(); + start = self._findStart(); + if (!start) { return null; } - code = { - code: startInfo.code, - start: startInfo.start, - end: startInfo.end - }; - 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); - 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); + nextStart = start.startCounter; - 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; + do { + pattern = self._toPattern(nextStart); + if (pattern < 0) { + return null; } - if (unshift) { - codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A; + decodedChar = self._patternToChar(pattern); + if (decodedChar < 0) { + return null; } - } - - if (code === null) { - return null; - } + result.push(decodedChar); + nextStart += 8; + if (result.length > 1 && self._isStartEnd(pattern)) { + break; + } + } while (nextStart < self._counters.length); - code.end = self._nextUnset(self._row, code.end); - if (!self._verifyTrailingWhitespace(code)) { + // verify end + if (result.length - 2 < self.MIN_ENCODED_CHARS || !self._isStartEnd(pattern)) { return null; } - checksum -= multiplier * rawResult[rawResult.length - 1]; - if (checksum % 103 !== rawResult[rawResult.length - 1]) { + // verify end white space + if (!self._verifyWhitespace(start.startCounter, nextStart - 8)) { return null; } - if (!result.length) { + if (!self._validateResult(result, start.startCounter)) { return null; } - // remove last code from result (checksum) - if (removeLastCharacter) { - result.splice(result.length - 1, 1); - } + nextStart = nextStart > self._counters.length ? self._counters.length : nextStart; + end = start.start + self._sumCounters(start.startCounter, nextStart - 8); return { code: result.join(""), - start: startInfo.start, - end: code.end, - codeset: codeset, - startInfo: startInfo, - decodedCodes: decodedCodes, - endInfo: code + start: start.start, + end: end, + startInfo: start, + decodedCodes: result }; }; - _barcode_reader2["default"].prototype._verifyTrailingWhitespace = function (endInfo) { + 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, - trailingWhitespaceEnd; + 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; - trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; - if (trailingWhitespaceEnd < self._row.length) { - if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { - return endInfo; + 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; } - return null; - }; - exports["default"] = Code128Reader; - module.exports = exports["default"]; - -/***/ }, -/* 17 */ -/***/ function(module, exports) { - - 'use strict'; + ["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); + }); - Object.defineProperty(exports, '__esModule', { - value: true - }); - function BarcodeReader(config) { - this._row = []; - this.config = config || {}; - return this; - } + return categorization; + }; - BarcodeReader.prototype._nextUnset = function (line, start) { - var i; + CodabarReader.prototype._charToPattern = function (char) { + var self = this, + charCode = char.charCodeAt(0), + i; - if (start === undefined) { - start = 0; - } - for (i = start; i < line.length; i++) { - if (!line[i]) { - return i; + for (i = 0; i < self.ALPHABET.length; i++) { + if (self.ALPHABET[i] === charCode) { + return self.CHARACTER_ENCODINGS[i]; } } - return line.length; + return 0x0; }; - BarcodeReader.prototype._matchPattern = function (counter, code) { - var i, - error = 0, - singleError = 0, - modulo = this.MODULO, - maxSingleError = this.SINGLE_CODE_ERROR || 1; + 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 < counter.length; i++) { - singleError = Math.abs(code[i] - counter[i]); - if (singleError > maxSingleError) { - return Number.MAX_VALUE; + 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; } - error += singleError; + pos += 8; } - return error / modulo; + return true; }; - BarcodeReader.prototype._nextSet = function (line, offset) { - var i; + CodabarReader.prototype._patternToChar = function (pattern) { + var i, + self = this; - offset = offset || 0; - for (i = offset; i < line.length; i++) { - if (line[i]) { - return i; + for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) { + if (self.CHARACTER_ENCODINGS[i] === pattern) { + return String.fromCharCode(self.ALPHABET[i]); } } - return line.length; + return -1; }; - BarcodeReader.prototype._normalize = function (counter, modulo) { + CodabarReader.prototype._computeAlternatingThreshold = function (offset, end) { var i, - self = this, - sum = 0, - ratio, - numOnes = 0, - normalized = [], - norm = 0; + min = Number.MAX_VALUE, + max = 0, + counter; - if (!modulo) { - modulo = self.MODULO; - } - for (i = 0; i < counter.length; i++) { - if (counter[i] === 1) { - numOnes++; - } else { - sum += counter[i]; - } - } - ratio = sum / (modulo - numOnes); - if (ratio > 1.0) { - for (i = 0; i < counter.length; i++) { - norm = counter[i] === 1 ? counter[i] : counter[i] / ratio; - normalized.push(norm); + for (i = offset; i < end; i += 2) { + counter = this._counters[i]; + if (counter > max) { + max = counter; } - } else { - ratio = (sum + numOnes) / modulo; - for (i = 0; i < counter.length; i++) { - norm = counter[i] / ratio; - normalized.push(norm); + if (counter < min) { + min = counter; } } - return normalized; + + return (min + max) / 2.0 | 0; }; - BarcodeReader.prototype._matchTrace = function (cmpCounter, epsilon) { - var counter = [], + CodabarReader.prototype._toPattern = function (offset) { + var numCounters = 7, + end = offset + numCounters, + barThreshold, + spaceThreshold, + bitmask = 1 << numCounters - 1, + pattern = 0, i, - self = this, - offset = self._nextSet(self._row), - isWhite = !self._row[offset], - counterPos = 0, - bestMatch = { - error: Number.MAX_VALUE, - code: -1, - start: 0 - }, - error; + threshold; - 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 (end > this._counters.length) { + return -1; + } - 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; - } + 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; } - // if cmpCounter was not given - bestMatch.start = offset; - bestMatch.end = self._row.length - 1; - bestMatch.counter = counter; - return bestMatch; + return pattern; }; - BarcodeReader.prototype.decodePattern = function (pattern) { - var self = this, - result; + CodabarReader.prototype._isStartEnd = function (pattern) { + var i; - 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; + for (i = 0; i < this.START_END.length; i++) { + if (this.START_END[i] === pattern) { + return true; } - } else { - result.direction = BarcodeReader.DIRECTION.FORWARD; - } - if (result) { - result.format = self.FORMAT; } - return result; + return false; }; - BarcodeReader.prototype._matchRange = function (start, end, value) { - var i; + CodabarReader.prototype._sumCounters = function (start, end) { + var i, + sum = 0; - start = start < 0 ? 0 : start; for (i = start; i < end; i++) { - if (this._row[i] !== value) { - return false; - } + sum += this._counters[i]; } - return true; + return sum; }; - BarcodeReader.prototype._fillCounters = function (offset, end, isWhite) { + CodabarReader.prototype._findStart = function () { 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; + pattern, + start = self._nextUnset(self._row), + end; - counters[counterPos] = 0; - for (i = offset; i < end; i++) { - if (self._row[i] ^ isWhite) { - counters[counterPos]++; - } else { - counterPos++; - counters[counterPos] = 1; - isWhite = !isWhite; + 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 + }; } } - return counters; - }; - - 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; - module.exports = exports['default']; + exports.default = CodabarReader; /***/ }, -/* 18 */ +/* 66 */ /***/ function(module, exports, __webpack_require__) { "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + exports.__esModule = true; - var _barcode_reader = __webpack_require__(17); + var _barcode_reader = __webpack_require__(5); var _barcode_reader2 = _interopRequireDefault(_barcode_reader); - function EANReader(opts) { - _barcode_reader2["default"].call(this, opts); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + function Code128Reader() { + _barcode_reader2.default.call(this); } var properties = { - CODE_L_START: { value: 0 }, - MODULO: { value: 7 }, - CODE_G_START: { value: 10 }, - START_PATTERN: { value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7] }, - STOP_PATTERN: { value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7] }, - MIDDLE_PATTERN: { value: [1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7] }, - 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.67 }, - AVG_CODE_ERROR: { value: 0.27 }, - FORMAT: { value: "ean_13", writeable: false } + 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 }, + MODULO: { value: 11 }, + 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: 1 }, + AVG_CODE_ERROR: { value: 0.5 }, + FORMAT: { value: "code_128", writeable: false } }; - EANReader.prototype = Object.create(_barcode_reader2["default"].prototype, properties); - EANReader.prototype.constructor = EANReader; + Code128Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties); + Code128Reader.prototype.constructor = Code128Reader; - EANReader.prototype._decodeCode = function (start, coderange) { - var counter = [0, 0, 0, 0], + Code128Reader.prototype._decodeCode = function (start) { + var counter = [0, 0, 0, 0, 0, 0], i, self = this, offset = start, @@ -4486,143 +7010,267 @@ module.exports = error, normalized; - 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) { + normalized = self._normalize(counter); + if (normalized) { + for (code = 0; code < self.CODE_PATTERN.length; code++) { + error = self._matchPattern(normalized, self.CODE_PATTERN[code]); + if (error < bestMatch.error) { + bestMatch.code = code; + bestMatch.error = error; + } + } + bestMatch.end = i; + return bestMatch; + } + } else { + counterPos++; + } + counter[counterPos] = 1; + isWhite = !isWhite; + } } + return null; + }; + + 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 + }, + code, + error, + j, + sum, + normalized; 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]; + } normalized = self._normalize(counter); if (normalized) { - for (code = 0; code < coderange; code++) { + for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) { error = self._matchPattern(normalized, 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; + if (bestMatch.error < self.AVG_CODE_ERROR) { + bestMatch.start = i - sum; + bestMatch.end = i; + 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 + }; + 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); + 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; + } } - return bestMatch; - } - } else { - counterPos++; + break; } - counter[counterPos] = 1; - isWhite = !isWhite; + } else { + done = true; + } + if (unshift) { + codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A; } - } - 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, - normalized; - - if (!offset) { - offset = self._nextSet(self._row); } - if (isWhite === undefined) { - isWhite = false; + if (code === null) { + return null; } - if (tryHarder === undefined) { - tryHarder = true; + code.end = self._nextUnset(self._row, code.end); + if (!self._verifyTrailingWhitespace(code)) { + return null; } - if (epsilon === undefined) { - epsilon = self.AVG_CODE_ERROR; + checksum -= multiplier * rawResult[rawResult.length - 1]; + if (checksum % 103 !== rawResult[rawResult.length - 1]) { + return null; } - for (i = 0; i < pattern.length; i++) { - counter[i] = 0; + if (!result.length) { + return null; } - 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]; - } - normalized = self._normalize(counter); - if (normalized) { - error = self._matchPattern(normalized, 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; - } + // remove last code from result (checksum) + if (removeLastCharacter) { + result.splice(result.length - 1, 1); } - 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; - } + return { + code: result.join(""), + start: startInfo.start, + end: code.end, + codeset: codeset, + startInfo: startInfo, + decodedCodes: decodedCodes, + endInfo: code + }; }; - EANReader.prototype._verifyTrailingWhitespace = function (endInfo) { + _barcode_reader2.default.prototype._verifyTrailingWhitespace = function (endInfo) { var self = this, trailingWhitespaceEnd; - trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start); + trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; if (trailingWhitespaceEnd < self._row.length) { if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { return endInfo; @@ -4631,347 +7279,267 @@ module.exports = 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; - }; + exports.default = Code128Reader; + +/***/ }, +/* 67 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; - EANReader.prototype._decodePayload = function (code, result, decodedCodes) { - var i, - self = this, - codeFrequency = 0x0, - firstDigit; + exports.__esModule = true; - 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); - } + var _code_39_reader = __webpack_require__(30); - firstDigit = self._calculateFirstDigit(codeFrequency); - if (firstDigit === null) { - return null; - } - result.unshift(firstDigit); + var _code_39_reader2 = _interopRequireDefault(_code_39_reader); - code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); - if (code === null) { - return null; - } - decodedCodes.push(code); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - 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); - } + function Code39VINReader() { + _code_39_reader2.default.call(this); + } - return code; + var patterns = { + IOQ: /[IOQ]/g, + AZ09: /[A-Z0-9]{17}/ }; - EANReader.prototype._decode = function () { - var startInfo, - self = this, - code, - result = [], - decodedCodes = []; + Code39VINReader.prototype = Object.create(_code_39_reader2.default.prototype); + Code39VINReader.prototype.constructor = Code39VINReader; - startInfo = self._findStart(); - if (!startInfo) { + // 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; } - code = { - code: startInfo.code, - start: startInfo.start, - end: startInfo.end - }; - decodedCodes.push(code); - code = self._decodePayload(code, result, decodedCodes); + + var code = result.code; + if (!code) { return null; } - code = self._findEnd(code.end, false); - if (!code) { + + code = code.replace(patterns.IOQ, ''); + + if (!code.match(patterns.AZ09)) { + if (false) { + console.log('Failed AZ09 pattern code:', code); + } return null; } - decodedCodes.push(code); - - // Checksum - if (!self._checksum(result)) { + if (!this._checkChecksum(code)) { return null; } - return { - code: result.join(""), - start: startInfo.start, - end: code.end, - codeset: "", - startInfo: startInfo, - decodedCodes: decodedCodes - }; + result.code = code; + return result; }; - - 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; + + Code39VINReader.prototype._checkChecksum = function (code) { + // TODO + return !!code; }; - exports["default"] = EANReader; - module.exports = exports["default"]; + exports.default = Code39VINReader; /***/ }, -/* 19 */ +/* 68 */ /***/ function(module, exports, __webpack_require__) { - 'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + "use strict"; - var _barcode_reader = __webpack_require__(17); + exports.__esModule = true; - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); + var _ean_reader = __webpack_require__(10); - var _commonArray_helper = __webpack_require__(8); + var _ean_reader2 = _interopRequireDefault(_ean_reader); - var _commonArray_helper2 = _interopRequireDefault(_commonArray_helper); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - function Code39Reader() { - _barcode_reader2['default'].call(this); + function EAN8Reader() { + _ean_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 } + FORMAT: { value: "ean_8", writeable: false } }; - Code39Reader.prototype = Object.create(_barcode_reader2['default'].prototype, properties); - Code39Reader.prototype.constructor = Code39Reader; - - Code39Reader.prototype._toCounters = function (start, counter) { - var self = this, - numCounters = counter.length, - end = self._row.length, - isWhite = !self._row[start], - i, - counterPos = 0; + EAN8Reader.prototype = Object.create(_ean_reader2.default.prototype, properties); + EAN8Reader.prototype.constructor = EAN8Reader; - _commonArray_helper2['default'].init(counter, 0); + EAN8Reader.prototype._decodePayload = function (code, result, decodedCodes) { + var i, + self = this; - 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; - } + 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); } - return counter; - }; - - 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) { + code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); + if (code === null) { return null; } - nextStart = self._nextSet(self._row, start.end); + decodedCodes.push(code); - do { - counters = self._toCounters(nextStart, counters); - pattern = self._toPattern(counters); - if (pattern < 0) { - return null; - } - decodedChar = self._patternToChar(pattern); - if (decodedChar < 0) { + for (i = 0; i < 4; i++) { + code = self._decodeCode(code.end, self.CODE_G_START); + if (!code) { return null; } - result.push(decodedChar); - lastStart = nextStart; - nextStart += _commonArray_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; + decodedCodes.push(code); + result.push(code.code); } - return { - code: result.join(""), - start: start.start, - end: nextStart, - startInfo: start, - decodedCodes: result - }; + return code; }; - Code39Reader.prototype._verifyTrailingWhitespace = function (lastStart, nextStart, counters) { - var trailingWhitespaceEnd, - patternSize = _commonArray_helper2['default'].sum(counters); + exports.default = EAN8Reader; + +/***/ }, +/* 69 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; - trailingWhitespaceEnd = nextStart - lastStart - patternSize; - if (trailingWhitespaceEnd * 3 >= patternSize) { - return true; - } - return false; - }; + exports.__esModule = true; - Code39Reader.prototype._patternToChar = function (pattern) { - var i, - self = this; + var _merge2 = __webpack_require__(28); - for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) { - if (self.CHARACTER_ENCODINGS[i] === pattern) { - return String.fromCharCode(self.ALPHABET[i]); - } - } - return -1; - }; + var _merge3 = _interopRequireDefault(_merge2); - Code39Reader.prototype._findNextWidth = function (counters, current) { - var i, - minWidth = Number.MAX_VALUE; + var _barcode_reader = __webpack_require__(5); - for (i = 0; i < counters.length; i++) { - if (counters[i] < minWidth && counters[i] > current) { - minWidth = counters[i]; - } + 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; } + } - return minWidth; + 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 = { + MODULO: { value: 10 }, + START_PATTERN: { value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5] }, + STOP_PATTERN: { value: [N * 2, N * 2, W * 2] }, + 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" } }; - Code39Reader.prototype._toPattern = function (counters) { - var numCounters = counters.length, - maxNarrowWidth = 0, - numWideBars = numCounters, - wideBarWidth = 0, - self = this, - pattern, - i; + I2of5Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties); + I2of5Reader.prototype.constructor = I2of5Reader; - 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]; - } + 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]; - 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; + 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 -1; + return _barcode_reader2.default.prototype._matchPattern.call(this, counter, code); }; - 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, + 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, - whiteSpaceMustStart; + 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]; + } + normalized = self._normalize(counter); + if (normalized) { + error = self._matchPattern(normalized, pattern); - 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 - }; + if (error < epsilon) { + bestMatch.error = error; + bestMatch.start = i - sum; + bestMatch.end = i; + return bestMatch; } } - - patternStart += counter[0] + counter[1]; - for (j = 0; j < 7; j++) { - counter[j] = counter[j + 2]; + 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; } - counter[7] = 0; - counter[8] = 0; - counterPos--; } else { counterPos++; } @@ -4982,405 +7550,330 @@ module.exports = return null; }; - exports['default'] = Code39Reader; - module.exports = exports['default']; - -/***/ }, -/* 20 */ -/***/ function(module, exports, __webpack_require__) { - - 'use strict'; - - Object.defineProperty(exports, '__esModule', { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - - var _code_39_reader = __webpack_require__(19); - - var _code_39_reader2 = _interopRequireDefault(_code_39_reader); - - 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; + I2of5Reader.prototype._findStart = function () { + var self = this, + leadingWhitespaceStart, + offset = self._nextSet(self._row), + startInfo, + narrowBarWidth = 1; - // 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; + 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; } + }; - var code = result.code; + I2of5Reader.prototype._verifyTrailingWhitespace = function (endInfo) { + var self = this, + trailingWhitespaceEnd; - if (!code) { - return null; + trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; + if (trailingWhitespaceEnd < self._row.length) { + if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { + return endInfo; + } } + return null; + }; - code = code.replace(patterns.IOQ, ''); + I2of5Reader.prototype._findEnd = function () { + var self = this, + endInfo, + tmp; - if (!code.match(patterns.AZ09)) { - if (false) { - console.log('Failed AZ09 pattern code:', code); - } - return null; - } + self._row.reverse(); + endInfo = self._findPattern(self.STOP_PATTERN); + self._row.reverse(); - if (!this._checkChecksum(code)) { + if (endInfo === null) { return null; } - result.code = code; - return result; - }; + // reverse numbers + tmp = endInfo.start; + endInfo.start = self._row.length - endInfo.end; + endInfo.end = self._row.length - tmp; - Code39VINReader.prototype._checkChecksum = function (code) { - // TODO - return !!code; + return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null; }; - exports['default'] = Code39VINReader; - module.exports = exports['default']; - -/***/ }, -/* 21 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); + I2of5Reader.prototype._decodePair = function (counterPair) { + var i, + code, + codes = [], + self = this; - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + for (i = 0; i < counterPair.length; i++) { + code = self._decodeCode(counterPair[i]); + if (!code) { + return null; + } + codes.push(code); + } + return codes; + }; - var _barcode_reader = __webpack_require__(17); + 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 + }; - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); + for (j = 0; j < counter.length; j++) { + sum += counter[j]; + } + normalized = self._normalize(counter); + if (normalized) { + for (code = 0; code < self.CODE_PATTERN.length; code++) { + error = self._matchPattern(normalized, self.CODE_PATTERN[code]); + if (error < bestMatch.error) { + bestMatch.code = code; + bestMatch.error = error; + } + } + if (bestMatch.error < epsilon) { + return bestMatch; + } + } + return null; + }; - function CodabarReader() { - _barcode_reader2["default"].call(this); - this._counters = []; - } + 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; - 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 } + 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; }; - CodabarReader.prototype = Object.create(_barcode_reader2["default"].prototype, properties); - CodabarReader.prototype.constructor = CodabarReader; + I2of5Reader.prototype._verifyCounterLength = function (counters) { + return counters.length % 10 === 0; + }; - CodabarReader.prototype._decode = function () { - var self = this, + I2of5Reader.prototype._decode = function () { + var startInfo, + endInfo, + self = this, + code, result = [], - start, - decodedChar, - pattern, - nextStart, - end; + decodedCodes = [], + counters; - this._counters = self._fillCounters(); - start = self._findStart(); - if (!start) { + startInfo = self._findStart(); + if (!startInfo) { 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)) { + decodedCodes.push(startInfo); + + endInfo = self._findEnd(); + if (!endInfo) { return null; } - // verify end white space - if (!self._verifyWhitespace(start.startCounter, nextStart - 8)) { + counters = self._fillCounters(startInfo.end, endInfo.start, false); + if (!self._verifyCounterLength(counters)) { return null; } - - if (!self._validateResult(result, start.startCounter)) { + code = self._decodePayload(counters, result, decodedCodes); + if (!code) { + return null; + } + if (result.length % 2 !== 0 || result.length < 6) { return null; } - nextStart = nextStart > self._counters.length ? self._counters.length : nextStart; - end = start.start + self._sumCounters(start.startCounter, nextStart - 8); - + decodedCodes.push(endInfo); return { code: result.join(""), - start: start.start, - end: end, - startInfo: start, - decodedCodes: result + start: startInfo.start, + end: endInfo.end, + startInfo: startInfo, + decodedCodes: decodedCodes }; }; - 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]; + I2of5Reader.CONFIG_KEYS = { + normalizeBarSpaceWidth: { + 'type': 'boolean', + 'default': false, + 'description': 'If true, the reader tries to normalize the' + 'width-difference between bars and spaces' } - - 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; - } + exports.default = I2of5Reader; + +/***/ }, +/* 70 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; - ["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); - }); + exports.__esModule = true; - return categorization; - }; + var _ean_reader = __webpack_require__(10); - CodabarReader.prototype._charToPattern = function (char) { - var self = this, - charCode = char.charCodeAt(0), - i; + var _ean_reader2 = _interopRequireDefault(_ean_reader); - for (i = 0; i < self.ALPHABET.length; i++) { - if (self.ALPHABET[i] === charCode) { - return self.CHARACTER_ENCODINGS[i]; - } - } - return 0x0; - }; + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - CodabarReader.prototype._validateResult = function (result, startCounter) { - var self = this, - thresholds = self._thresholdResultPattern(result, startCounter), - i, - j, - kind, - cat, - size, - pos = startCounter, - pattern; + function UPCEReader() { + _ean_reader2.default.call(this); + } - 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; + 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 } }; - 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; - }; + UPCEReader.prototype = Object.create(_ean_reader2.default.prototype, properties); + UPCEReader.prototype.constructor = UPCEReader; - CodabarReader.prototype._computeAlternatingThreshold = function (offset, end) { + UPCEReader.prototype._decodePayload = function (code, result, decodedCodes) { var i, - min = Number.MAX_VALUE, - max = 0, - counter; + self = this, + codeFrequency = 0x0; - for (i = offset; i < end; i += 2) { - counter = this._counters[i]; - if (counter > max) { - max = counter; + for (i = 0; i < 6; i++) { + code = self._decodeCode(code.end); + if (!code) { + return null; } - if (counter < min) { - min = counter; + 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 (min + max) / 2.0 | 0; + return code; }; - 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); + UPCEReader.prototype._determineParity = function (codeFrequency, result) { + var i, nrSystem; - for (i = 0; i < numCounters; i++) { - threshold = (i & 1) === 0 ? barThreshold : spaceThreshold; - if (this._counters[offset + i] > threshold) { - pattern |= bitmask; + 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; + } } - bitmask >>= 1; } - - return pattern; + return false; }; - CodabarReader.prototype._isStartEnd = function (pattern) { - var i; + UPCEReader.prototype._convertToUPCA = function (result) { + var upca = [result[0]], + lastDigit = result[result.length - 2]; - for (i = 0; i < this.START_END.length; i++) { - if (this.START_END[i] === pattern) { - return true; - } + 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]); } - return false; + + upca.push(result[result.length - 1]); + return upca; }; - CodabarReader.prototype._sumCounters = function (start, end) { - var i, - sum = 0; + UPCEReader.prototype._checksum = function (result) { + return _ean_reader2.default.prototype._checksum.call(this, this._convertToUPCA(result)); + }; - for (i = start; i < end; i++) { - sum += this._counters[i]; - } - return sum; + UPCEReader.prototype._findEnd = function (offset, isWhite) { + isWhite = true; + return _ean_reader2.default.prototype._findEnd.call(this, offset, isWhite); }; - CodabarReader.prototype._findStart = function () { + UPCEReader.prototype._verifyTrailingWhitespace = function (endInfo) { 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 - }; + 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"] = CodabarReader; - module.exports = exports["default"]; + exports.default = UPCEReader; /***/ }, -/* 22 */ +/* 71 */ /***/ function(module, exports, __webpack_require__) { "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + exports.__esModule = true; - var _ean_reader = __webpack_require__(18); + var _ean_reader = __webpack_require__(10); var _ean_reader2 = _interopRequireDefault(_ean_reader); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + function UPCReader() { - _ean_reader2["default"].call(this); + _ean_reader2.default.call(this); } var properties = { FORMAT: { value: "upc_a", writeable: false } }; - UPCReader.prototype = Object.create(_ean_reader2["default"].prototype, properties); + 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); + 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); @@ -5389,2492 +7882,4548 @@ module.exports = return null; }; - exports["default"] = UPCReader; - module.exports = exports["default"]; + exports.default = UPCReader; /***/ }, -/* 23 */ +/* 72 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; + module.e = copy - Object.defineProperty(exports, "__esModule", { - value: true - }); + /** + * 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 + } + + +/***/ }, +/* 73 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = create - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + /** + * 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 + } + + +/***/ }, +/* 74 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = invert - var _ean_reader = __webpack_require__(18); + /** + * 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 + } + + +/***/ }, +/* 75 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = scale - var _ean_reader2 = _interopRequireDefault(_ean_reader); + /** + * 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 + } + +/***/ }, +/* 76 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = transformMat2 - function EAN8Reader() { - _ean_reader2["default"].call(this); + /** + * 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 } + +/***/ }, +/* 77 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = clone; - var properties = { - FORMAT: { value: "ean_8", writeable: false } - }; + /** + * 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 + } + +/***/ }, +/* 78 */ +/***/ function(module, exports, __webpack_require__) { + + var nativeCreate = __webpack_require__(14); - EAN8Reader.prototype = Object.create(_ean_reader2["default"].prototype, properties); - EAN8Reader.prototype.constructor = EAN8Reader; + /** Used for built-in method references. */ + var objectProto = Object.prototype; - EAN8Reader.prototype._decodePayload = function (code, result, decodedCodes) { - var i, - self = this; + /** + * Creates an hash object. + * + * @private + * @constructor + * @returns {Object} Returns the new hash object. + */ + function Hash() {} - 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); - } + // Avoid inheriting from `Object.prototype` when possible. + Hash.prototype = nativeCreate ? nativeCreate(null) : objectProto; - code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false); - if (code === null) { - return null; - } - decodedCodes.push(code); + module.e = Hash; + + +/***/ }, +/* 79 */ +/***/ function(module, exports, __webpack_require__) { + + var mapClear = __webpack_require__(125), + mapDelete = __webpack_require__(126), + mapGet = __webpack_require__(127), + mapHas = __webpack_require__(128), + mapSet = __webpack_require__(129); - 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); + /** + * Creates a map cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [values] The values to cache. + */ + function MapCache(values) { + var index = -1, + length = values ? values.length : 0; + + this.clear(); + while (++index < length) { + var entry = values[index]; + this.set(entry[0], entry[1]); + } + } + + // Add functions to the `MapCache`. + MapCache.prototype.clear = mapClear; + MapCache.prototype['delete'] = mapDelete; + MapCache.prototype.get = mapGet; + MapCache.prototype.has = mapHas; + MapCache.prototype.set = mapSet; + + module.e = MapCache; + + +/***/ }, +/* 80 */ +/***/ function(module, exports, __webpack_require__) { + + var root = __webpack_require__(1); + + /** Built-in value references. */ + var Reflect = root.Reflect; + + module.e = Reflect; + + +/***/ }, +/* 81 */ +/***/ function(module, exports, __webpack_require__) { + + var getNative = __webpack_require__(12), + root = __webpack_require__(1); + + /* Built-in method references that are verified to be native. */ + var Set = getNative(root, 'Set'); + + module.e = Set; + + +/***/ }, +/* 82 */ +/***/ function(module, exports, __webpack_require__) { + + var root = __webpack_require__(1); + + /** Built-in value references. */ + var Symbol = root.Symbol; + + module.e = Symbol; + + +/***/ }, +/* 83 */ +/***/ function(module, exports, __webpack_require__) { + + var root = __webpack_require__(1); + + /** Built-in value references. */ + var Uint8Array = root.Uint8Array; + + module.e = Uint8Array; + + +/***/ }, +/* 84 */ +/***/ function(module, exports, __webpack_require__) { + + var getNative = __webpack_require__(12), + root = __webpack_require__(1); + + /* Built-in method references that are verified to be native. */ + var WeakMap = getNative(root, 'WeakMap'); + + module.e = WeakMap; + + +/***/ }, +/* 85 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Adds the key-value `pair` to `map`. + * + * @private + * @param {Object} map The map to modify. + * @param {Array} pair The key-value pair to add. + * @returns {Object} Returns `map`. + */ + function addMapEntry(map, pair) { + // Don't return `Map#set` because it doesn't return the map instance in IE 11. + map.set(pair[0], pair[1]); + return map; + } + + module.e = addMapEntry; + + +/***/ }, +/* 86 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Adds `value` to `set`. + * + * @private + * @param {Object} set The set to modify. + * @param {*} value The value to add. + * @returns {Object} Returns `set`. + */ + function addSetEntry(set, value) { + set.add(value); + return set; + } + + module.e = addSetEntry; + + +/***/ }, +/* 87 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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 {...*} args The arguments to invoke `func` with. + * @returns {*} Returns the result of `func`. + */ + function apply(func, thisArg, args) { + var length = args.length; + switch (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.e = apply; + + +/***/ }, +/* 88 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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.e = arrayPush; + + +/***/ }, +/* 89 */ +/***/ function(module, exports, __webpack_require__) { + + var copyObject = __webpack_require__(20), + keys = __webpack_require__(45); + + /** + * The base implementation of `_.assign` without support for multiple sources + * or `customizer` functions. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @returns {Object} Returns `object`. + */ + function baseAssign(object, source) { + return object && copyObject(source, keys(source), object); + } + + module.e = baseAssign; + + +/***/ }, +/* 90 */ +/***/ function(module, exports, __webpack_require__) { + + var Stack = __webpack_require__(32), + arrayEach = __webpack_require__(33), + assignValue = __webpack_require__(35), + baseAssign = __webpack_require__(89), + baseForOwn = __webpack_require__(94), + cloneBuffer = __webpack_require__(104), + copyArray = __webpack_require__(41), + copySymbols = __webpack_require__(111), + getTag = __webpack_require__(116), + initCloneArray = __webpack_require__(120), + initCloneByTag = __webpack_require__(121), + initCloneObject = __webpack_require__(122), + isArray = __webpack_require__(4), + isBuffer = __webpack_require__(138), + isHostObject = __webpack_require__(21), + isObject = __webpack_require__(2); + + /** `Object#toString` result references. */ + var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + mapTag = '[object Map]', + numberTag = '[object Number]', + objectTag = '[object Object]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]', + weakMapTag = '[object WeakMap]'; + + var arrayBufferTag = '[object ArrayBuffer]', + 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 supported by `_.clone`. */ + var cloneableTags = {}; + cloneableTags[argsTag] = cloneableTags[arrayTag] = + cloneableTags[arrayBufferTag] = cloneableTags[boolTag] = + cloneableTags[dateTag] = cloneableTags[float32Tag] = + cloneableTags[float64Tag] = cloneableTags[int8Tag] = + cloneableTags[int16Tag] = cloneableTags[int32Tag] = + cloneableTags[mapTag] = cloneableTags[numberTag] = + cloneableTags[objectTag] = cloneableTags[regexpTag] = + cloneableTags[setTag] = cloneableTags[stringTag] = + cloneableTags[symbolTag] = cloneableTags[uint8Tag] = + cloneableTags[uint8ClampedTag] = cloneableTags[uint16Tag] = + cloneableTags[uint32Tag] = true; + cloneableTags[errorTag] = cloneableTags[funcTag] = + cloneableTags[weakMapTag] = false; + + /** + * The base implementation of `_.clone` and `_.cloneDeep` which tracks + * traversed objects. + * + * @private + * @param {*} value The value to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @param {boolean} [isFull] Specify a clone including symbols. + * @param {Function} [customizer] The function to customize cloning. + * @param {string} [key] The key of `value`. + * @param {Object} [object] The parent object of `value`. + * @param {Object} [stack] Tracks traversed objects and their clone counterparts. + * @returns {*} Returns the cloned value. + */ + function baseClone(value, isDeep, isFull, customizer, key, object, stack) { + var result; + if (customizer) { + result = object ? customizer(value, key, object, stack) : customizer(value); + } + if (result !== undefined) { + return result; + } + if (!isObject(value)) { + return value; + } + var isArr = isArray(value); + if (isArr) { + result = initCloneArray(value); + if (!isDeep) { + return copyArray(value, result); + } + } else { + var tag = getTag(value), + isFunc = tag == funcTag || tag == genTag; + + if (isBuffer(value)) { + return cloneBuffer(value, isDeep); + } + if (tag == objectTag || tag == argsTag || (isFunc && !object)) { + if (isHostObject(value)) { + return object ? value : {}; + } + result = initCloneObject(isFunc ? {} : value); + if (!isDeep) { + result = baseAssign(result, value); + return isFull ? copySymbols(value, result) : result; + } + } else { + if (!cloneableTags[tag]) { + return object ? value : {}; + } + result = initCloneByTag(value, tag, isDeep); } + } + // Check for circular references and return its corresponding clone. + stack || (stack = new Stack); + var stacked = stack.get(value); + if (stacked) { + return stacked; + } + stack.set(value, result); - return code; - }; + // Recursively populate clone (susceptible to call stack limits). + (isArr ? arrayEach : baseForOwn)(value, function(subValue, key) { + assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack)); + }); + return (isFull && !isArr) ? copySymbols(value, result) : result; + } - exports["default"] = EAN8Reader; - module.exports = exports["default"]; + module.e = baseClone; + /***/ }, -/* 24 */ +/* 91 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); + var isObject = __webpack_require__(2); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + /** Built-in value references. */ + var objectCreate = Object.create; - var _ean_reader = __webpack_require__(18); - - var _ean_reader2 = _interopRequireDefault(_ean_reader); - - function UPCEReader() { - _ean_reader2["default"].call(this); + /** + * The base implementation of `_.create` without support for assigning + * properties to the created object. + * + * @private + * @param {Object} prototype The object to inherit from. + * @returns {Object} Returns the new object. + */ + function baseCreate(proto) { + return isObject(proto) ? objectCreate(proto) : {}; } - 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 } - }; + module.e = baseCreate; + + +/***/ }, +/* 92 */ +/***/ function(module, exports, __webpack_require__) { + + var arrayPush = __webpack_require__(88), + isArguments = __webpack_require__(24), + isArray = __webpack_require__(4), + isArrayLikeObject = __webpack_require__(26); - UPCEReader.prototype = Object.create(_ean_reader2["default"].prototype, properties); - UPCEReader.prototype.constructor = UPCEReader; + /** + * 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} [isStrict] Restrict flattening to arrays-like objects. + * @param {Array} [result=[]] The initial result value. + * @returns {Array} Returns the new flattened array. + */ + function baseFlatten(array, depth, isStrict, result) { + result || (result = []); - UPCEReader.prototype._decodePayload = function (code, result, decodedCodes) { - var i, - self = this, - codeFrequency = 0x0; + var index = -1, + length = array.length; - 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; + while (++index < length) { + var value = array[index]; + if (depth > 0 && isArrayLikeObject(value) && + (isStrict || isArray(value) || isArguments(value))) { + if (depth > 1) { + // Recursively flatten arrays (susceptible to call stack limits). + baseFlatten(value, depth - 1, isStrict, result); + } else { + arrayPush(result, value); + } + } else if (!isStrict) { + result[result.length] = value; } + } + return result; + } - 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; - }; + module.e = baseFlatten; + + +/***/ }, +/* 93 */ +/***/ function(module, exports, __webpack_require__) { + + var createBaseFor = __webpack_require__(113); - UPCEReader.prototype._convertToUPCA = function (result) { - var upca = [result[0]], - lastDigit = result[result.length - 2]; + /** + * The base implementation of `baseForIn` and `baseForOwn` which iterates + * over `object` properties returned by `keysFunc` invoking `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(); - 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]); - } + module.e = baseFor; + + +/***/ }, +/* 94 */ +/***/ function(module, exports, __webpack_require__) { + + var baseFor = __webpack_require__(93), + keys = __webpack_require__(45); - upca.push(result[result.length - 1]); - return upca; - }; + /** + * The base implementation of `_.forOwn` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ + function baseForOwn(object, iteratee) { + return object && baseFor(object, iteratee, keys); + } - UPCEReader.prototype._checksum = function (result) { - return _ean_reader2["default"].prototype._checksum.call(this, this._convertToUPCA(result)); - }; + module.e = baseForOwn; + + +/***/ }, +/* 95 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used for built-in method references. */ + var objectProto = Object.prototype; - UPCEReader.prototype._findEnd = function (offset, isWhite) { - isWhite = true; - return _ean_reader2["default"].prototype._findEnd.call(this, offset, isWhite); - }; + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; - UPCEReader.prototype._verifyTrailingWhitespace = function (endInfo) { - var self = this, - trailingWhitespaceEnd; + /** Built-in value references. */ + var getPrototypeOf = Object.getPrototypeOf; - trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; - if (trailingWhitespaceEnd < self._row.length) { - if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { - return endInfo; - } - } - }; + /** + * The base implementation of `_.has` 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 baseHas(object, key) { + // Avoid a bug in IE 10-11 where objects with a [[Prototype]] of `null`, + // that are composed entirely of index properties, return `false` for + // `hasOwnProperty` checks of them. + return hasOwnProperty.call(object, key) || + (typeof object == 'object' && key in object && getPrototypeOf(object) === null); + } - exports["default"] = UPCEReader; - module.exports = exports["default"]; + module.e = baseHas; + /***/ }, -/* 25 */ +/* 96 */ /***/ function(module, exports, __webpack_require__) { - 'use strict'; + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeKeys = Object.keys; - Object.defineProperty(exports, '__esModule', { - value: true - }); + /** + * The base implementation of `_.keys` which doesn't skip the constructor + * property of prototypes or treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeys(object) { + return nativeKeys(Object(object)); + } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + module.e = baseKeys; + + +/***/ }, +/* 97 */ +/***/ function(module, exports, __webpack_require__) { + + var Reflect = __webpack_require__(80), + iteratorToArray = __webpack_require__(124); - var _barcode_reader = __webpack_require__(17); + /** Used for built-in method references. */ + var objectProto = Object.prototype; - var _barcode_reader2 = _interopRequireDefault(_barcode_reader); + /** Built-in value references. */ + var enumerate = Reflect ? Reflect.enumerate : undefined, + propertyIsEnumerable = objectProto.propertyIsEnumerable; - var merge = __webpack_require__(26); + /** + * The base implementation of `_.keysIn` which doesn't skip the constructor + * property of prototypes or treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeysIn(object) { + object = object == null ? object : Object(object); - function I2of5Reader(opts) { - opts = merge(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; - } + var result = []; + for (var key in object) { + result.push(key); + } + return result; } - function getDefaulConfig() { - var config = {}; - - Object.keys(I2of5Reader.CONFIG_KEYS).forEach(function (key) { - config[key] = I2of5Reader.CONFIG_KEYS[key]['default']; - }); - return config; + // Fallback for IE < 9 with es6-shim. + if (enumerate && !propertyIsEnumerable.call({ 'valueOf': 1 }, 'valueOf')) { + baseKeysIn = function(object) { + return iteratorToArray(enumerate(object)); + }; } - var N = 1, - W = 3, - properties = { - MODULO: { value: 10 }, - START_PATTERN: { value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5] }, - STOP_PATTERN: { value: [N * 2, N * 2, W * 2] }, - 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; + module.e = baseKeysIn; + + +/***/ }, +/* 98 */ +/***/ function(module, exports, __webpack_require__) { + + var Stack = __webpack_require__(32), + arrayEach = __webpack_require__(33), + assignMergeValue = __webpack_require__(34), + baseMergeDeep = __webpack_require__(99), + isArray = __webpack_require__(4), + isObject = __webpack_require__(2), + isTypedArray = __webpack_require__(44), + keysIn = __webpack_require__(46); - isWhite = isWhite || false; - tryHarder = tryHarder || false; + /** + * 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; + } + var props = (isArray(source) || isTypedArray(source)) + ? undefined + : keysIn(source); - if (!offset) { - offset = self._nextSet(self._row); + arrayEach(props || source, function(srcValue, key) { + if (props) { + key = srcValue; + srcValue = source[key]; + } + if (isObject(srcValue)) { + stack || (stack = new Stack); + baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack); } + else { + var newValue = customizer + ? customizer(object[key], srcValue, (key + ''), object, source, stack) + : undefined; - for (i = 0; i < pattern.length; i++) { - counter[i] = 0; + if (newValue === undefined) { + newValue = srcValue; + } + assignMergeValue(object, key, newValue); } + }); + } - 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]; - } - normalized = self._normalize(counter); - if (normalized) { - error = self._matchPattern(normalized, pattern); + module.e = baseMerge; + + +/***/ }, +/* 99 */ +/***/ function(module, exports, __webpack_require__) { + + var assignMergeValue = __webpack_require__(34), + baseClone = __webpack_require__(90), + copyArray = __webpack_require__(41), + isArguments = __webpack_require__(24), + isArray = __webpack_require__(4), + isArrayLikeObject = __webpack_require__(26), + isFunction = __webpack_require__(16), + isObject = __webpack_require__(2), + isPlainObject = __webpack_require__(140), + isTypedArray = __webpack_require__(44), + toPlainObject = __webpack_require__(145); - 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; - }; + /** + * 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 = object[key], + srcValue = source[key], + stacked = stack.get(srcValue); + + if (stacked) { + assignMergeValue(object, key, stacked); + return; + } + var newValue = customizer + ? customizer(objValue, srcValue, (key + ''), object, source, stack) + : undefined; - I2of5Reader.prototype._findStart = function () { - var self = this, - leadingWhitespaceStart, - offset = self._nextSet(self._row), - startInfo, - narrowBarWidth = 1; + var isCommon = newValue === undefined; - 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; + if (isCommon) { + newValue = srcValue; + if (isArray(srcValue) || isTypedArray(srcValue)) { + if (isArray(objValue)) { + newValue = objValue; + } + else if (isArrayLikeObject(objValue)) { + newValue = copyArray(objValue); + } + else { + isCommon = false; + newValue = baseClone(srcValue, !customizer); + } } - }; + else if (isPlainObject(srcValue) || isArguments(srcValue)) { + if (isArguments(objValue)) { + newValue = toPlainObject(objValue); + } + else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) { + isCommon = false; + newValue = baseClone(srcValue, !customizer); + } + else { + newValue = objValue; + } + } + else { + isCommon = false; + } + } + stack.set(srcValue, newValue); - I2of5Reader.prototype._verifyTrailingWhitespace = function (endInfo) { - var self = this, - trailingWhitespaceEnd; + if (isCommon) { + // Recursively merge objects and arrays (susceptible to call stack limits). + mergeFunc(newValue, srcValue, srcIndex, customizer, stack); + } + stack['delete'](srcValue); + assignMergeValue(object, key, newValue); + } - trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2; - if (trailingWhitespaceEnd < self._row.length) { - if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) { - return endInfo; - } + module.e = baseMergeDeep; + + +/***/ }, +/* 100 */ +/***/ function(module, exports, __webpack_require__) { + + var arrayReduce = __webpack_require__(19); + + /** + * The base implementation of `_.pick` without support for individual + * property names. + * + * @private + * @param {Object} object The source object. + * @param {string[]} props The property names to pick. + * @returns {Object} Returns the new object. + */ + function basePick(object, props) { + object = Object(object); + return arrayReduce(props, function(result, key) { + if (key in object) { + result[key] = object[key]; } - return null; - }; + return result; + }, {}); + } - I2of5Reader.prototype._findEnd = function () { - var self = this, - endInfo, - tmp; + module.e = basePick; + + +/***/ }, +/* 101 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * The base implementation of `_.property` without support for deep paths. + * + * @private + * @param {string} key The key of the property to get. + * @returns {Function} Returns the new function. + */ + function baseProperty(key) { + return function(object) { + return object == null ? undefined : object[key]; + }; + } - self._row.reverse(); - endInfo = self._findPattern(self.STOP_PATTERN); - self._row.reverse(); + module.e = baseProperty; + + +/***/ }, +/* 102 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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); - if (endInfo === null) { - return null; - } + while (++index < n) { + result[index] = iteratee(index); + } + return result; + } - // reverse numbers - tmp = endInfo.start; - endInfo.start = self._row.length - endInfo.end; - endInfo.end = self._row.length - tmp; + module.e = baseTimes; + + +/***/ }, +/* 103 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * Checks if `value` is a global object. + * + * @private + * @param {*} value The value to check. + * @returns {null|Object} Returns `value` if it's a global object, else `null`. + */ + function checkGlobal(value) { + return (value && value.Object === Object) ? value : null; + } - return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null; - }; + module.e = checkGlobal; + + +/***/ }, +/* 104 */ +/***/ function(module, exports, __webpack_require__) { + + /** + * 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 result = new buffer.constructor(buffer.length); + buffer.copy(result); + return result; + } - I2of5Reader.prototype._decodePair = function (counterPair) { - var i, - code, - codes = [], - self = this; + module.e = cloneBuffer; + + +/***/ }, +/* 105 */ +/***/ function(module, exports, __webpack_require__) { + + var addMapEntry = __webpack_require__(85), + arrayReduce = __webpack_require__(19), + mapToArray = __webpack_require__(130); - for (i = 0; i < counterPair.length; i++) { - code = self._decodeCode(counterPair[i]); - if (!code) { - return null; - } - codes.push(code); - } - return codes; - }; + /** + * Creates a clone of `map`. + * + * @private + * @param {Object} map The map to clone. + * @returns {Object} Returns the cloned map. + */ + function cloneMap(map) { + return arrayReduce(mapToArray(map), addMapEntry, new map.constructor); + } + + module.e = cloneMap; + + +/***/ }, +/* 106 */ +/***/ function(module, exports, __webpack_require__) { + + /** Used to match `RegExp` flags from their coerced string values. */ + var reFlags = /\w*$/; + + /** + * Creates a clone of `regexp`. + * + * @private + * @param {Object} regexp The regexp to clone. + * @returns {Object} Returns the cloned regexp. + */ + function cloneRegExp(regexp) { + var result = new regexp.constructor(regexp.source, reFlags.exec(regexp)); + result.lastIndex = regexp.lastIndex; + return result; + } + + module.e = cloneRegExp; + + +/***/ }, +/* 107 */ +/***/ function(module, exports, __webpack_require__) { + + var addSetEntry = __webpack_require__(86), + arrayReduce = __webpack_require__(19), + setToArray = __webpack_require__(131); + + /** + * Creates a clone of `set`. + * + * @private + * @param {Object} set The set to clone. + * @returns {Object} Returns the cloned set. + */ + function cloneSet(set) { + return arrayReduce(setToArray(set), addSetEntry, new set.constructor); + } - 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 - }; + module.e = cloneSet; + + +/***/ }, +/* 108 */ +/***/ function(module, exports, __webpack_require__) { + + var Symbol = __webpack_require__(82); - for (j = 0; j < counter.length; j++) { - sum += counter[j]; - } - normalized = self._normalize(counter); - if (normalized) { - for (code = 0; code < self.CODE_PATTERN.length; code++) { - error = self._matchPattern(normalized, self.CODE_PATTERN[code]); - if (error < bestMatch.error) { - bestMatch.code = code; - bestMatch.error = error; - } - } - if (bestMatch.error < epsilon) { - return bestMatch; - } - } - return null; - }; + /** Used to convert symbols to primitives and strings. */ + var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolValueOf = symbolProto ? symbolProto.valueOf : undefined; - 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; + /** + * Creates a clone of the `symbol` object. + * + * @private + * @param {Object} symbol The symbol object to clone. + * @returns {Object} Returns the cloned symbol object. + */ + function cloneSymbol(symbol) { + return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {}; + } - 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; - }; + module.e = cloneSymbol; + + +/***/ }, +/* 109 */ +/***/ function(module, exports, __webpack_require__) { + + var cloneArrayBuffer = __webpack_require__(40); - I2of5Reader.prototype._verifyCounterLength = function (counters) { - return counters.length % 10 === 0; - }; + /** + * 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); + } - I2of5Reader.prototype._decode = function () { - var startInfo, - endInfo, - self = this, - code, - result = [], - decodedCodes = [], - counters; + module.e = cloneTypedArray; + + +/***/ }, +/* 110 */ +/***/ function(module, exports, __webpack_require__) { + + var assignValue = __webpack_require__(35); - startInfo = self._findStart(); - if (!startInfo) { - return null; - } - decodedCodes.push(startInfo); + /** + * This function is like `copyObject` except that it accepts a function to + * customize copied values. + * + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property names 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 copyObjectWith(source, props, object, customizer) { + object || (object = {}); - endInfo = self._findEnd(); - if (!endInfo) { - return null; - } + var index = -1, + length = props.length; - 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; - } + while (++index < length) { + var key = props[index]; - decodedCodes.push(endInfo); - return { - code: result.join(""), - start: startInfo.start, - end: endInfo.end, - startInfo: startInfo, - decodedCodes: decodedCodes - }; - }; + var newValue = customizer + ? customizer(object[key], source[key], key, object, source) + : source[key]; - I2of5Reader.CONFIG_KEYS = { - normalizeBarSpaceWidth: { - 'type': 'boolean', - 'default': false, - 'description': 'If true, the reader tries to normalize the' + 'width-difference between bars and spaces' - } - }; + assignValue(object, key, newValue); + } + return object; + } - exports['default'] = I2of5Reader; - module.exports = exports['default']; + module.e = copyObjectWith; + /***/ }, -/* 26 */ +/* 111 */ /***/ function(module, exports, __webpack_require__) { - var baseMerge = __webpack_require__(27), - createAssigner = __webpack_require__(54); + var copyObject = __webpack_require__(20), + getSymbols = __webpack_require__(115); /** - * Recursively merges own enumerable properties of the source object(s), that - * don't resolve to `undefined` into the destination object. Subsequent sources - * overwrite property assignments of previous sources. If `customizer` is - * provided it's invoked to produce the merged values of the destination and - * source properties. If `customizer` returns `undefined` merging is handled - * by the method instead. The `customizer` is bound to `thisArg` and invoked - * with five arguments: (objectValue, sourceValue, key, object, source). + * Copies own symbol properties of `source` to `object`. * - * @static - * @memberOf _ - * @category Object - * @param {Object} object The destination object. - * @param {...Object} [sources] The source objects. - * @param {Function} [customizer] The function to customize assigned values. - * @param {*} [thisArg] The `this` binding of `customizer`. + * @private + * @param {Object} source The object to copy symbols from. + * @param {Object} [object={}] The object to copy symbols to. * @returns {Object} Returns `object`. - * @example - * - * var users = { - * 'data': [{ 'user': 'barney' }, { 'user': 'fred' }] - * }; - * - * var ages = { - * 'data': [{ 'age': 36 }, { 'age': 40 }] - * }; - * - * _.merge(users, ages); - * // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] } - * - * // using a customizer callback - * var object = { - * 'fruits': ['apple'], - * 'vegetables': ['beet'] - * }; - * - * var other = { - * 'fruits': ['banana'], - * 'vegetables': ['carrot'] - * }; - * - * _.merge(object, other, function(a, b) { - * if (_.isArray(a)) { - * return a.concat(b); - * } - * }); - * // => { 'fruits': ['apple', 'banana'], 'vegetables': ['beet', 'carrot'] } */ - var merge = createAssigner(baseMerge); + function copySymbols(source, object) { + return copyObject(source, getSymbols(source), object); + } - module.exports = merge; + module.e = copySymbols; /***/ }, -/* 27 */ +/* 112 */ /***/ function(module, exports, __webpack_require__) { - var arrayEach = __webpack_require__(28), - baseMergeDeep = __webpack_require__(29), - isArray = __webpack_require__(37), - isArrayLike = __webpack_require__(32), - isObject = __webpack_require__(41), - isObjectLike = __webpack_require__(36), - isTypedArray = __webpack_require__(49), - keys = __webpack_require__(52); + var isIterateeCall = __webpack_require__(123), + rest = __webpack_require__(47); /** - * The base implementation of `_.merge` without support for argument juggling, - * multiple sources, and `this` binding `customizer` functions. + * Creates a function like `_.assign`. * * @private - * @param {Object} object The destination object. - * @param {Object} source The source object. - * @param {Function} [customizer] The function to customize merged values. - * @param {Array} [stackA=[]] Tracks traversed source objects. - * @param {Array} [stackB=[]] Associates values with source counterparts. - * @returns {Object} Returns `object`. + * @param {Function} assigner The function to assign values. + * @returns {Function} Returns the new assigner function. */ - function baseMerge(object, source, customizer, stackA, stackB) { - if (!isObject(object)) { - return object; - } - var isSrcArr = isArrayLike(source) && (isArray(source) || isTypedArray(source)), - props = isSrcArr ? undefined : keys(source); + function createAssigner(assigner) { + return rest(function(object, sources) { + var index = -1, + length = sources.length, + customizer = length > 1 ? sources[length - 1] : undefined, + guard = length > 2 ? sources[2] : undefined; - arrayEach(props || source, function(srcValue, key) { - if (props) { - key = srcValue; - srcValue = source[key]; - } - if (isObjectLike(srcValue)) { - stackA || (stackA = []); - stackB || (stackB = []); - baseMergeDeep(object, source, key, baseMerge, customizer, stackA, stackB); - } - else { - var value = object[key], - result = customizer ? customizer(value, srcValue, key, object, source) : undefined, - isCommon = result === undefined; + customizer = typeof customizer == 'function' + ? (length--, customizer) + : undefined; - if (isCommon) { - result = srcValue; - } - if ((result !== undefined || (isSrcArr && !(key in object))) && - (isCommon || (result === result ? (result !== value) : (value === value)))) { - object[key] = result; + 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; }); - return object; } - module.exports = baseMerge; + module.e = createAssigner; /***/ }, -/* 28 */ -/***/ function(module, exports) { +/* 113 */ +/***/ function(module, exports, __webpack_require__) { /** - * A specialized version of `_.forEach` for arrays without support for callback - * shorthands and `this` binding. + * Creates a base function for methods like `_.forIn`. * * @private - * @param {Array} array The array to iterate over. - * @param {Function} iteratee The function invoked per iteration. - * @returns {Array} Returns `array`. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. */ - function arrayEach(array, iteratee) { - var index = -1, - length = array.length; + function createBaseFor(fromRight) { + return function(object, iteratee, keysFunc) { + var index = -1, + iterable = Object(object), + props = keysFunc(object), + length = props.length; - while (++index < length) { - if (iteratee(array[index], index, array) === false) { - break; + while (length--) { + var key = props[fromRight ? length : ++index]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } } - } - return array; + return object; + }; } - module.exports = arrayEach; + module.e = createBaseFor; + + +/***/ }, +/* 114 */ +/***/ function(module, exports, __webpack_require__) { + + var baseProperty = __webpack_require__(101); + + /** + * Gets the "length" property value of `object`. + * + * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) + * that affects Safari on at least iOS 8.1-8.3 ARM64. + * + * @private + * @param {Object} object The object to query. + * @returns {*} Returns the "length" value. + */ + var getLength = baseProperty('length'); + + module.e = getLength; + + +/***/ }, +/* 115 */ +/***/ function(module, exports, __webpack_require__) { + + /** Built-in value references. */ + var getOwnPropertySymbols = Object.getOwnPropertySymbols; + + /** + * Creates an array of the own symbol properties of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ + var getSymbols = getOwnPropertySymbols || function() { + return []; + }; + + module.e = getSymbols; /***/ }, -/* 29 */ +/* 116 */ /***/ function(module, exports, __webpack_require__) { - var arrayCopy = __webpack_require__(30), - isArguments = __webpack_require__(31), - isArray = __webpack_require__(37), - isArrayLike = __webpack_require__(32), - isPlainObject = __webpack_require__(42), - isTypedArray = __webpack_require__(49), - toPlainObject = __webpack_require__(50); + var Map = __webpack_require__(3), + Set = __webpack_require__(81), + WeakMap = __webpack_require__(84); + + /** `Object#toString` result references. */ + var mapTag = '[object Map]', + objectTag = '[object Object]', + setTag = '[object Set]', + weakMapTag = '[object WeakMap]'; + + /** Used for built-in method references. */ + var objectProto = Object.prototype; + + /** Used to resolve the decompiled source of functions. */ + var funcToString = Function.prototype.toString; /** - * 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. + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; + + /** Used to detect maps, sets, and weakmaps. */ + var mapCtorString = Map ? funcToString.call(Map) : '', + setCtorString = Set ? funcToString.call(Set) : '', + weakMapCtorString = WeakMap ? funcToString.call(WeakMap) : ''; + + /** + * Gets the `toStringTag` of `value`. * * @private - * @param {Object} object The destination object. - * @param {Object} source The source object. - * @param {string} key The key of the value to merge. - * @param {Function} mergeFunc The function to merge values. - * @param {Function} [customizer] The function to customize merged values. - * @param {Array} [stackA=[]] Tracks traversed source objects. - * @param {Array} [stackB=[]] Associates values with source counterparts. - * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. */ - function baseMergeDeep(object, source, key, mergeFunc, customizer, stackA, stackB) { - var length = stackA.length, - srcValue = source[key]; - - while (length--) { - if (stackA[length] == srcValue) { - object[key] = stackB[length]; - return; - } - } - var value = object[key], - result = customizer ? customizer(value, srcValue, key, object, source) : undefined, - isCommon = result === undefined; + function getTag(value) { + return objectToString.call(value); + } - if (isCommon) { - result = srcValue; - if (isArrayLike(srcValue) && (isArray(srcValue) || isTypedArray(srcValue))) { - result = isArray(value) - ? value - : (isArrayLike(value) ? arrayCopy(value) : []); - } - else if (isPlainObject(srcValue) || isArguments(srcValue)) { - result = isArguments(value) - ? toPlainObject(value) - : (isPlainObject(value) ? value : {}); - } - else { - isCommon = false; + // Fallback for IE 11 providing `toStringTag` values for maps, sets, and weakmaps. + if ((Map && getTag(new Map) != mapTag) || + (Set && getTag(new Set) != setTag) || + (WeakMap && getTag(new WeakMap) != weakMapTag)) { + getTag = function(value) { + var result = objectToString.call(value), + Ctor = result == objectTag ? value.constructor : null, + ctorString = typeof Ctor == 'function' ? funcToString.call(Ctor) : ''; + + if (ctorString) { + switch (ctorString) { + case mapCtorString: return mapTag; + case setCtorString: return setTag; + case weakMapCtorString: return weakMapTag; + } } - } - // Add the source value to the stack of traversed objects and associate - // it with its merged value. - stackA.push(srcValue); - stackB.push(result); - - if (isCommon) { - // Recursively merge objects and arrays (susceptible to call stack limits). - object[key] = mergeFunc(result, srcValue, customizer, stackA, stackB); - } else if (result === result ? (result !== value) : (value === value)) { - object[key] = result; - } + return result; + }; } - module.exports = baseMergeDeep; + module.e = getTag; /***/ }, -/* 30 */ -/***/ function(module, exports) { +/* 117 */ +/***/ function(module, exports, __webpack_require__) { + var hashHas = __webpack_require__(42); + /** - * Copies the values of `source` to `array`. + * Removes `key` and its value from the hash. * * @private - * @param {Array} source The array to copy values from. - * @param {Array} [array=[]] The array to copy values to. - * @returns {Array} Returns `array`. + * @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 arrayCopy(source, array) { - var index = -1, - length = source.length; - - array || (array = Array(length)); - while (++index < length) { - array[index] = source[index]; - } - return array; + function hashDelete(hash, key) { + return hashHas(hash, key) && delete hash[key]; } - module.exports = arrayCopy; + module.e = hashDelete; /***/ }, -/* 31 */ +/* 118 */ /***/ function(module, exports, __webpack_require__) { - var isArrayLike = __webpack_require__(32), - isObjectLike = __webpack_require__(36); + var nativeCreate = __webpack_require__(14); + + /** Used to stand-in for `undefined` hash values. */ + var HASH_UNDEFINED = '__lodash_hash_undefined__'; - /** Used for native method references. */ + /** Used for built-in method references. */ var objectProto = Object.prototype; /** Used to check objects for own properties. */ var hasOwnProperty = objectProto.hasOwnProperty; - /** Native method references. */ - var propertyIsEnumerable = objectProto.propertyIsEnumerable; - /** - * Checks if `value` is classified as an `arguments` object. - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. - * @example - * - * _.isArguments(function() { return arguments; }()); - * // => true + * Gets the hash value for `key`. * - * _.isArguments([1, 2, 3]); - * // => false + * @private + * @param {Object} hash The hash to query. + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. */ - function isArguments(value) { - return isObjectLike(value) && isArrayLike(value) && - hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee'); + function hashGet(hash, key) { + if (nativeCreate) { + var result = hash[key]; + return result === HASH_UNDEFINED ? undefined : result; + } + return hasOwnProperty.call(hash, key) ? hash[key] : undefined; } - module.exports = isArguments; + module.e = hashGet; /***/ }, -/* 32 */ +/* 119 */ /***/ function(module, exports, __webpack_require__) { - var getLength = __webpack_require__(33), - isLength = __webpack_require__(35); + var nativeCreate = __webpack_require__(14); + + /** Used to stand-in for `undefined` hash values. */ + var HASH_UNDEFINED = '__lodash_hash_undefined__'; /** - * Checks if `value` is array-like. + * Sets the hash `key` to `value`. * * @private - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is array-like, else `false`. + * @param {Object} hash The hash to modify. + * @param {string} key The key of the value to set. + * @param {*} value The value to set. */ - function isArrayLike(value) { - return value != null && isLength(getLength(value)); + function hashSet(hash, key, value) { + hash[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value; } - module.exports = isArrayLike; + module.e = hashSet; /***/ }, -/* 33 */ +/* 120 */ /***/ function(module, exports, __webpack_require__) { - var baseProperty = __webpack_require__(34); + /** Used for built-in method references. */ + var objectProto = Object.prototype; - /** - * Gets the "length" property value of `object`. - * - * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) - * that affects Safari on at least iOS 8.1-8.3 ARM64. - * - * @private - * @param {Object} object The object to query. - * @returns {*} Returns the "length" value. - */ - var getLength = baseProperty('length'); + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; - module.exports = getLength; - - -/***/ }, -/* 34 */ -/***/ function(module, exports) { - /** - * The base implementation of `_.property` without support for deep paths. + * Initializes an array clone. * * @private - * @param {string} key The key of the property to get. - * @returns {Function} Returns the new function. + * @param {Array} array The array to clone. + * @returns {Array} Returns the initialized clone. */ - function baseProperty(key) { - return function(object) { - return object == null ? undefined : object[key]; - }; + function initCloneArray(array) { + var length = array.length, + result = array.constructor(length); + + // Add properties assigned by `RegExp#exec`. + if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) { + result.index = array.index; + result.input = array.input; + } + return result; } - module.exports = baseProperty; + module.e = initCloneArray; /***/ }, -/* 35 */ -/***/ function(module, exports) { +/* 121 */ +/***/ function(module, exports, __webpack_require__) { - /** - * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) - * of an array-like value. - */ - var MAX_SAFE_INTEGER = 9007199254740991; + var cloneArrayBuffer = __webpack_require__(40), + cloneMap = __webpack_require__(105), + cloneRegExp = __webpack_require__(106), + cloneSet = __webpack_require__(107), + cloneSymbol = __webpack_require__(108), + cloneTypedArray = __webpack_require__(109); + + /** `Object#toString` result references. */ + var boolTag = '[object Boolean]', + dateTag = '[object Date]', + mapTag = '[object Map]', + numberTag = '[object Number]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]'; + + var arrayBufferTag = '[object ArrayBuffer]', + 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]'; /** - * Checks if `value` is a valid array-like length. + * Initializes an object clone based on its `toStringTag`. * - * **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). + * **Note:** This function only supports cloning values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. * * @private - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. + * @param {Object} object The object to clone. + * @param {string} tag The `toStringTag` of the object to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the initialized clone. */ - function isLength(value) { - return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; + function initCloneByTag(object, tag, isDeep) { + var Ctor = object.constructor; + switch (tag) { + case arrayBufferTag: + return cloneArrayBuffer(object); + + case boolTag: + case dateTag: + return new Ctor(+object); + + case float32Tag: case float64Tag: + case int8Tag: case int16Tag: case int32Tag: + case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag: + return cloneTypedArray(object, isDeep); + + case mapTag: + return cloneMap(object); + + case numberTag: + case stringTag: + return new Ctor(object); + + case regexpTag: + return cloneRegExp(object); + + case setTag: + return cloneSet(object); + + case symbolTag: + return cloneSymbol(object); + } } - module.exports = isLength; + module.e = initCloneByTag; /***/ }, -/* 36 */ -/***/ function(module, exports) { +/* 122 */ +/***/ function(module, exports, __webpack_require__) { + var baseCreate = __webpack_require__(91), + isPrototype = __webpack_require__(23); + + /** Built-in value references. */ + var getPrototypeOf = Object.getPrototypeOf; + /** - * Checks if `value` is object-like. + * Initializes an object clone. * * @private - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is object-like, else `false`. + * @param {Object} object The object to clone. + * @returns {Object} Returns the initialized clone. */ - function isObjectLike(value) { - return !!value && typeof value == 'object'; + function initCloneObject(object) { + return (typeof object.constructor == 'function' && !isPrototype(object)) + ? baseCreate(getPrototypeOf(object)) + : {}; } - module.exports = isObjectLike; + module.e = initCloneObject; /***/ }, -/* 37 */ +/* 123 */ /***/ function(module, exports, __webpack_require__) { - var getNative = __webpack_require__(38), - isLength = __webpack_require__(35), - isObjectLike = __webpack_require__(36); - - /** `Object#toString` result references. */ - var arrayTag = '[object Array]'; - - /** Used for native method references. */ - var objectProto = Object.prototype; - - /** - * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) - * of values. - */ - var objToString = objectProto.toString; - - /* Native method references for those with the same name as other `lodash` methods. */ - var nativeIsArray = getNative(Array, 'isArray'); + var eq = __webpack_require__(15), + isArrayLike = __webpack_require__(25), + isIndex = __webpack_require__(22), + isObject = __webpack_require__(2); /** - * Checks if `value` is classified as an `Array` object. - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. - * @example - * - * _.isArray([1, 2, 3]); - * // => true + * Checks if the given arguments are from an iteratee call. * - * _.isArray(function() { return arguments; }()); - * // => false + * @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`. */ - var isArray = nativeIsArray || function(value) { - return isObjectLike(value) && isLength(value.length) && objToString.call(value) == arrayTag; - }; + 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 = isArray; + module.e = isIterateeCall; /***/ }, -/* 38 */ +/* 124 */ /***/ function(module, exports, __webpack_require__) { - var isNative = __webpack_require__(39); - /** - * Gets the native function at `key` of `object`. + * Converts `iterator` to an array. * * @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`. + * @param {Object} iterator The iterator to convert. + * @returns {Array} Returns the converted array. */ - function getNative(object, key) { - var value = object == null ? undefined : object[key]; - return isNative(value) ? value : undefined; + function iteratorToArray(iterator) { + var data, + result = []; + + while (!(data = iterator.next()).done) { + result.push(data.value); + } + return result; } - module.exports = getNative; + module.e = iteratorToArray; /***/ }, -/* 39 */ +/* 125 */ /***/ function(module, exports, __webpack_require__) { - var isFunction = __webpack_require__(40), - isObjectLike = __webpack_require__(36); - - /** Used to detect host constructors (Safari > 5). */ - var reIsHostCtor = /^\[object .+?Constructor\]$/; - - /** Used for native method references. */ - var objectProto = Object.prototype; + var Hash = __webpack_require__(78), + Map = __webpack_require__(3); - /** Used to resolve the decompiled source of functions. */ - var fnToString = Function.prototype.toString; - - /** Used to check objects for own properties. */ - var hasOwnProperty = objectProto.hasOwnProperty; - - /** Used to detect if a method is native. */ - var reIsNative = RegExp('^' + - fnToString.call(hasOwnProperty).replace(/[\\^$.*+?()[\]{}|]/g, '\\$&') - .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' - ); - - /** - * Checks if `value` is a native function. - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is a native function, else `false`. - * @example - * - * _.isNative(Array.prototype.push); - * // => true - * - * _.isNative(_); - * // => false - */ - function isNative(value) { - if (value == null) { - return false; - } - if (isFunction(value)) { - return reIsNative.test(fnToString.call(value)); - } - return isObjectLike(value) && reIsHostCtor.test(value); + /** + * Removes all key-value entries from the map. + * + * @private + * @name clear + * @memberOf MapCache + */ + function mapClear() { + this.__data__ = { + 'hash': new Hash, + 'map': Map ? new Map : [], + 'string': new Hash + }; } - module.exports = isNative; + module.e = mapClear; /***/ }, -/* 40 */ +/* 126 */ /***/ function(module, exports, __webpack_require__) { - var isObject = __webpack_require__(41); - - /** `Object#toString` result references. */ - var funcTag = '[object Function]'; - - /** Used for native method references. */ - var objectProto = Object.prototype; - - /** - * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) - * of values. - */ - var objToString = objectProto.toString; + var Map = __webpack_require__(3), + assocDelete = __webpack_require__(36), + hashDelete = __webpack_require__(117), + isKeyable = __webpack_require__(13); /** - * Checks if `value` is classified as a `Function` object. + * Removes `key` and its value from the map. * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. - * @example - * - * _.isFunction(_); - * // => true - * - * _.isFunction(/abc/); - * // => false + * @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 isFunction(value) { - // The use of `Object#toString` avoids issues with the `typeof` operator - // in older versions of Chrome and Safari which return 'function' for regexes - // and Safari 8 which returns 'object' for typed array constructors. - return isObject(value) && objToString.call(value) == funcTag; + function mapDelete(key) { + var data = this.__data__; + if (isKeyable(key)) { + return hashDelete(typeof key == 'string' ? data.string : data.hash, key); + } + return Map ? data.map['delete'](key) : assocDelete(data.map, key); } - module.exports = isFunction; + module.e = mapDelete; /***/ }, -/* 41 */ -/***/ function(module, exports) { +/* 127 */ +/***/ function(module, exports, __webpack_require__) { + var Map = __webpack_require__(3), + assocGet = __webpack_require__(37), + hashGet = __webpack_require__(118), + isKeyable = __webpack_require__(13); + /** - * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. - * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is an object, else `false`. - * @example - * - * _.isObject({}); - * // => true + * Gets the map value for `key`. * - * _.isObject([1, 2, 3]); - * // => true - * - * _.isObject(1); - * // => false + * @private + * @name get + * @memberOf MapCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. */ - function isObject(value) { - // Avoid a V8 JIT bug in Chrome 19-20. - // See https://code.google.com/p/v8/issues/detail?id=2291 for more details. - var type = typeof value; - return !!value && (type == 'object' || type == 'function'); + function mapGet(key) { + var data = this.__data__; + if (isKeyable(key)) { + return hashGet(typeof key == 'string' ? data.string : data.hash, key); + } + return Map ? data.map.get(key) : assocGet(data.map, key); } - module.exports = isObject; + module.e = mapGet; /***/ }, -/* 42 */ +/* 128 */ /***/ function(module, exports, __webpack_require__) { - var baseForIn = __webpack_require__(43), - isArguments = __webpack_require__(31), - isObjectLike = __webpack_require__(36); - - /** `Object#toString` result references. */ - var objectTag = '[object Object]'; - - /** Used for native 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/6.0/#sec-object.prototype.tostring) - * of values. - */ - var objToString = objectProto.toString; + var Map = __webpack_require__(3), + assocHas = __webpack_require__(38), + hashHas = __webpack_require__(42), + isKeyable = __webpack_require__(13); /** - * Checks if `value` is a plain object, that is, an object created by the - * `Object` constructor or one with a `[[Prototype]]` of `null`. - * - * **Note:** This method assumes objects created by the `Object` constructor - * have no inherited enumerable properties. - * - * @static - * @memberOf _ - * @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 + * Checks if a map value for `key` exists. * - * _.isPlainObject([1, 2, 3]); - * // => false - * - * _.isPlainObject({ 'x': 0, 'y': 0 }); - * // => true - * - * _.isPlainObject(Object.create(null)); - * // => true + * @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 isPlainObject(value) { - var Ctor; - - // Exit early for non `Object` objects. - if (!(isObjectLike(value) && objToString.call(value) == objectTag && !isArguments(value)) || - (!hasOwnProperty.call(value, 'constructor') && (Ctor = value.constructor, typeof Ctor == 'function' && !(Ctor instanceof Ctor)))) { - return false; + function mapHas(key) { + var data = this.__data__; + if (isKeyable(key)) { + return hashHas(typeof key == 'string' ? data.string : data.hash, key); } - // IE < 9 iterates inherited properties before own properties. If the first - // iterated property is an object's own property then there are no inherited - // enumerable properties. - var result; - // In most environments an object's own properties are iterated before - // its inherited properties. If the last iterated property is an object's - // own property then there are no inherited enumerable properties. - baseForIn(value, function(subValue, key) { - result = key; - }); - return result === undefined || hasOwnProperty.call(value, result); + return Map ? data.map.has(key) : assocHas(data.map, key); } - module.exports = isPlainObject; + module.e = mapHas; /***/ }, -/* 43 */ +/* 129 */ /***/ function(module, exports, __webpack_require__) { - var baseFor = __webpack_require__(44), - keysIn = __webpack_require__(47); + var Map = __webpack_require__(3), + assocSet = __webpack_require__(39), + hashSet = __webpack_require__(119), + isKeyable = __webpack_require__(13); /** - * The base implementation of `_.forIn` without support for callback - * shorthands and `this` binding. + * Sets the map `key` to `value`. * * @private - * @param {Object} object The object to iterate over. - * @param {Function} iteratee The function invoked per iteration. - * @returns {Object} Returns `object`. + * @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 object. */ - function baseForIn(object, iteratee) { - return baseFor(object, iteratee, keysIn); + function mapSet(key, value) { + var data = this.__data__; + if (isKeyable(key)) { + hashSet(typeof key == 'string' ? data.string : data.hash, key, value); + } else if (Map) { + data.map.set(key, value); + } else { + assocSet(data.map, key, value); + } + return this; } - module.exports = baseForIn; + module.e = mapSet; /***/ }, -/* 44 */ +/* 130 */ /***/ function(module, exports, __webpack_require__) { - var createBaseFor = __webpack_require__(45); - /** - * The base implementation of `baseForIn` and `baseForOwn` which iterates - * over `object` properties returned by `keysFunc` invoking `iteratee` for - * each property. Iteratee functions may exit iteration early by explicitly - * returning `false`. + * Converts `map` to an array. * * @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`. + * @param {Object} map The map to convert. + * @returns {Array} Returns the converted array. */ - var baseFor = createBaseFor(); + function mapToArray(map) { + var index = -1, + result = Array(map.size); + + map.forEach(function(value, key) { + result[++index] = [key, value]; + }); + return result; + } - module.exports = baseFor; + module.e = mapToArray; /***/ }, -/* 45 */ +/* 131 */ /***/ function(module, exports, __webpack_require__) { - var toObject = __webpack_require__(46); - /** - * Creates a base function for `_.forIn` or `_.forInRight`. + * Converts `set` to an array. * * @private - * @param {boolean} [fromRight] Specify iterating from right to left. - * @returns {Function} Returns the new base function. + * @param {Object} set The set to convert. + * @returns {Array} Returns the converted array. */ - function createBaseFor(fromRight) { - return function(object, iteratee, keysFunc) { - var iterable = toObject(object), - props = keysFunc(object), - length = props.length, - index = fromRight ? length : -1; + function setToArray(set) { + var index = -1, + result = Array(set.size); - while ((fromRight ? index-- : ++index < length)) { - var key = props[index]; - if (iteratee(iterable[key], key, iterable) === false) { - break; - } - } - return object; - }; + set.forEach(function(value) { + result[++index] = value; + }); + return result; } - module.exports = createBaseFor; + module.e = setToArray; /***/ }, -/* 46 */ +/* 132 */ /***/ function(module, exports, __webpack_require__) { - var isObject = __webpack_require__(41); - /** - * Converts `value` to an object if it's not one. + * Removes all key-value entries from the stack. * * @private - * @param {*} value The value to process. - * @returns {Object} Returns the object. + * @name clear + * @memberOf Stack */ - function toObject(value) { - return isObject(value) ? value : Object(value); + function stackClear() { + this.__data__ = { 'array': [], 'map': null }; } - module.exports = toObject; + module.e = stackClear; /***/ }, -/* 47 */ +/* 133 */ /***/ function(module, exports, __webpack_require__) { - var isArguments = __webpack_require__(31), - isArray = __webpack_require__(37), - isIndex = __webpack_require__(48), - isLength = __webpack_require__(35), - isObject = __webpack_require__(41); - - /** Used for native method references. */ - var objectProto = Object.prototype; - - /** Used to check objects for own properties. */ - var hasOwnProperty = objectProto.hasOwnProperty; + var assocDelete = __webpack_require__(36); /** - * Creates an array of the own and inherited enumerable property names of `object`. - * - * **Note:** Non-object values are coerced to objects. - * - * @static - * @memberOf _ - * @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; + * Removes `key` and its value from the stack. * - * _.keysIn(new Foo); - * // => ['a', 'b', 'c'] (iteration order is not guaranteed) + * @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 keysIn(object) { - if (object == null) { - return []; - } - if (!isObject(object)) { - object = Object(object); - } - var length = object.length; - length = (length && isLength(length) && - (isArray(object) || isArguments(object)) && length) || 0; - - var Ctor = object.constructor, - index = -1, - isProto = typeof Ctor == 'function' && Ctor.prototype === object, - result = Array(length), - skipIndexes = length > 0; + function stackDelete(key) { + var data = this.__data__, + array = data.array; - while (++index < length) { - result[index] = (index + ''); - } - for (var key in object) { - if (!(skipIndexes && isIndex(key, length)) && - !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { - result.push(key); - } - } - return result; + return array ? assocDelete(array, key) : data.map['delete'](key); } - module.exports = keysIn; + module.e = stackDelete; /***/ }, -/* 48 */ -/***/ function(module, exports) { +/* 134 */ +/***/ function(module, exports, __webpack_require__) { - /** Used to detect unsigned integer values. */ - var reIsUint = /^\d+$/; - - /** - * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) - * of an array-like value. - */ - var MAX_SAFE_INTEGER = 9007199254740991; + var assocGet = __webpack_require__(37); /** - * Checks if `value` is a valid array-like index. + * Gets the stack value for `key`. * * @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`. + * @name get + * @memberOf Stack + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. */ - function isIndex(value, length) { - value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1; - length = length == null ? MAX_SAFE_INTEGER : length; - return value > -1 && value % 1 == 0 && value < length; + function stackGet(key) { + var data = this.__data__, + array = data.array; + + return array ? assocGet(array, key) : data.map.get(key); } - module.exports = isIndex; + module.e = stackGet; /***/ }, -/* 49 */ +/* 135 */ /***/ function(module, exports, __webpack_require__) { - var isLength = __webpack_require__(35), - isObjectLike = __webpack_require__(36); + var assocHas = __webpack_require__(38); - /** `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]'; + /** + * 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) { + var data = this.__data__, + array = data.array; - var arrayBufferTag = '[object ArrayBuffer]', - 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]'; + return array ? assocHas(array, key) : data.map.has(key); + } - /** 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[dateTag] = typedArrayTags[errorTag] = - typedArrayTags[funcTag] = typedArrayTags[mapTag] = - typedArrayTags[numberTag] = typedArrayTags[objectTag] = - typedArrayTags[regexpTag] = typedArrayTags[setTag] = - typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false; + module.e = stackHas; + + +/***/ }, +/* 136 */ +/***/ function(module, exports, __webpack_require__) { + + var MapCache = __webpack_require__(79), + assocSet = __webpack_require__(39); - /** Used for native method references. */ - var objectProto = Object.prototype; + /** Used as the size to enable large array optimizations. */ + var LARGE_ARRAY_SIZE = 200; /** - * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) - * of values. + * 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 object. */ - var objToString = objectProto.toString; + function stackSet(key, value) { + var data = this.__data__, + array = data.array; + + if (array) { + if (array.length < (LARGE_ARRAY_SIZE - 1)) { + assocSet(array, key, value); + } else { + data.array = null; + data.map = new MapCache(array); + } + } + var map = data.map; + if (map) { + map.set(key, value); + } + return this; + } + module.e = stackSet; + + +/***/ }, +/* 137 */ +/***/ function(module, exports, __webpack_require__) { + /** - * Checks if `value` is classified as a typed array. + * Creates a function that returns `value`. * * @static * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @category Util + * @param {*} value The value to return from the new function. + * @returns {Function} Returns the new function. * @example * - * _.isTypedArray(new Uint8Array); - * // => true + * var object = { 'user': 'fred' }; + * var getter = _.constant(object); * - * _.isTypedArray([]); - * // => false + * getter() === object; + * // => true */ - function isTypedArray(value) { - return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objToString.call(value)]; + function constant(value) { + return function() { + return value; + }; } - module.exports = isTypedArray; + module.e = constant; /***/ }, -/* 50 */ +/* 138 */ /***/ function(module, exports, __webpack_require__) { - var baseCopy = __webpack_require__(51), - keysIn = __webpack_require__(47); + /* WEBPACK VAR INJECTION */(function(module) {var constant = __webpack_require__(137), + root = __webpack_require__(1); + + /** Used to determine if values are of the language type `Object`. */ + var objectTypes = { + 'function': true, + 'object': true + }; + + /** Detect free variable `exports`. */ + var freeExports = (objectTypes[typeof exports] && exports && !exports.nodeType) + ? exports + : undefined; + + /** Detect free variable `module`. */ + var freeModule = (objectTypes[typeof module] && module && !module.nodeType) + ? module + : undefined; + + /** Detect the popular CommonJS extension `module.exports`. */ + var moduleExports = (freeModule && freeModule.exports === freeExports) + ? freeExports + : undefined; + + /** Built-in value references. */ + var Buffer = moduleExports ? root.Buffer : undefined; /** - * Converts `value` to a plain object flattening inherited enumerable - * properties of `value` to own properties of the plain object. + * Checks if `value` is a buffer. * * @static * @memberOf _ * @category Lang - * @param {*} value The value to convert. - * @returns {Object} Returns the converted plain object. + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a buffer, else `false`. * @example * - * function Foo() { - * this.b = 2; - * } - * - * Foo.prototype.c = 3; - * - * _.assign({ 'a': 1 }, new Foo); - * // => { 'a': 1, 'b': 2 } + * _.isBuffer(new Buffer(2)); + * // => true * - * _.assign({ 'a': 1 }, _.toPlainObject(new Foo)); - * // => { 'a': 1, 'b': 2, 'c': 3 } + * _.isBuffer(new Uint8Array(2)); + * // => false */ - function toPlainObject(value) { - return baseCopy(value, keysIn(value)); - } + var isBuffer = !Buffer ? constant(false) : function(value) { + return value instanceof Buffer; + }; - module.exports = toPlainObject; - + module.e = isBuffer; + + /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(48)(module))) /***/ }, -/* 51 */ -/***/ function(module, exports) { +/* 139 */ +/***/ function(module, exports, __webpack_require__) { + var isFunction = __webpack_require__(16), + isHostObject = __webpack_require__(21), + isObjectLike = __webpack_require__(7); + + /** Used to match `RegExp` [syntax characters](http://ecma-international.org/ecma-262/6.0/#sec-patterns). */ + var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; + + /** Used to detect host constructors (Safari > 5). */ + var reIsHostCtor = /^\[object .+?Constructor\]$/; + + /** Used for built-in method references. */ + var objectProto = Object.prototype; + + /** Used to resolve the decompiled source of functions. */ + var funcToString = Function.prototype.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.*?') + '$' + ); + /** - * Copies properties of `source` to `object`. + * Checks if `value` is a native function. * - * @private - * @param {Object} source The object to copy properties from. - * @param {Array} props The property names to copy. - * @param {Object} [object={}] The object to copy properties to. - * @returns {Object} Returns `object`. + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, else `false`. + * @example + * + * _.isNative(Array.prototype.push); + * // => true + * + * _.isNative(_); + * // => false */ - function baseCopy(source, props, object) { - object || (object = {}); - - var index = -1, - length = props.length; - - while (++index < length) { - var key = props[index]; - object[key] = source[key]; + function isNative(value) { + if (value == null) { + return false; } - return object; + if (isFunction(value)) { + return reIsNative.test(funcToString.call(value)); + } + return isObjectLike(value) && + (isHostObject(value) ? reIsNative : reIsHostCtor).test(value); } - module.exports = baseCopy; + module.e = isNative; /***/ }, -/* 52 */ +/* 140 */ /***/ function(module, exports, __webpack_require__) { - var getNative = __webpack_require__(38), - isArrayLike = __webpack_require__(32), - isObject = __webpack_require__(41), - shimKeys = __webpack_require__(53); + var isHostObject = __webpack_require__(21), + isObjectLike = __webpack_require__(7); - /* Native method references for those with the same name as other `lodash` methods. */ - var nativeKeys = getNative(Object, 'keys'); + /** `Object#toString` result references. */ + var objectTag = '[object Object]'; + + /** Used for built-in method references. */ + var objectProto = Object.prototype; + + /** Used to resolve the decompiled source of functions. */ + var funcToString = Function.prototype.toString; + + /** Used to infer the `Object` constructor. */ + var objectCtorString = funcToString.call(Object); /** - * Creates an array of the own enumerable property names of `object`. - * - * **Note:** Non-object values are coerced to objects. See the - * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys) - * for more details. + * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; + + /** Built-in value references. */ + var getPrototypeOf = Object.getPrototypeOf; + + /** + * 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 _ - * @category Object - * @param {Object} object The object to query. - * @returns {Array} Returns the array of property names. + * @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; - * this.b = 2; * } * - * Foo.prototype.c = 3; + * _.isPlainObject(new Foo); + * // => false * - * _.keys(new Foo); - * // => ['a', 'b'] (iteration order is not guaranteed) + * _.isPlainObject([1, 2, 3]); + * // => false * - * _.keys('hi'); - * // => ['0', '1'] + * _.isPlainObject({ 'x': 0, 'y': 0 }); + * // => true + * + * _.isPlainObject(Object.create(null)); + * // => true */ - var keys = !nativeKeys ? shimKeys : function(object) { - var Ctor = object == null ? undefined : object.constructor; - if ((typeof Ctor == 'function' && Ctor.prototype === object) || - (typeof object != 'function' && isArrayLike(object))) { - return shimKeys(object); + function isPlainObject(value) { + if (!isObjectLike(value) || + objectToString.call(value) != objectTag || isHostObject(value)) { + return false; } - return isObject(object) ? nativeKeys(object) : []; - }; + var proto = getPrototypeOf(value); + if (proto === null) { + return true; + } + var Ctor = proto.constructor; + return (typeof Ctor == 'function' && + Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString); + } - module.exports = keys; + module.e = isPlainObject; /***/ }, -/* 53 */ +/* 141 */ /***/ function(module, exports, __webpack_require__) { - var isArguments = __webpack_require__(31), - isArray = __webpack_require__(37), - isIndex = __webpack_require__(48), - isLength = __webpack_require__(35), - keysIn = __webpack_require__(47); + var isArray = __webpack_require__(4), + isObjectLike = __webpack_require__(7); - /** Used for native method references. */ + /** `Object#toString` result references. */ + var stringTag = '[object String]'; + + /** 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/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; /** - * A fallback implementation of `Object.keys` which creates an array of the - * own enumerable property names of `object`. + * Checks if `value` is classified as a `String` primitive or object. * - * @private - * @param {Object} object The object to query. - * @returns {Array} Returns the array of property names. + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. + * @example + * + * _.isString('abc'); + * // => true + * + * _.isString(1); + * // => false */ - function shimKeys(object) { - var props = keysIn(object), - propsLength = props.length, - length = propsLength && object.length; - - var allowIndexes = !!length && isLength(length) && - (isArray(object) || isArguments(object)); - - var index = -1, - result = []; - - while (++index < propsLength) { - var key = props[index]; - if ((allowIndexes && isIndex(key, length)) || hasOwnProperty.call(object, key)) { - result.push(key); - } - } - return result; + function isString(value) { + return typeof value == 'string' || + (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag); } - module.exports = shimKeys; + module.e = isString; /***/ }, -/* 54 */ +/* 142 */ /***/ function(module, exports, __webpack_require__) { - var bindCallback = __webpack_require__(55), - isIterateeCall = __webpack_require__(57), - restParam = __webpack_require__(58); + var baseFlatten = __webpack_require__(92), + basePick = __webpack_require__(100), + rest = __webpack_require__(47); /** - * Creates a `_.assign`, `_.defaults`, or `_.merge` function. + * Creates an object composed of the picked `object` properties. * - * @private - * @param {Function} assigner The function to assign values. - * @returns {Function} Returns the new assigner function. + * @static + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [props] The property names to pick, specified + * individually or in arrays. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.pick(object, ['a', 'c']); + * // => { 'a': 1, 'c': 3 } */ - function createAssigner(assigner) { - return restParam(function(object, sources) { - var index = -1, - length = object == null ? 0 : sources.length, - customizer = length > 2 ? sources[length - 2] : undefined, - guard = length > 2 ? sources[2] : undefined, - thisArg = length > 1 ? sources[length - 1] : undefined; - - if (typeof customizer == 'function') { - customizer = bindCallback(customizer, thisArg, 5); - length -= 2; - } else { - customizer = typeof thisArg == 'function' ? thisArg : undefined; - length -= (customizer ? 1 : 0); - } - if (guard && isIterateeCall(sources[0], sources[1], guard)) { - customizer = length < 3 ? undefined : customizer; - length = 1; - } - while (++index < length) { - var source = sources[index]; - if (source) { - assigner(object, source, customizer); - } - } - return object; - }); - } + var pick = rest(function(object, props) { + return object == null ? {} : basePick(object, baseFlatten(props, 1)); + }); - module.exports = createAssigner; + module.e = pick; /***/ }, -/* 55 */ +/* 143 */ /***/ function(module, exports, __webpack_require__) { - var identity = __webpack_require__(56); + var toNumber = __webpack_require__(144); - /** - * A specialized version of `baseCallback` which only supports `this` binding - * and specifying the number of arguments to provide to `func`. - * - * @private - * @param {Function} func The function to bind. - * @param {*} thisArg The `this` binding of `func`. - * @param {number} [argCount] The number of arguments to provide to `func`. - * @returns {Function} Returns the callback. - */ - function bindCallback(func, thisArg, argCount) { - if (typeof func != 'function') { - return identity; - } - if (thisArg === undefined) { - return func; - } - switch (argCount) { - case 1: return function(value) { - return func.call(thisArg, value); - }; - case 3: return function(value, index, collection) { - return func.call(thisArg, value, index, collection); - }; - case 4: return function(accumulator, value, index, collection) { - return func.call(thisArg, accumulator, value, index, collection); - }; - case 5: return function(value, other, key, object, source) { - return func.call(thisArg, value, other, key, object, source); - }; - } - return function() { - return func.apply(thisArg, arguments); - }; - } + /** Used as references for various `Number` constants. */ + var INFINITY = 1 / 0, + MAX_INTEGER = 1.7976931348623157e+308; - module.exports = bindCallback; - - -/***/ }, -/* 56 */ -/***/ function(module, exports) { - /** - * This method returns the first argument provided to it. + * Converts `value` to an integer. + * + * **Note:** This function is loosely based on [`ToInteger`](http://www.ecma-international.org/ecma-262/6.0/#sec-tointeger). * * @static * @memberOf _ - * @category Utility - * @param {*} value Any value. - * @returns {*} Returns `value`. + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. * @example * - * var object = { 'user': 'fred' }; + * _.toInteger(3); + * // => 3 * - * _.identity(object) === object; - * // => true + * _.toInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toInteger(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toInteger('3'); + * // => 3 */ - function identity(value) { - return value; + function toInteger(value) { + if (!value) { + return value === 0 ? value : 0; + } + value = toNumber(value); + if (value === INFINITY || value === -INFINITY) { + var sign = (value < 0 ? -1 : 1); + return sign * MAX_INTEGER; + } + var remainder = value % 1; + return value === value ? (remainder ? value - remainder : value) : 0; } - module.exports = identity; + module.e = toInteger; /***/ }, -/* 57 */ +/* 144 */ /***/ function(module, exports, __webpack_require__) { - var isArrayLike = __webpack_require__(32), - isIndex = __webpack_require__(48), - isObject = __webpack_require__(41); + var isFunction = __webpack_require__(16), + isObject = __webpack_require__(2); + + /** Used as references for various `Number` constants. */ + var NAN = 0 / 0; + + /** Used to match leading and trailing whitespace. */ + var reTrim = /^\s+|\s+$/g; + + /** Used to detect bad signed hexadecimal string values. */ + var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + + /** Used to detect binary string values. */ + var reIsBinary = /^0b[01]+$/i; + + /** Used to detect octal string values. */ + var reIsOctal = /^0o[0-7]+$/i; + + /** Built-in method references without a dependency on `root`. */ + var freeParseInt = parseInt; /** - * Checks if the provided arguments are from an iteratee call. + * Converts `value` to a number. + * + * @static + * @memberOf _ + * @category Lang + * @param {*} value The value to process. + * @returns {number} Returns the number. + * @example * - * @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`. + * _.toNumber(3); + * // => 3 + * + * _.toNumber(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toNumber(Infinity); + * // => Infinity + * + * _.toNumber('3'); + * // => 3 */ - function isIterateeCall(value, index, object) { - if (!isObject(object)) { - return false; + function toNumber(value) { + if (isObject(value)) { + var other = isFunction(value.valueOf) ? value.valueOf() : value; + value = isObject(other) ? (other + '') : other; } - var type = typeof index; - if (type == 'number' - ? (isArrayLike(object) && isIndex(index, object.length)) - : (type == 'string' && index in object)) { - var other = object[index]; - return value === value ? (value === other) : (other !== other); + if (typeof value != 'string') { + return value === 0 ? value : +value; } - return false; + value = value.replace(reTrim, ''); + var isBinary = reIsBinary.test(value); + return (isBinary || reIsOctal.test(value)) + ? freeParseInt(value.slice(2), isBinary ? 2 : 8) + : (reIsBadHex.test(value) ? NAN : +value); } - module.exports = isIterateeCall; + module.e = toNumber; /***/ }, -/* 58 */ -/***/ function(module, exports) { +/* 145 */ +/***/ function(module, exports, __webpack_require__) { - /** Used as the `TypeError` message for "Functions" methods. */ - var FUNC_ERROR_TEXT = 'Expected a function'; - - /* Native method references for those with the same name as other `lodash` methods. */ - var nativeMax = Math.max; + var copyObject = __webpack_require__(20), + keysIn = __webpack_require__(46); /** - * Creates a function that invokes `func` with the `this` binding of the - * created function and arguments from `start` and beyond provided as an array. - * - * **Note:** This method is based on the [rest parameter](https://developer.mozilla.org/Web/JavaScript/Reference/Functions/rest_parameters). + * Converts `value` to a plain object flattening inherited enumerable + * properties of `value` to own properties of the plain object. * * @static * @memberOf _ - * @category Function - * @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. + * @category Lang + * @param {*} value The value to convert. + * @returns {Object} Returns the converted plain object. * @example * - * var say = _.restParam(function(what, names) { - * return what + ' ' + _.initial(names).join(', ') + - * (_.size(names) > 1 ? ', & ' : '') + _.last(names); - * }); + * function Foo() { + * this.b = 2; + * } * - * say('hello', 'fred', 'barney', 'pebbles'); - * // => 'hello fred, barney, & pebbles' + * 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 restParam(func, start) { - if (typeof func != 'function') { - throw new TypeError(FUNC_ERROR_TEXT); - } - start = nativeMax(start === undefined ? (func.length - 1) : (+start || 0), 0); - return function() { - var args = arguments, - index = -1, - length = nativeMax(args.length - start, 0), - rest = Array(length); - - while (++index < length) { - rest[index] = args[start + index]; - } - switch (start) { - case 0: return func.call(this, rest); - case 1: return func.call(this, args[0], rest); - case 2: return func.call(this, args[0], args[1], rest); - } - var otherArgs = Array(start + 1); - index = -1; - while (++index < start) { - otherArgs[index] = args[index]; - } - otherArgs[start] = rest; - return func.apply(this, otherArgs); - }; + function toPlainObject(value) { + return copyObject(value, keysIn(value)); } - module.exports = restParam; + module.e = toPlainObject; /***/ }, -/* 59 */ -/***/ function(module, exports) { +/* 146 */ +/***/ function(module, exports, __webpack_require__) { - "use strict"; + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ + 'use strict'; - Object.defineProperty(exports, "__esModule", { - value: true - }); + // Shimming starts here. + (function() { + // Utils. + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; + // Export to the adapter global object visible in the browser. + module.e.browserDetails = browserDetails; + module.e.extractVersion = __webpack_require__(0).extractVersion; + module.e.disableLog = __webpack_require__(0).disableLog; + + // Uncomment if you do not want any logging at all including the switch + // statement below. Can also be turned off in the browser via + // adapter.disableLog(true) but then logging from the switch statement below + // will still appear. + //require('./utils').disableLog(true); + + // Browser shims. + var chromeShim = __webpack_require__(147) || null; + var edgeShim = __webpack_require__(150) || null; + var firefoxShim = __webpack_require__(151) || null; + + // Shim browser if found. + switch (browserDetails.browser) { + case 'chrome': + if (!chromeShim || !chromeShim.shimPeerConnection) { + logging('Chrome shim is not included in this adapter release.'); + return; + } + logging('adapter.js shimming chrome!'); + // Export to the adapter global object visible in the browser. + module.e.browserShim = chromeShim; + + chromeShim.shimGetUserMedia(); + chromeShim.shimSourceObject(); + chromeShim.shimPeerConnection(); + chromeShim.shimOnTrack(); + break; + case 'edge': + if (!edgeShim || !edgeShim.shimPeerConnection) { + logging('MS edge shim is not included in this adapter release.'); + return; + } + logging('adapter.js shimming edge!'); + // Export to the adapter global object visible in the browser. + module.e.browserShim = edgeShim; - exports["default"] = (function () { - var events = {}; + edgeShim.shimPeerConnection(); + break; + case 'firefox': + if (!firefoxShim || !firefoxShim.shimPeerConnection) { + logging('Firefox shim is not included in this adapter release.'); + return; + } + logging('adapter.js shimming firefox!'); + // Export to the adapter global object visible in the browser. + module.e.browserShim = firefoxShim; + + firefoxShim.shimGetUserMedia(); + firefoxShim.shimSourceObject(); + firefoxShim.shimPeerConnection(); + firefoxShim.shimOnTrack(); + break; + default: + logging('Unsupported browser!'); + } + })(); + + +/***/ }, +/* 147 */ +/***/ function(module, exports, __webpack_require__) { + + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ + 'use strict'; + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; + + var chromeShim = { + shimOnTrack: function() { + if (typeof window === 'object' && window.RTCPeerConnection && !('ontrack' in + window.RTCPeerConnection.prototype)) { + Object.defineProperty(window.RTCPeerConnection.prototype, 'ontrack', { + get: function() { return this._ontrack; }, + set: function(f) { + var self = this; + if (this._ontrack) { + this.removeEventListener('track', this._ontrack); + this.removeEventListener('addstream', this._ontrackpoly); + } + this.addEventListener('track', this._ontrack = f); + this.addEventListener('addstream', this._ontrackpoly = function(e) { + // onaddstream does not fire when a track is added to an existing stream. + // but stream.onaddtrack is implemented so we use that + e.stream.addEventListener('addtrack', function(te) { + var event = new Event('track'); + event.track = te.track; + event.receiver = {track: te.track}; + event.streams = [e.stream]; + self.dispatchEvent(event); + }); + e.stream.getTracks().forEach(function(track) { + var event = new Event('track'); + event.track = track; + event.receiver = {track: track}; + event.streams = [e.stream]; + this.dispatchEvent(event); + }.bind(this)); + }.bind(this)); + } + }); + } + }, + + shimSourceObject: function() { + if (typeof window === 'object') { + if (window.HTMLMediaElement && + !('srcObject' in window.HTMLMediaElement.prototype)) { + // Shim the srcObject property, once, when HTMLMediaElement is found. + Object.defineProperty(window.HTMLMediaElement.prototype, 'srcObject', { + get: function() { + return this._srcObject; + }, + set: function(stream) { + var self = this; + // Use _srcObject as a private property for this shim + this._srcObject = stream; + if (this.src) { + URL.revokeObjectURL(this.src); + } - function getEvent(eventName) { - if (!events[eventName]) { - events[eventName] = { - subscribers: [] - }; - } - return events[eventName]; + if (!stream) { + this.src = ''; + return; + } + this.src = URL.createObjectURL(stream); + // We need to recreate the blob url when a track is added or removed. + // Doing it manually since we want to avoid a recursion. + stream.addEventListener('addtrack', function() { + if (self.src) { + URL.revokeObjectURL(self.src); + } + self.src = URL.createObjectURL(stream); + }); + stream.addEventListener('removetrack', function() { + if (self.src) { + URL.revokeObjectURL(self.src); + } + self.src = URL.createObjectURL(stream); + }); + } + }); + } } + }, - function clearEvents() { - events = {}; - } + shimPeerConnection: function() { + // The RTCPeerConnection object. + window.RTCPeerConnection = function(pcConfig, pcConstraints) { + // Translate iceTransportPolicy to iceTransports, + // see https://code.google.com/p/webrtc/issues/detail?id=4869 + logging('PeerConnection'); + if (pcConfig && pcConfig.iceTransportPolicy) { + pcConfig.iceTransports = pcConfig.iceTransportPolicy; + } - function publishSubscription(subscription, data) { - if (subscription.async) { - setTimeout(function () { - subscription.callback(data); - }, 4); - } else { - subscription.callback(data); + var pc = new webkitRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors + var origGetStats = pc.getStats.bind(pc); + pc.getStats = function(selector, successCallback, errorCallback) { // jshint ignore: line + var self = this; + var args = arguments; + + // If selector is a function then we are in the old style stats so just + // pass back the original getStats format to avoid breaking old users. + if (arguments.length > 0 && typeof selector === 'function') { + return origGetStats(selector, successCallback); + } + + var fixChromeStats_ = function(response) { + var standardReport = {}; + var reports = response.result(); + reports.forEach(function(report) { + var standardStats = { + id: report.id, + timestamp: report.timestamp, + type: report.type + }; + report.names().forEach(function(name) { + standardStats[name] = report.stat(name); + }); + standardReport[standardStats.id] = standardStats; + }); + + return standardReport; + }; + + if (arguments.length >= 2) { + var successCallbackWrapper_ = function(response) { + args[1](fixChromeStats_(response)); + }; + + return origGetStats.apply(this, [successCallbackWrapper_, arguments[0]]); } - } - function _subscribe(event, callback, async) { - var subscription; + // promise-support + return new Promise(function(resolve, reject) { + if (args.length === 1 && selector === null) { + origGetStats.apply(self, [ + function(response) { + resolve.apply(null, [fixChromeStats_(response)]); + }, reject]); + } else { + origGetStats.apply(self, [resolve, reject]); + } + }); + }; - if (typeof callback === "function") { - subscription = { - callback: callback, - async: async - }; + return pc; + }; + window.RTCPeerConnection.prototype = webkitRTCPeerConnection.prototype; + + // wrap static methods. Currently just generateCertificate. + if (webkitRTCPeerConnection.generateCertificate) { + Object.defineProperty(window.RTCPeerConnection, 'generateCertificate', { + get: function() { + if (arguments.length) { + return webkitRTCPeerConnection.generateCertificate.apply(null, + arguments); + } else { + return webkitRTCPeerConnection.generateCertificate; + } + } + }); + } + + // add promise support + ['createOffer', 'createAnswer'].forEach(function(method) { + var nativeMethod = webkitRTCPeerConnection.prototype[method]; + webkitRTCPeerConnection.prototype[method] = function() { + var self = this; + if (arguments.length < 1 || (arguments.length === 1 && + typeof(arguments[0]) === 'object')) { + var opts = arguments.length === 1 ? arguments[0] : undefined; + return new Promise(function(resolve, reject) { + nativeMethod.apply(self, [resolve, reject, opts]); + }); } else { - subscription = callback; - if (!subscription.callback) { - throw "Callback was not specified on options"; - } + return nativeMethod.apply(this, arguments); } + }; + }); - getEvent(event).subscribers.push(subscription); + ['setLocalDescription', 'setRemoteDescription', + 'addIceCandidate'].forEach(function(method) { + var nativeMethod = webkitRTCPeerConnection.prototype[method]; + webkitRTCPeerConnection.prototype[method] = function() { + var args = arguments; + var self = this; + return new Promise(function(resolve, reject) { + nativeMethod.apply(self, [args[0], + function() { + resolve(); + if (args.length >= 2) { + args[1].apply(null, []); + } + }, + function(err) { + reject(err); + if (args.length >= 3) { + args[2].apply(null, [err]); + } + }] + ); + }); + }; + }); + }, + + // Attach a media stream to an element. + attachMediaStream: function(element, stream) { + logging('DEPRECATED, attachMediaStream will soon be removed.'); + if (browserDetails.version >= 43) { + element.srcObject = stream; + } else if (typeof element.src !== 'undefined') { + element.src = URL.createObjectURL(stream); + } else { + logging('Error attaching stream to element.'); } + }, - return { - subscribe: function subscribe(event, callback, async) { - return _subscribe(event, callback, async); - }, - publish: function publish(eventName, data) { - var event = getEvent(eventName), - subscribers = event.subscribers; - - event.subscribers = subscribers.filter(function (subscriber) { - publishSubscription(subscriber, data); - return !subscriber.once; - }); - }, - once: function once(event, callback, async) { - _subscribe(event, { - callback: callback, - async: async, - once: true - }); - }, - unsubscribe: function unsubscribe(eventName, callback) { - var event; + reattachMediaStream: function(to, from) { + logging('DEPRECATED, reattachMediaStream will soon be removed.'); + if (browserDetails.version >= 43) { + to.srcObject = from.srcObject; + } else { + to.src = from.src; + } + } + } - if (eventName) { - event = getEvent(eventName); - if (event && callback) { - event.subscribers = event.subscribers.filter(function (subscriber) { - return subscriber.callback !== callback; - }); - } else { - event.subscribers = []; - } - } else { - clearEvents(); - } - } - }; - })(); - module.exports = exports["default"]; + // Expose public methods. + module.e = { + shimOnTrack: chromeShim.shimOnTrack, + shimSourceObject: chromeShim.shimSourceObject, + shimPeerConnection: chromeShim.shimPeerConnection, + shimGetUserMedia: __webpack_require__(148), + attachMediaStream: chromeShim.attachMediaStream, + reattachMediaStream: chromeShim.reattachMediaStream + }; + /***/ }, -/* 60 */ +/* 148 */ /***/ function(module, exports, __webpack_require__) { + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ 'use strict'; + var logging = __webpack_require__(0).log; - Object.defineProperty(exports, '__esModule', { - value: true - }); - var merge = __webpack_require__(26); - - var streamRef, loadedDataHandler; - - /** - * Wraps browser-specific getUserMedia - * @param {Object} constraints - * @param {Object} success Callback - * @param {Object} failure Callback - */ - function getUserMedia(constraints, success, failure) { - if (typeof navigator.getUserMedia !== 'undefined') { - navigator.getUserMedia(constraints, function (stream) { - streamRef = stream; - var videoSrc = window.URL && window.URL.createObjectURL(stream) || stream; - success.apply(null, [videoSrc]); - }, failure); - } else { - failure(new TypeError("getUserMedia not available")); + // Expose public methods. + module.e = function() { + var constraintsToChrome_ = function(c) { + if (typeof c !== 'object' || c.mandatory || c.optional) { + return c; } - } - - function loadedData(video, callback) { - var attempts = 10; - - function checkVideo() { - if (attempts > 0) { - if (video.videoWidth > 0 && video.videoHeight > 0) { - if (false) { - console.log(video.videoWidth + "px x " + video.videoHeight + "px"); - } - callback(); - } else { - window.setTimeout(checkVideo, 500); - } + var cc = {}; + Object.keys(c).forEach(function(key) { + if (key === 'require' || key === 'advanced' || key === 'mediaSource') { + return; + } + var r = (typeof c[key] === 'object') ? c[key] : {ideal: c[key]}; + if (r.exact !== undefined && typeof r.exact === 'number') { + r.min = r.max = r.exact; + } + var oldname_ = function(prefix, name) { + if (prefix) { + return prefix + name.charAt(0).toUpperCase() + name.slice(1); + } + return (name === 'deviceId') ? 'sourceId' : name; + }; + if (r.ideal !== undefined) { + cc.optional = cc.optional || []; + var oc = {}; + if (typeof r.ideal === 'number') { + oc[oldname_('min', key)] = r.ideal; + cc.optional.push(oc); + oc = {}; + oc[oldname_('max', key)] = r.ideal; + cc.optional.push(oc); } else { - callback('Unable to play video stream. Is webcam working?'); + oc[oldname_('', key)] = r.ideal; + cc.optional.push(oc); } - attempts--; + } + if (r.exact !== undefined && typeof r.exact !== 'number') { + cc.mandatory = cc.mandatory || {}; + cc.mandatory[oldname_('', key)] = r.exact; + } else { + ['min', 'max'].forEach(function(mix) { + if (r[mix] !== undefined) { + cc.mandatory = cc.mandatory || {}; + cc.mandatory[oldname_(mix, key)] = r[mix]; + } + }); + } + }); + if (c.advanced) { + cc.optional = (cc.optional || []).concat(c.advanced); } - checkVideo(); - } + return cc; + }; - /** - * 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 - * @param {Object} callback - */ - function initCamera(constraints, video, callback) { - getUserMedia(constraints, function (src) { - video.src = src; - if (loadedDataHandler) { - video.removeEventListener("loadeddata", loadedDataHandler, false); - } - loadedDataHandler = loadedData.bind(null, video, callback); - video.addEventListener('loadeddata', loadedDataHandler, false); - video.play(); - }, function (e) { - callback(e); - }); - } + var getUserMedia_ = function(constraints, onSuccess, onError) { + if (constraints.audio) { + constraints.audio = constraintsToChrome_(constraints.audio); + } + if (constraints.video) { + constraints.video = constraintsToChrome_(constraints.video); + } + logging('chrome: ' + JSON.stringify(constraints)); + return navigator.webkitGetUserMedia(constraints, onSuccess, onError); + }; + navigator.getUserMedia = getUserMedia_; - /** - * Normalizes the incoming constraints to satisfy the current browser - * @param config - * @param cb Callback which is called whenever constraints are created - * @returns {*} - */ - function normalizeConstraints(config, cb) { - var constraints = { - audio: false, - video: true - }, - videoConstraints = merge({ - width: 640, - height: 480, - minAspectRatio: 0, - maxAspectRatio: 100, - facing: "environment" - }, config); + // Returns the result of getUserMedia as a Promise. + var getUserMediaPromise_ = function(constraints) { + return new Promise(function(resolve, reject) { + navigator.getUserMedia(constraints, resolve, reject); + }); + } - if (typeof MediaStreamTrack !== 'undefined' && typeof MediaStreamTrack.getSources !== 'undefined') { - MediaStreamTrack.getSources(function (sourceInfos) { - var videoSourceId; - for (var i = 0; i < sourceInfos.length; ++i) { - var sourceInfo = sourceInfos[i]; - if (sourceInfo.kind === "video" && sourceInfo.facing === videoConstraints.facing) { - videoSourceId = sourceInfo.id; - } - } - constraints.video = { - mandatory: { - minWidth: videoConstraints.width, - minHeight: videoConstraints.height, - minAspectRatio: videoConstraints.minAspectRatio, - maxAspectRatio: videoConstraints.maxAspectRatio - }, - optional: [{ - sourceId: videoSourceId - }] - }; - return cb(constraints); + if (!navigator.mediaDevices) { + navigator.mediaDevices = {getUserMedia: getUserMediaPromise_, + enumerateDevices: function() { + return new Promise(function(resolve) { + var kinds = {audio: 'audioinput', video: 'videoinput'}; + return MediaStreamTrack.getSources(function(devices) { + resolve(devices.map(function(device) { + return {label: device.label, + kind: kinds[device.kind], + deviceId: device.id, + groupId: ''}; + })); }); - } else { - constraints.video = { - mediaSource: "camera", - width: { min: videoConstraints.width, max: videoConstraints.width }, - height: { min: videoConstraints.height, max: videoConstraints.height }, - require: ["width", "height"] - }; - return cb(constraints); - } - } + }); + }}; + } - /** - * Requests the back-facing camera of the user. The callback is called - * whenever the stream is ready to be consumed, or if an error occures. - * @param {Object} video - * @param {Object} callback - */ - function _request(video, videoConstraints, callback) { - normalizeConstraints(videoConstraints, function (constraints) { - initCamera(constraints, video, callback); - }); - } + // A shim for getUserMedia method on the mediaDevices object. + // TODO(KaptenJansson) remove once implemented in Chrome stable. + if (!navigator.mediaDevices.getUserMedia) { + navigator.mediaDevices.getUserMedia = function(constraints) { + return getUserMediaPromise_(constraints); + }; + } else { + // Even though Chrome 45 has navigator.mediaDevices and a getUserMedia + // function which returns a Promise, it does not accept spec-style + // constraints. + var origGetUserMedia = navigator.mediaDevices.getUserMedia. + bind(navigator.mediaDevices); + navigator.mediaDevices.getUserMedia = function(c) { + if (c) { + logging('spec: ' + JSON.stringify(c)); // whitespace for alignment + c.audio = constraintsToChrome_(c.audio); + c.video = constraintsToChrome_(c.video); + logging('chrome: ' + JSON.stringify(c)); + } + return origGetUserMedia(c); + }.bind(this); + } - exports['default'] = { - request: function request(video, constraints, callback) { - _request(video, constraints, callback); - }, - release: function release() { - var tracks = streamRef && streamRef.getVideoTracks(); - if (tracks && tracks.length) { - tracks[0].stop(); - } - streamRef = null; - } + // Dummy devicechange event methods. + // TODO(KaptenJansson) remove once implemented in Chrome stable. + if (typeof navigator.mediaDevices.addEventListener === 'undefined') { + navigator.mediaDevices.addEventListener = function() { + logging('Dummy mediaDevices.addEventListener called.'); + }; + } + if (typeof navigator.mediaDevices.removeEventListener === 'undefined') { + navigator.mediaDevices.removeEventListener = function() { + logging('Dummy mediaDevices.removeEventListener called.'); + }; + } }; - module.exports = exports['default']; + /***/ }, -/* 61 */ +/* 149 */ /***/ function(module, exports, __webpack_require__) { + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ 'use strict'; - Object.defineProperty(exports, '__esModule', { - value: true - }); + // SDP helpers. + var SDPUtils = {}; - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + // Generate an alphanumeric identifier for cname or mids. + // TODO: use UUIDs instead? https://gist.github.com/jed/982883 + SDPUtils.generateIdentifier = function() { + return Math.random().toString(36).substr(2, 10); + }; - var _commonImage_debug = __webpack_require__(10); + // The RTCP CNAME used by all peerconnections from the same JS. + SDPUtils.localCName = SDPUtils.generateIdentifier(); - var _commonImage_debug2 = _interopRequireDefault(_commonImage_debug); - 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; - } + // Splits SDP into lines, dealing with both CRLF and LF. + SDPUtils.splitLines = function(blob) { + return blob.trim().split('\n').map(function(line) { + return line.trim(); + }); + }; + // Splits SDP into sessionpart and mediasections. Ensures CRLF. + SDPUtils.splitSections = function(blob) { + var parts = blob.split('\r\nm='); + return parts.map(function(part, index) { + return (index > 0 ? 'm=' + part : part).trim() + '\r\n'; + }); + }; - function passesFilter(codeResult, filter) { - if (typeof filter === 'function') { - return filter(codeResult); + // Returns lines that start with a certain prefix. + SDPUtils.matchPrefix = function(blob, prefix) { + return SDPUtils.splitLines(blob).filter(function(line) { + return line.indexOf(prefix) === 0; + }); + }; + + // Parses an ICE candidate line. Sample input: + // candidate:702786350 2 udp 41819902 8.8.8.8 60769 typ relay raddr 8.8.8.8 rport 55996" + SDPUtils.parseCandidate = function(line) { + var parts; + // Parse both variants. + if (line.indexOf('a=candidate:') === 0) { + parts = line.substring(12).split(' '); + } else { + parts = line.substring(10).split(' '); + } + + var candidate = { + foundation: parts[0], + component: parts[1], + protocol: parts[2].toLowerCase(), + priority: parseInt(parts[3], 10), + ip: parts[4], + port: parseInt(parts[5], 10), + // skip parts[6] == 'typ' + type: parts[7] + }; + + for (var i = 8; i < parts.length; i += 2) { + switch (parts[i]) { + case 'raddr': + candidate.relatedAddress = parts[i + 1]; + break; + case 'rport': + candidate.relatedPort = parseInt(parts[i + 1], 10); + break; + case 'tcptype': + candidate.tcpType = parts[i + 1]; + break; + default: // Unknown extensions are silently ignored. + break; } - return true; - } + } + return candidate; + }; + + // Translates a candidate object into SDP candidate attribute. + SDPUtils.writeCandidate = function(candidate) { + var sdp = []; + sdp.push(candidate.foundation); + sdp.push(candidate.component); + sdp.push(candidate.protocol.toUpperCase()); + sdp.push(candidate.priority); + sdp.push(candidate.ip); + sdp.push(candidate.port); + + var type = candidate.type; + sdp.push('typ'); + sdp.push(type); + if (type !== 'host' && candidate.relatedAddress && + candidate.relatedPort) { + sdp.push('raddr'); + sdp.push(candidate.relatedAddress); // was: relAddr + sdp.push('rport'); + sdp.push(candidate.relatedPort); // was: relPort + } + if (candidate.tcpType && candidate.protocol.toLowerCase() === 'tcp') { + sdp.push('tcptype'); + sdp.push(candidate.tcpType); + } + return 'candidate:' + sdp.join(' '); + }; - exports['default'] = { - create: function create(config) { - var canvas = document.createElement("canvas"), - ctx = canvas.getContext("2d"), - results = [], - capacity = config.capacity || 20, - capture = config.capture === true; + // Parses an rtpmap line, returns RTCRtpCoddecParameters. Sample input: + // a=rtpmap:111 opus/48000/2 + SDPUtils.parseRtpMap = function(line) { + var parts = line.substr(9).split(' '); + var parsed = { + payloadType: parseInt(parts.shift(), 10) // was: id + }; - function matchesConstraints(codeResult) { - return capacity && codeResult && !contains(codeResult, config.blacklist) && passesFilter(codeResult, config.filter); - } + parts = parts[0].split('/'); - return { - addResult: function addResult(data, imageSize, codeResult) { - var result = {}; + parsed.name = parts[0]; + parsed.clockRate = parseInt(parts[1], 10); // was: clockrate + parsed.numChannels = parts.length === 3 ? parseInt(parts[2], 10) : 1; // was: channels + return parsed; + }; - if (matchesConstraints(codeResult)) { - capacity--; - result.codeResult = codeResult; - if (capture) { - canvas.width = imageSize.x; - canvas.height = imageSize.y; - _commonImage_debug2['default'].drawImage(data, imageSize, ctx); - result.frame = canvas.toDataURL(); - } - results.push(result); - } - }, - getResults: function getResults() { - return results; - } - }; + // Generate an a=rtpmap line from RTCRtpCodecCapability or RTCRtpCodecParameters. + SDPUtils.writeRtpMap = function(codec) { + var pt = codec.payloadType; + if (codec.preferredPayloadType !== undefined) { + pt = codec.preferredPayloadType; + } + return 'a=rtpmap:' + pt + ' ' + codec.name + '/' + codec.clockRate + + (codec.numChannels !== 1 ? '/' + codec.numChannels : '') + '\r\n'; + }; + + // Parses an ftmp line, returns dictionary. Sample input: + // a=fmtp:96 vbr=on;cng=on + // Also deals with vbr=on; cng=on + SDPUtils.parseFmtp = function(line) { + var parsed = {}; + var kv; + var parts = line.substr(line.indexOf(' ') + 1).split(';'); + for (var j = 0; j < parts.length; j++) { + kv = parts[j].trim().split('='); + parsed[kv[0].trim()] = kv[1]; + } + return parsed; + }; + + // Generates an a=ftmp line from RTCRtpCodecCapability or RTCRtpCodecParameters. + SDPUtils.writeFtmp = function(codec) { + var line = ''; + var pt = codec.payloadType; + if (codec.preferredPayloadType !== undefined) { + pt = codec.preferredPayloadType; + } + if (codec.parameters && codec.parameters.length) { + var params = []; + Object.keys(codec.parameters).forEach(function(param) { + params.push(param + '=' + codec.parameters[param]); + }); + line += 'a=fmtp:' + pt + ' ' + params.join(';') + '\r\n'; + } + return line; + }; + + // Parses an rtcp-fb line, returns RTCPRtcpFeedback object. Sample input: + // a=rtcp-fb:98 nack rpsi + SDPUtils.parseRtcpFb = function(line) { + var parts = line.substr(line.indexOf(' ') + 1).split(' '); + return { + type: parts.shift(), + parameter: parts.join(' ') + }; + }; + // Generate a=rtcp-fb lines from RTCRtpCodecCapability or RTCRtpCodecParameters. + SDPUtils.writeRtcpFb = function(codec) { + var lines = ''; + var pt = codec.payloadType; + if (codec.preferredPayloadType !== undefined) { + pt = codec.preferredPayloadType; + } + if (codec.rtcpFeedback && codec.rtcpFeedback.length) { + // FIXME: special handling for trr-int? + codec.rtcpFeedback.forEach(function(fb) { + lines += 'a=rtcp-fb:' + pt + ' ' + fb.type + ' ' + fb.parameter + + '\r\n'; + }); + } + return lines; + }; + + // Parses an RFC 5576 ssrc media attribute. Sample input: + // a=ssrc:3735928559 cname:something + SDPUtils.parseSsrcMedia = function(line) { + var sp = line.indexOf(' '); + var parts = { + ssrc: line.substr(7, sp - 7), + }; + var colon = line.indexOf(':', sp); + if (colon > -1) { + parts.attribute = line.substr(sp + 1, colon - sp - 1); + parts.value = line.substr(colon + 1); + } else { + parts.attribute = line.substr(sp + 1); + } + return parts; + }; + + // Extracts DTLS parameters from SDP media section or sessionpart. + // FIXME: for consistency with other functions this should only + // get the fingerprint line as input. See also getIceParameters. + SDPUtils.getDtlsParameters = function(mediaSection, sessionpart) { + var lines = SDPUtils.splitLines(mediaSection); + lines = lines.concat(SDPUtils.splitLines(sessionpart)); // Search in session part, too. + var fpLine = lines.filter(function(line) { + return line.indexOf('a=fingerprint:') === 0; + })[0].substr(14); + // Note: a=setup line is ignored since we use the 'auto' role. + var dtlsParameters = { + role: 'auto', + fingerprints: [{ + algorithm: fpLine.split(' ')[0], + value: fpLine.split(' ')[1] + }] + }; + return dtlsParameters; + }; + + // Serializes DTLS parameters to SDP. + SDPUtils.writeDtlsParameters = function(params, setupType) { + var sdp = 'a=setup:' + setupType + '\r\n'; + params.fingerprints.forEach(function(fp) { + sdp += 'a=fingerprint:' + fp.algorithm + ' ' + fp.value + '\r\n'; + }); + return sdp; + }; + // Parses ICE information from SDP media section or sessionpart. + // FIXME: for consistency with other functions this should only + // get the ice-ufrag and ice-pwd lines as input. + SDPUtils.getIceParameters = function(mediaSection, sessionpart) { + var lines = SDPUtils.splitLines(mediaSection); + lines = lines.concat(SDPUtils.splitLines(sessionpart)); // Search in session part, too. + var iceParameters = { + usernameFragment: lines.filter(function(line) { + return line.indexOf('a=ice-ufrag:') === 0; + })[0].substr(12), + password: lines.filter(function(line) { + return line.indexOf('a=ice-pwd:') === 0; + })[0].substr(10) + }; + return iceParameters; + }; + + // Serializes ICE parameters to SDP. + SDPUtils.writeIceParameters = function(params) { + return 'a=ice-ufrag:' + params.usernameFragment + '\r\n' + + 'a=ice-pwd:' + params.password + '\r\n'; + }; + + // Parses the SDP media section and returns RTCRtpParameters. + SDPUtils.parseRtpParameters = function(mediaSection) { + var description = { + codecs: [], + headerExtensions: [], + fecMechanisms: [], + rtcp: [] + }; + var lines = SDPUtils.splitLines(mediaSection); + var mline = lines[0].split(' '); + for (var i = 3; i < mline.length; i++) { // find all codecs from mline[3..] + var pt = mline[i]; + var rtpmapline = SDPUtils.matchPrefix( + mediaSection, 'a=rtpmap:' + pt + ' ')[0]; + if (rtpmapline) { + var codec = SDPUtils.parseRtpMap(rtpmapline); + var fmtps = SDPUtils.matchPrefix( + mediaSection, 'a=fmtp:' + pt + ' '); + // Only the first a=fmtp: is considered. + codec.parameters = fmtps.length ? SDPUtils.parseFmtp(fmtps[0]) : {}; + codec.rtcpFeedback = SDPUtils.matchPrefix( + mediaSection, 'a=rtcp-fb:' + pt + ' ') + .map(SDPUtils.parseRtcpFb); + description.codecs.push(codec); } + } + // FIXME: parse headerExtensions, fecMechanisms and rtcp. + return description; }; - module.exports = exports['default']; - -/***/ }, -/* 62 */ -/***/ function(module, exports, __webpack_require__) { - - 'use strict'; - Object.defineProperty(exports, '__esModule', { - value: true - }); - var config = undefined; + // Generates parts of the SDP media section describing the capabilities / parameters. + SDPUtils.writeRtpDescription = function(kind, caps) { + var sdp = ''; - if (false) { - config = require('./config.dev.js'); - } else if (true) { - config = __webpack_require__(63); - } else { - config = require('./config.prod.js'); - } + // Build the mline. + sdp += 'm=' + kind + ' '; + sdp += caps.codecs.length > 0 ? '9' : '0'; // reject if no codecs. + sdp += ' UDP/TLS/RTP/SAVPF '; + sdp += caps.codecs.map(function(codec) { + if (codec.preferredPayloadType !== undefined) { + return codec.preferredPayloadType; + } + return codec.payloadType; + }).join(' ') + '\r\n'; - exports['default'] = config; - module.exports = exports['default']; - -/***/ }, -/* 63 */ -/***/ function(module, exports) { - - "use strict"; + sdp += 'c=IN IP4 0.0.0.0\r\n'; + sdp += 'a=rtcp:9 IN IP4 0.0.0.0\r\n'; - 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 + // Add a=rtpmap lines for each codec. Also fmtp and rtcp-fb. + caps.codecs.forEach(function(codec) { + sdp += SDPUtils.writeRtpMap(codec); + sdp += SDPUtils.writeFtmp(codec); + sdp += SDPUtils.writeRtcpFb(codec); + }); + // FIXME: add headerExtensions, fecMechanismş and rtcp. + sdp += 'a=rtcp-mux\r\n'; + return sdp; + }; + + SDPUtils.writeSessionBoilerplate = function() { + // FIXME: sess-id should be an NTP timestamp. + return 'v=0\r\n' + + 'o=thisisadapterortc 8169639915646943137 2 IN IP4 127.0.0.1\r\n' + + 's=-\r\n' + + 't=0 0\r\n'; + }; + + SDPUtils.writeMediaSection = function(transceiver, caps, type, stream) { + var sdp = SDPUtils.writeRtpDescription(transceiver.kind, caps); + + // Map ICE parameters (ufrag, pwd) to SDP. + sdp += SDPUtils.writeIceParameters( + transceiver.iceGatherer.getLocalParameters()); + + // Map DTLS parameters to SDP. + sdp += SDPUtils.writeDtlsParameters( + transceiver.dtlsTransport.getLocalParameters(), + type === 'offer' ? 'actpass' : 'active'); + + sdp += 'a=mid:' + transceiver.mid + '\r\n'; + + if (transceiver.rtpSender && transceiver.rtpReceiver) { + sdp += 'a=sendrecv\r\n'; + } else if (transceiver.rtpSender) { + sdp += 'a=sendonly\r\n'; + } else if (transceiver.rtpReceiver) { + sdp += 'a=recvonly\r\n'; + } else { + sdp += 'a=inactive\r\n'; + } + + // FIXME: for RTX there might be multiple SSRCs. Not implemented in Edge yet. + if (transceiver.rtpSender) { + var msid = 'msid:' + stream.id + ' ' + + transceiver.rtpSender.track.id + '\r\n'; + sdp += 'a=' + msid; + sdp += 'a=ssrc:' + transceiver.sendSsrc + ' ' + msid; + } + // FIXME: this should be written by writeRtpDescription. + sdp += 'a=ssrc:' + transceiver.sendSsrc + ' cname:' + + SDPUtils.localCName + '\r\n'; + return sdp; + }; + + // Gets the direction from the mediaSection or the sessionpart. + SDPUtils.getDirection = function(mediaSection, sessionpart) { + // Look for sendrecv, sendonly, recvonly, inactive, default to sendrecv. + var lines = SDPUtils.splitLines(mediaSection); + for (var i = 0; i < lines.length; i++) { + switch (lines[i]) { + case 'a=sendrecv': + case 'a=sendonly': + case 'a=recvonly': + case 'a=inactive': + return lines[i].substr(2); } + } + if (sessionpart) { + return SDPUtils.getDirection(sessionpart); + } + return 'sendrecv'; }; + + // Expose public methods. + module.e = SDPUtils; + /***/ }, -/* 64 */ +/* 150 */ /***/ function(module, exports, __webpack_require__) { + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ 'use strict'; - var GetPixels = __webpack_require__(65); - - var InputStream = {}; + var SDPUtils = __webpack_require__(149); + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; + + var edgeShim = { + shimPeerConnection: function() { + if (window.RTCIceGatherer) { + // ORTC defines an RTCIceCandidate object but no constructor. + // Not implemented in Edge. + if (!window.RTCIceCandidate) { + window.RTCIceCandidate = function(args) { + return args; + }; + } + // ORTC does not have a session description object but + // other browsers (i.e. Chrome) that will support both PC and ORTC + // in the future might have this defined already. + if (!window.RTCSessionDescription) { + window.RTCSessionDescription = function(args) { + return args; + }; + } + } - InputStream.createImageStream = function () { - var that = {}; - var _config = null; + window.RTCPeerConnection = function(config) { + var self = this; + + var _eventTarget = document.createDocumentFragment(); + ['addEventListener', 'removeEventListener', 'dispatchEvent'].forEach( + function(method) { + self[method] = _eventTarget[method].bind(_eventTarget); + }); + + this.onicecandidate = null; + this.onaddstream = null; + this.ontrack = null; + this.onremovestream = null; + this.onsignalingstatechange = null; + this.oniceconnectionstatechange = null; + this.onnegotiationneeded = null; + this.ondatachannel = null; + + this.localStreams = []; + this.remoteStreams = []; + this.getLocalStreams = function() { return self.localStreams; }; + this.getRemoteStreams = function() { return self.remoteStreams; }; + + this.localDescription = new RTCSessionDescription({ + type: '', + sdp: '' + }); + this.remoteDescription = new RTCSessionDescription({ + type: '', + sdp: '' + }); + this.signalingState = 'stable'; + this.iceConnectionState = 'new'; + this.iceGatheringState = 'new'; + + this.iceOptions = { + gatherPolicy: 'all', + iceServers: [] + }; + if (config && config.iceTransportPolicy) { + switch (config.iceTransportPolicy) { + case 'all': + case 'relay': + this.iceOptions.gatherPolicy = config.iceTransportPolicy; + break; + case 'none': + // FIXME: remove once implementation and spec have added this. + throw new TypeError('iceTransportPolicy "none" not supported'); + } + } + if (config && config.iceServers) { + // Edge does not like + // 1) stun: + // 2) turn: that does not have all of turn:host:port?transport=udp + this.iceOptions.iceServers = config.iceServers.filter(function(server) { + if (server && server.urls) { + server.urls = server.urls.filter(function(url) { + return url.indexOf('transport=udp') !== -1; + })[0]; + return true; + } + return false; + }); + } - 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 }; + // per-track iceGathers, iceTransports, dtlsTransports, rtpSenders, ... + // everything that is needed to describe a SDP m-line. + this.transceivers = []; - function loadImages() { - loaded = false; - GetPixels(baseUrl, 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; + // since the iceGatherer is currently created in createOffer but we + // must not emit candidates until after setLocalDescription we buffer + // them in this array. + this._localIceCandidatesBuffer = []; + }; - _canvasSize.x = calculatedWidth; - _canvasSize.y = calculatedHeight; + window.RTCPeerConnection.prototype._emitBufferedCandidates = function() { + var self = this; + var sections = SDPUtils.splitSections(self.localDescription.sdp); + // FIXME: need to apply ice candidates in a way which is async but in-order + this._localIceCandidatesBuffer.forEach(function(event) { + var end = !event.candidate || Object.keys(event.candidate).length == 0; + if (end) { + for (var j = 1; j < sections.length; j++) { + sections[j] += 'a=end-of-candidates\r\n'; + } + } else { + sections[event.candidate.sdpMLineIndex + 1] += + 'a=' + event.candidate.candidate + '\r\n'; + } + self.dispatchEvent(event); + if (self.onicecandidate !== null) { + self.onicecandidate(event); + } + if (!event.candidate) { + self.iceGatheringState = 'complete'; + } + }); + this._localIceCandidatesBuffer = []; + this.localDescription.sdp = sections.join(''); + }; - setTimeout(function () { - publishEvent("canrecord", []); - }, 0); - }); - } + window.RTCPeerConnection.prototype.addStream = function(stream) { + // Clone is necessary for local demos mostly, attaching directly + // to two different senders does not work (build 10547). + this.localStreams.push(stream.clone()); + this._maybeFireNegotiationNeeded(); + }; - function publishEvent(eventName, args) { - var j, - handlers = _eventHandlers[eventName]; + window.RTCPeerConnection.prototype.removeStream = function(stream) { + var idx = this.localStreams.indexOf(stream); + if (idx > -1) { + this.localStreams.splice(idx, 1); + this._maybeFireNegotiationNeeded(); + } + }; - if (handlers && handlers.length > 0) { - for (j = 0; j < handlers.length; j++) { - handlers[j].apply(that, args); - } + // Determines the intersection of local and remote capabilities. + window.RTCPeerConnection.prototype._getCommonCapabilities = + function(localCapabilities, remoteCapabilities) { + var commonCapabilities = { + codecs: [], + headerExtensions: [], + fecMechanisms: [] + }; + localCapabilities.codecs.forEach(function(lCodec) { + for (var i = 0; i < remoteCapabilities.codecs.length; i++) { + var rCodec = remoteCapabilities.codecs[i]; + if (lCodec.name.toLowerCase() === rCodec.name.toLowerCase() && + lCodec.clockRate === rCodec.clockRate && + lCodec.numChannels === rCodec.numChannels) { + // push rCodec so we reply with offerer payload type + commonCapabilities.codecs.push(rCodec); + + // FIXME: also need to determine intersection between + // .rtcpFeedback and .parameters + break; + } } - } + }); - that.trigger = publishEvent; + localCapabilities.headerExtensions.forEach(function(lHeaderExtension) { + for (var i = 0; i < remoteCapabilities.headerExtensions.length; i++) { + var rHeaderExtension = remoteCapabilities.headerExtensions[i]; + if (lHeaderExtension.uri === rHeaderExtension.uri) { + commonCapabilities.headerExtensions.push(rHeaderExtension); + break; + } + } + }); - that.getWidth = function () { - return calculatedWidth; + // FIXME: fecMechanisms + return commonCapabilities; }; - that.getHeight = function () { - return calculatedHeight; + // Create ICE gatherer, ICE transport and DTLS transport. + window.RTCPeerConnection.prototype._createIceAndDtlsTransports = + function(mid, sdpMLineIndex) { + var self = this; + var iceGatherer = new RTCIceGatherer(self.iceOptions); + var iceTransport = new RTCIceTransport(iceGatherer); + iceGatherer.onlocalcandidate = function(evt) { + var event = new Event('icecandidate'); + event.candidate = {sdpMid: mid, sdpMLineIndex: sdpMLineIndex}; + + var cand = evt.candidate; + var end = !cand || Object.keys(cand).length === 0; + // Edge emits an empty object for RTCIceCandidateComplete‥ + if (end) { + // polyfill since RTCIceGatherer.state is not implemented in Edge 10547 yet. + if (iceGatherer.state === undefined) { + iceGatherer.state = 'completed'; + } + + // Emit a candidate with type endOfCandidates to make the samples work. + // Edge requires addIceCandidate with this empty candidate to start checking. + // The real solution is to signal end-of-candidates to the other side when + // getting the null candidate but some apps (like the samples) don't do that. + event.candidate.candidate = + 'candidate:1 1 udp 1 0.0.0.0 9 typ endOfCandidates'; + } else { + // RTCIceCandidate doesn't have a component, needs to be added + cand.component = iceTransport.component === 'RTCP' ? 2 : 1; + event.candidate.candidate = SDPUtils.writeCandidate(cand); + } + + var complete = self.transceivers.every(function(transceiver) { + return transceiver.iceGatherer && + transceiver.iceGatherer.state === 'completed'; + }); + // update .localDescription with candidate and (potentially) end-of-candidates. + // To make this harder, the gatherer might emit candidates before localdescription + // is set. To make things worse, gather.getLocalCandidates still errors in + // Edge 10547 when no candidates have been gathered yet. + if (self.localDescription && self.localDescription.type !== '') { + var sections = SDPUtils.splitSections(self.localDescription.sdp); + sections[sdpMLineIndex + 1] += (!end ? 'a=' + event.candidate.candidate : + 'a=end-of-candidates') + '\r\n'; + self.localDescription.sdp = sections.join(''); + } + + // Emit candidate if localDescription is set. + // Also emits null candidate when all gatherers are complete. + switch(self.iceGatheringState) { + case 'new': + self._localIceCandidatesBuffer.push(event); + if (complete) { + self._localIceCandidatesBuffer.push(new Event('icecandidate')); + } + break; + case 'gathering': + self._emitBufferedCandidates(); + self.dispatchEvent(event); + if (self.onicecandidate !== null) { + self.onicecandidate(event); + } + if (complete) { + self.dispatchEvent(new Event('icecandidate')); + if (self.onicecandidate !== null) { + self.onicecandidate(new Event('icecandidate')); + } + self.iceGatheringState = 'complete'; + } + break; + case 'complete': + // should not happen... currently! + break; + } + }; + iceTransport.onicestatechange = function() { + self._updateConnectionState(); + }; + + var dtlsTransport = new RTCDtlsTransport(iceTransport); + dtlsTransport.ondtlsstatechange = function() { + self._updateConnectionState(); + }; + dtlsTransport.onerror = function() { + // onerror does not set state to failed by itself. + dtlsTransport.state = 'failed'; + self._updateConnectionState(); + }; + + return { + iceGatherer: iceGatherer, + iceTransport: iceTransport, + dtlsTransport: dtlsTransport + }; }; - that.setWidth = function (width) { - calculatedWidth = width; + // Start the RTP Sender and Receiver for a transceiver. + window.RTCPeerConnection.prototype._transceive = function(transceiver, + send, recv) { + var params = this._getCommonCapabilities(transceiver.localCapabilities, + transceiver.remoteCapabilities); + if (send && transceiver.rtpSender) { + params.encodings = [{ + ssrc: transceiver.sendSsrc + }]; + params.rtcp = { + cname: SDPUtils.localCName, + ssrc: transceiver.recvSsrc + }; + transceiver.rtpSender.send(params); + } + if (recv && transceiver.rtpReceiver) { + params.encodings = [{ + ssrc: transceiver.recvSsrc + }]; + params.rtcp = { + cname: transceiver.cname, + ssrc: transceiver.sendSsrc + }; + transceiver.rtpReceiver.receive(params); + } }; - that.setHeight = function (height) { - calculatedHeight = height; - }; + window.RTCPeerConnection.prototype.setLocalDescription = + function(description) { + var self = this; + if (description.type === 'offer') { + if (!this._pendingOffer) { + } else { + this.transceivers = this._pendingOffer; + delete this._pendingOffer; + } + } else if (description.type === 'answer') { + var sections = SDPUtils.splitSections(self.remoteDescription.sdp); + var sessionpart = sections.shift(); + sections.forEach(function(mediaSection, sdpMLineIndex) { + var transceiver = self.transceivers[sdpMLineIndex]; + var iceGatherer = transceiver.iceGatherer; + var iceTransport = transceiver.iceTransport; + var dtlsTransport = transceiver.dtlsTransport; + var localCapabilities = transceiver.localCapabilities; + var remoteCapabilities = transceiver.remoteCapabilities; + var rejected = mediaSection.split('\n', 1)[0] + .split(' ', 2)[1] === '0'; + + if (!rejected) { + var remoteIceParameters = SDPUtils.getIceParameters(mediaSection, + sessionpart); + iceTransport.start(iceGatherer, remoteIceParameters, 'controlled'); + + var remoteDtlsParameters = SDPUtils.getDtlsParameters(mediaSection, + sessionpart); + dtlsTransport.start(remoteDtlsParameters); + + // Calculate intersection of capabilities. + var params = self._getCommonCapabilities(localCapabilities, + remoteCapabilities); + + // Start the RTCRtpSender. The RTCRtpReceiver for this transceiver + // has already been started in setRemoteDescription. + self._transceive(transceiver, + params.codecs.length > 0, + false); + } + }); + } - that.getRealWidth = function () { - return width; - }; + this.localDescription = { + type: description.type, + sdp: description.sdp + }; + switch (description.type) { + case 'offer': + this._updateSignalingState('have-local-offer'); + break; + case 'answer': + this._updateSignalingState('stable'); + break; + default: + throw new TypeError('unsupported type "' + description.type + '"'); + } - that.getRealHeight = function () { - return height; + // If a success callback was provided, emit ICE candidates after it has been + // executed. Otherwise, emit callback after the Promise is resolved. + var hasCallback = arguments.length > 1 && + typeof arguments[1] === 'function'; + if (hasCallback) { + var cb = arguments[1]; + window.setTimeout(function() { + cb(); + if (self.iceGatheringState === 'new') { + self.iceGatheringState = 'gathering'; + } + self._emitBufferedCandidates(); + }, 0); + } + var p = Promise.resolve(); + p.then(function() { + if (!hasCallback) { + if (self.iceGatheringState === 'new') { + self.iceGatheringState = 'gathering'; + } + // Usually candidates will be emitted earlier. + window.setTimeout(self._emitBufferedCandidates.bind(self), 500); + } + }); + return p; }; - that.setInputStream = function (stream) { - _config = stream; - baseUrl = _config.src; - size = 1; - loadImages(); + window.RTCPeerConnection.prototype.setRemoteDescription = + function(description) { + var self = this; + var stream = new MediaStream(); + var receiverList = []; + var sections = SDPUtils.splitSections(description.sdp); + var sessionpart = sections.shift(); + sections.forEach(function(mediaSection, sdpMLineIndex) { + var lines = SDPUtils.splitLines(mediaSection); + var mline = lines[0].substr(2).split(' '); + var kind = mline[0]; + var rejected = mline[1] === '0'; + var direction = SDPUtils.getDirection(mediaSection, sessionpart); + + var transceiver; + var iceGatherer; + var iceTransport; + var dtlsTransport; + var rtpSender; + var rtpReceiver; + var sendSsrc; + var recvSsrc; + var localCapabilities; + + var track; + // FIXME: ensure the mediaSection has rtcp-mux set. + var remoteCapabilities = SDPUtils.parseRtpParameters(mediaSection); + var remoteIceParameters; + var remoteDtlsParameters; + if (!rejected) { + remoteIceParameters = SDPUtils.getIceParameters(mediaSection, + sessionpart); + remoteDtlsParameters = SDPUtils.getDtlsParameters(mediaSection, + sessionpart); + } + var mid = SDPUtils.matchPrefix(mediaSection, 'a=mid:')[0].substr(6); + + var cname; + // Gets the first SSRC. Note that with RTX there might be multiple SSRCs. + var remoteSsrc = SDPUtils.matchPrefix(mediaSection, 'a=ssrc:') + .map(function(line) { + return SDPUtils.parseSsrcMedia(line); + }) + .filter(function(obj) { + return obj.attribute === 'cname'; + })[0]; + if (remoteSsrc) { + recvSsrc = parseInt(remoteSsrc.ssrc, 10); + cname = remoteSsrc.value; + } + + if (description.type === 'offer') { + var transports = self._createIceAndDtlsTransports(mid, sdpMLineIndex); + + localCapabilities = RTCRtpReceiver.getCapabilities(kind); + sendSsrc = (2 * sdpMLineIndex + 2) * 1001; + + rtpReceiver = new RTCRtpReceiver(transports.dtlsTransport, kind); + + track = rtpReceiver.track; + receiverList.push([track, rtpReceiver]); + // FIXME: not correct when there are multiple streams but that is + // not currently supported in this shim. + stream.addTrack(track); + + // FIXME: look at direction. + if (self.localStreams.length > 0 && + self.localStreams[0].getTracks().length >= sdpMLineIndex) { + // FIXME: actually more complicated, needs to match types etc + var localtrack = self.localStreams[0].getTracks()[sdpMLineIndex]; + rtpSender = new RTCRtpSender(localtrack, transports.dtlsTransport); + } + + self.transceivers[sdpMLineIndex] = { + iceGatherer: transports.iceGatherer, + iceTransport: transports.iceTransport, + dtlsTransport: transports.dtlsTransport, + localCapabilities: localCapabilities, + remoteCapabilities: remoteCapabilities, + rtpSender: rtpSender, + rtpReceiver: rtpReceiver, + kind: kind, + mid: mid, + cname: cname, + sendSsrc: sendSsrc, + recvSsrc: recvSsrc + }; + // Start the RTCRtpReceiver now. The RTPSender is started in setLocalDescription. + self._transceive(self.transceivers[sdpMLineIndex], + false, + direction === 'sendrecv' || direction === 'sendonly'); + } else if (description.type === 'answer' && !rejected) { + transceiver = self.transceivers[sdpMLineIndex]; + iceGatherer = transceiver.iceGatherer; + iceTransport = transceiver.iceTransport; + dtlsTransport = transceiver.dtlsTransport; + rtpSender = transceiver.rtpSender; + rtpReceiver = transceiver.rtpReceiver; + sendSsrc = transceiver.sendSsrc; + //recvSsrc = transceiver.recvSsrc; + localCapabilities = transceiver.localCapabilities; + + self.transceivers[sdpMLineIndex].recvSsrc = recvSsrc; + self.transceivers[sdpMLineIndex].remoteCapabilities = + remoteCapabilities; + self.transceivers[sdpMLineIndex].cname = cname; + + iceTransport.start(iceGatherer, remoteIceParameters, 'controlling'); + dtlsTransport.start(remoteDtlsParameters); + + self._transceive(transceiver, + direction === 'sendrecv' || direction === 'recvonly', + direction === 'sendrecv' || direction === 'sendonly'); + + if (rtpReceiver && + (direction === 'sendrecv' || direction === 'sendonly')) { + track = rtpReceiver.track; + receiverList.push([track, rtpReceiver]); + stream.addTrack(track); + } else { + // FIXME: actually the receiver should be created later. + delete transceiver.rtpReceiver; + } + } + }); + + this.remoteDescription = { + type: description.type, + sdp: description.sdp + }; + switch (description.type) { + case 'offer': + this._updateSignalingState('have-remote-offer'); + break; + case 'answer': + this._updateSignalingState('stable'); + break; + default: + throw new TypeError('unsupported type "' + description.type + '"'); + } + if (stream.getTracks().length) { + self.remoteStreams.push(stream); + window.setTimeout(function() { + var event = new Event('addstream'); + event.stream = stream; + self.dispatchEvent(event); + if (self.onaddstream !== null) { + window.setTimeout(function() { + self.onaddstream(event); + }, 0); + } + + receiverList.forEach(function(item) { + var track = item[0]; + var receiver = item[1]; + var event = new Event('track'); + event.track = track; + event.receiver = receiver; + event.streams = [stream]; + self.dispatchEvent(event); + if (self.ontrack !== null) { + window.setTimeout(function() { + self.ontrack(event); + }, 0); + } + }); + }, 0); + } + if (arguments.length > 1 && typeof arguments[1] === 'function') { + window.setTimeout(arguments[1], 0); + } + return Promise.resolve(); }; - that.ended = function () { - return ended; + window.RTCPeerConnection.prototype.close = function() { + this.transceivers.forEach(function(transceiver) { + /* not yet + if (transceiver.iceGatherer) { + transceiver.iceGatherer.close(); + } + */ + if (transceiver.iceTransport) { + transceiver.iceTransport.stop(); + } + if (transceiver.dtlsTransport) { + transceiver.dtlsTransport.stop(); + } + if (transceiver.rtpSender) { + transceiver.rtpSender.stop(); + } + if (transceiver.rtpReceiver) { + transceiver.rtpReceiver.stop(); + } + }); + // FIXME: clean up tracks, local streams, remote streams, etc + this._updateSignalingState('closed'); }; - that.setAttribute = function () {}; - - that.getConfig = function () { - return _config; + // Update the signaling state. + window.RTCPeerConnection.prototype._updateSignalingState = + function(newState) { + this.signalingState = newState; + var event = new Event('signalingstatechange'); + this.dispatchEvent(event); + if (this.onsignalingstatechange !== null) { + this.onsignalingstatechange(event); + } }; - that.pause = function () { - paused = true; + // Determine whether to fire the negotiationneeded event. + window.RTCPeerConnection.prototype._maybeFireNegotiationNeeded = + function() { + // Fire away (for now). + var event = new Event('negotiationneeded'); + this.dispatchEvent(event); + if (this.onnegotiationneeded !== null) { + this.onnegotiationneeded(event); + } }; - that.play = function () { - paused = false; - }; + // Update the connection state. + window.RTCPeerConnection.prototype._updateConnectionState = + function() { + var self = this; + var newState; + var states = { + 'new': 0, + closed: 0, + connecting: 0, + checking: 0, + connected: 0, + completed: 0, + failed: 0 + }; + this.transceivers.forEach(function(transceiver) { + states[transceiver.iceTransport.state]++; + states[transceiver.dtlsTransport.state]++; + }); + // ICETransport.completed and connected are the same for this purpose. + states['connected'] += states['completed']; + + newState = 'new'; + if (states['failed'] > 0) { + newState = 'failed'; + } else if (states['connecting'] > 0 || states['checking'] > 0) { + newState = 'connecting'; + } else if (states['disconnected'] > 0) { + newState = 'disconnected'; + } else if (states['new'] > 0) { + newState = 'new'; + } else if (states['connecting'] > 0 || states['completed'] > 0) { + newState = 'connected'; + } - that.setCurrentTime = function (time) { - frameIdx = time; + if (newState !== self.iceConnectionState) { + self.iceConnectionState = newState; + var event = new Event('iceconnectionstatechange'); + this.dispatchEvent(event); + if (this.oniceconnectionstatechange !== null) { + this.oniceconnectionstatechange(event); + } + } }; - that.addEventListener = function (event, f) { - if (_eventNames.indexOf(event) !== -1) { - if (!_eventHandlers[event]) { - _eventHandlers[event] = []; - } - _eventHandlers[event].push(f); + window.RTCPeerConnection.prototype.createOffer = function() { + var self = this; + if (this._pendingOffer) { + throw new Error('createOffer called while there is a pending offer.'); + } + var offerOptions; + if (arguments.length === 1 && typeof arguments[0] !== 'function') { + offerOptions = arguments[0]; + } else if (arguments.length === 3) { + offerOptions = arguments[2]; + } + + var tracks = []; + var numAudioTracks = 0; + var numVideoTracks = 0; + // Default to sendrecv. + if (this.localStreams.length) { + numAudioTracks = this.localStreams[0].getAudioTracks().length; + numVideoTracks = this.localStreams[0].getVideoTracks().length; + } + // Determine number of audio and video tracks we need to send/recv. + if (offerOptions) { + // Reject Chrome legacy constraints. + if (offerOptions.mandatory || offerOptions.optional) { + throw new TypeError( + 'Legacy mandatory/optional constraints not supported.'); } - }; + if (offerOptions.offerToReceiveAudio !== undefined) { + numAudioTracks = offerOptions.offerToReceiveAudio; + } + if (offerOptions.offerToReceiveVideo !== undefined) { + numVideoTracks = offerOptions.offerToReceiveVideo; + } + } + if (this.localStreams.length) { + // Push local streams. + this.localStreams[0].getTracks().forEach(function(track) { + tracks.push({ + kind: track.kind, + track: track, + wantReceive: track.kind === 'audio' ? + numAudioTracks > 0 : numVideoTracks > 0 + }); + if (track.kind === 'audio') { + numAudioTracks--; + } else if (track.kind === 'video') { + numVideoTracks--; + } + }); + } + // Create M-lines for recvonly streams. + while (numAudioTracks > 0 || numVideoTracks > 0) { + if (numAudioTracks > 0) { + tracks.push({ + kind: 'audio', + wantReceive: true + }); + numAudioTracks--; + } + if (numVideoTracks > 0) { + tracks.push({ + kind: 'video', + wantReceive: true + }); + numVideoTracks--; + } + } - that.setTopRight = function (topRight) { - _topRight.x = topRight.x; - _topRight.y = topRight.y; + var sdp = SDPUtils.writeSessionBoilerplate(); + var transceivers = []; + tracks.forEach(function(mline, sdpMLineIndex) { + // For each track, create an ice gatherer, ice transport, dtls transport, + // potentially rtpsender and rtpreceiver. + var track = mline.track; + var kind = mline.kind; + var mid = SDPUtils.generateIdentifier(); + + var transports = self._createIceAndDtlsTransports(mid, sdpMLineIndex); + + var localCapabilities = RTCRtpSender.getCapabilities(kind); + var rtpSender; + var rtpReceiver; + + // generate an ssrc now, to be used later in rtpSender.send + var sendSsrc = (2 * sdpMLineIndex + 1) * 1001; + if (track) { + rtpSender = new RTCRtpSender(track, transports.dtlsTransport); + } + + if (mline.wantReceive) { + rtpReceiver = new RTCRtpReceiver(transports.dtlsTransport, kind); + } + + transceivers[sdpMLineIndex] = { + iceGatherer: transports.iceGatherer, + iceTransport: transports.iceTransport, + dtlsTransport: transports.dtlsTransport, + localCapabilities: localCapabilities, + remoteCapabilities: null, + rtpSender: rtpSender, + rtpReceiver: rtpReceiver, + kind: kind, + mid: mid, + sendSsrc: sendSsrc, + recvSsrc: null + }; + var transceiver = transceivers[sdpMLineIndex]; + sdp += SDPUtils.writeMediaSection(transceiver, + transceiver.localCapabilities, 'offer', self.localStreams[0]); + }); + + this._pendingOffer = transceivers; + var desc = new RTCSessionDescription({ + type: 'offer', + sdp: sdp + }); + if (arguments.length && typeof arguments[0] === 'function') { + window.setTimeout(arguments[0], 0, desc); + } + return Promise.resolve(desc); }; - that.getTopRight = function () { - return _topRight; - }; + window.RTCPeerConnection.prototype.createAnswer = function() { + var self = this; + var answerOptions; + if (arguments.length === 1 && typeof arguments[0] !== 'function') { + answerOptions = arguments[0]; + } else if (arguments.length === 3) { + answerOptions = arguments[2]; + } - that.setCanvasSize = function (size) { - _canvasSize.x = size.x; - _canvasSize.y = size.y; + var sdp = SDPUtils.writeSessionBoilerplate(); + this.transceivers.forEach(function(transceiver) { + // Calculate intersection of capabilities. + var commonCapabilities = self._getCommonCapabilities( + transceiver.localCapabilities, + transceiver.remoteCapabilities); + + sdp += SDPUtils.writeMediaSection(transceiver, commonCapabilities, + 'answer', self.localStreams[0]); + }); + + var desc = new RTCSessionDescription({ + type: 'answer', + sdp: sdp + }); + if (arguments.length && typeof arguments[0] === 'function') { + window.setTimeout(arguments[0], 0, desc); + } + return Promise.resolve(desc); }; - that.getCanvasSize = function () { - return _canvasSize; + window.RTCPeerConnection.prototype.addIceCandidate = function(candidate) { + var mLineIndex = candidate.sdpMLineIndex; + if (candidate.sdpMid) { + for (var i = 0; i < this.transceivers.length; i++) { + if (this.transceivers[i].mid === candidate.sdpMid) { + mLineIndex = i; + break; + } + } + } + var transceiver = this.transceivers[mLineIndex]; + if (transceiver) { + var cand = Object.keys(candidate.candidate).length > 0 ? + SDPUtils.parseCandidate(candidate.candidate) : {}; + // Ignore Chrome's invalid candidates since Edge does not like them. + if (cand.protocol === 'tcp' && cand.port === 0) { + return; + } + // Ignore RTCP candidates, we assume RTCP-MUX. + if (cand.component !== '1') { + return; + } + // A dirty hack to make samples work. + if (cand.type === 'endOfCandidates') { + cand = {}; + } + transceiver.iceTransport.addRemoteCandidate(cand); + + // update the remoteDescription. + var sections = SDPUtils.splitSections(this.remoteDescription.sdp); + sections[mLineIndex + 1] += (cand.type ? candidate.candidate.trim() + : 'a=end-of-candidates') + '\r\n'; + this.remoteDescription.sdp = sections.join(''); + } + if (arguments.length > 1 && typeof arguments[1] === 'function') { + window.setTimeout(arguments[1], 0); + } + return Promise.resolve(); }; - that.getFrame = function () { - if (!loaded) { - return null; - } - return frame; + window.RTCPeerConnection.prototype.getStats = function() { + var promises = []; + this.transceivers.forEach(function(transceiver) { + ['rtpSender', 'rtpReceiver', 'iceGatherer', 'iceTransport', + 'dtlsTransport'].forEach(function(method) { + if (transceiver[method]) { + promises.push(transceiver[method].getStats()); + } + }); + }); + var cb = arguments.length > 1 && typeof arguments[1] === 'function' && + arguments[1]; + return new Promise(function(resolve) { + var results = {}; + Promise.all(promises).then(function(res) { + res.forEach(function(result) { + Object.keys(result).forEach(function(id) { + results[id] = result[id]; + }); + }); + if (cb) { + window.setTimeout(cb, 0, results); + } + resolve(results); + }); + }); }; + }, - return that; - }; + // Attach a media stream to an element. + attachMediaStream: function(element, stream) { + logging('DEPRECATED, attachMediaStream will soon be removed.'); + element.srcObject = stream; + }, + + reattachMediaStream: function(to, from) { + logging('DEPRECATED, reattachMediaStream will soon be removed.'); + to.srcObject = from.srcObject; + } + } + + // Expose public methods. + module.e = { + shimPeerConnection: edgeShim.shimPeerConnection, + attachMediaStream: edgeShim.attachMediaStream, + reattachMediaStream: edgeShim.reattachMediaStream + } - module.exports = InputStream; - -/***/ }, -/* 65 */ -/***/ function(module, exports) { - module.exports = require("get-pixels"); /***/ }, -/* 66 */ +/* 151 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; - - var CVUtils = __webpack_require__(5), - Ndarray = __webpack_require__(67), - Interp2D = __webpack_require__(68).d2; - - var FrameGrabber = {}; + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ + 'use strict'; - 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; + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; + + var firefoxShim = { + shimOnTrack: function() { + if (typeof window === 'object' && window.RTCPeerConnection && !('ontrack' in + window.RTCPeerConnection.prototype)) { + Object.defineProperty(window.RTCPeerConnection.prototype, 'ontrack', { + get: function() { return this._ontrack; }, + set: function(f) { + var self = this; + if (this._ontrack) { + this.removeEventListener('track', this._ontrack); + this.removeEventListener('addstream', this._ontrackpoly); + } + this.addEventListener('track', this._ontrack = f); + this.addEventListener('addstream', this._ontrackpoly = function(e) { + e.stream.getTracks().forEach(function(track) { + var event = new Event('track'); + event.track = track; + event.receiver = {track: track}; + event.streams = [e.stream]; + this.dispatchEvent(event); + }.bind(this)); + }.bind(this)); + } + }); + } + }, + + shimSourceObject: function() { + // Firefox has supported mozSrcObject since FF22, unprefixed in 42. + if (typeof window === 'object') { + if (window.HTMLMediaElement && + !('srcObject' in window.HTMLMediaElement.prototype)) { + // Shim the srcObject property, once, when HTMLMediaElement is found. + Object.defineProperty(window.HTMLMediaElement.prototype, 'srcObject', { + get: function() { + return this.mozSrcObject; + }, + set: function(stream) { + this.mozSrcObject = stream; + } + }); + } + } + }, + + shimPeerConnection: function() { + // The RTCPeerConnection object. + if (!window.RTCPeerConnection) { + window.RTCPeerConnection = function(pcConfig, pcConstraints) { + if (browserDetails.version < 38) { + // .urls is not supported in FF < 38. + // create RTCIceServers with a single url. + if (pcConfig && pcConfig.iceServers) { + var newIceServers = []; + for (var i = 0; i < pcConfig.iceServers.length; i++) { + var server = pcConfig.iceServers[i]; + if (server.hasOwnProperty('urls')) { + for (var j = 0; j < server.urls.length; j++) { + var newServer = { + url: server.urls[j] + }; + if (server.urls[j].indexOf('turn') === 0) { + newServer.username = server.username; + newServer.credential = server.credential; + } + newIceServers.push(newServer); + } + } else { + newIceServers.push(pcConfig.iceServers[i]); + } + } + pcConfig.iceServers = newIceServers; + } + } + return new mozRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors + }; + window.RTCPeerConnection.prototype = mozRTCPeerConnection.prototype; + + // wrap static methods. Currently just generateCertificate. + if (mozRTCPeerConnection.generateCertificate) { + Object.defineProperty(window.RTCPeerConnection, 'generateCertificate', { + get: function() { + if (arguments.length) { + return mozRTCPeerConnection.generateCertificate.apply(null, + arguments); + } else { + return mozRTCPeerConnection.generateCertificate; + } + } + }); + } - console.log("FrameGrabber", JSON.stringify({ - videoSize: _grayImageArray.shape, - canvasSize: _canvasImageArray.shape, - stepSize: [_stepSizeX, _stepSizeY], - size: _targetImageArray.shape, - topRight: _topRight - })); + window.RTCSessionDescription = mozRTCSessionDescription; + window.RTCIceCandidate = mozRTCIceCandidate; + } + }, - /** - * Uses the given array as frame-buffer - */ - _that.attachData = function (data) { - _data = data; + shimGetUserMedia: function() { + // getUserMedia constraints shim. + var getUserMedia_ = function(constraints, onSuccess, onError) { + var constraintsToFF37_ = function(c) { + if (typeof c !== 'object' || c.require) { + return c; + } + var require = []; + Object.keys(c).forEach(function(key) { + if (key === 'require' || key === 'advanced' || key === 'mediaSource') { + return; + } + var r = c[key] = (typeof c[key] === 'object') ? + c[key] : {ideal: c[key]}; + if (r.min !== undefined || + r.max !== undefined || r.exact !== undefined) { + require.push(key); + } + if (r.exact !== undefined) { + if (typeof r.exact === 'number') { + r. min = r.max = r.exact; + } else { + c[key] = r.exact; + } + delete r.exact; + } + if (r.ideal !== undefined) { + c.advanced = c.advanced || []; + var oc = {}; + if (typeof r.ideal === 'number') { + oc[key] = {min: r.ideal, max: r.ideal}; + } else { + oc[key] = r.ideal; + } + c.advanced.push(oc); + delete r.ideal; + if (!Object.keys(r).length) { + delete c[key]; + } + } + }); + if (require.length) { + c.require = require; + } + return c; + }; + if (browserDetails.version < 38) { + logging('spec: ' + JSON.stringify(constraints)); + if (constraints.audio) { + constraints.audio = constraintsToFF37_(constraints.audio); + } + if (constraints.video) { + constraints.video = constraintsToFF37_(constraints.video); + } + logging('ff37: ' + JSON.stringify(constraints)); + } + return navigator.mozGetUserMedia(constraints, onSuccess, onError); }; - /** - * Returns the used frame-buffer - */ - _that.getData = function () { - return _data; + navigator.getUserMedia = getUserMedia_; + + // Returns the result of getUserMedia as a Promise. + var getUserMediaPromise_ = function(constraints) { + return new Promise(function(resolve, reject) { + navigator.getUserMedia(constraints, resolve, reject); + }); + } + + // Shim for mediaDevices on older versions. + if (!navigator.mediaDevices) { + navigator.mediaDevices = {getUserMedia: getUserMediaPromise_, + addEventListener: function() { }, + removeEventListener: function() { } + }; + } + navigator.mediaDevices.enumerateDevices = + navigator.mediaDevices.enumerateDevices || function() { + return new Promise(function(resolve) { + var infos = [ + {kind: 'audioinput', deviceId: 'default', label: '', groupId: ''}, + {kind: 'videoinput', deviceId: 'default', label: '', groupId: ''} + ]; + resolve(infos); + }); }; - /** - * 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; - } - }; + if (browserDetails.version < 41) { + // Work around http://bugzil.la/1169665 + var orgEnumerateDevices = + navigator.mediaDevices.enumerateDevices.bind(navigator.mediaDevices); + navigator.mediaDevices.enumerateDevices = function() { + return orgEnumerateDevices().then(undefined, function(e) { + if (e.name === 'NotFoundError') { + return []; + } + throw e; + }); + }; + } + }, - _that.scaleAndCrop = function (frame) { - var x, y; + // Attach a media stream to an element. + attachMediaStream: function(element, stream) { + logging('DEPRECATED, attachMediaStream will soon be removed.'); + element.srcObject = stream; + }, - // 1. compute full-sized gray image - CVUtils.computeGray(frame.data, _grayData); + reattachMediaStream: function(to, from) { + logging('DEPRECATED, reattachMediaStream will soon be removed.'); + to.srcObject = from.srcObject; + } + } - // 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); - } - } + // Expose public methods. + module.e = { + shimOnTrack: firefoxShim.shimOnTrack, + shimSourceObject: firefoxShim.shimSourceObject, + shimPeerConnection: firefoxShim.shimPeerConnection, + shimGetUserMedia: __webpack_require__(152), + attachMediaStream: firefoxShim.attachMediaStream, + reattachMediaStream: firefoxShim.reattachMediaStream + } + + +/***/ }, +/* 152 */ +/***/ function(module, exports, __webpack_require__) { + + /* + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. + */ + 'use strict'; - // targetImageArray must be equal to targetSize - if (_targetImageArray.shape[0] !== _size.x || _targetImageArray.shape[1] !== _size.y) { - throw new Error("Shapes do not match!"); - } + var logging = __webpack_require__(0).log; + var browserDetails = __webpack_require__(0).browserDetails; - // 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; + // Expose public methods. + module.e = function() { + // getUserMedia constraints shim. + var getUserMedia_ = function(constraints, onSuccess, onError) { + var constraintsToFF37_ = function(c) { + if (typeof c !== 'object' || c.require) { + return c; + } + var require = []; + Object.keys(c).forEach(function(key) { + if (key === 'require' || key === 'advanced' || key === 'mediaSource') { + return; + } + var r = c[key] = (typeof c[key] === 'object') ? + c[key] : {ideal: c[key]}; + if (r.min !== undefined || + r.max !== undefined || r.exact !== undefined) { + require.push(key); + } + if (r.exact !== undefined) { + if (typeof r.exact === 'number') { + r. min = r.max = r.exact; + } else { + c[key] = r.exact; + } + delete r.exact; + } + if (r.ideal !== undefined) { + c.advanced = c.advanced || []; + var oc = {}; + if (typeof r.ideal === 'number') { + oc[key] = {min: r.ideal, max: r.ideal}; + } else { + oc[key] = r.ideal; + } + c.advanced.push(oc); + delete r.ideal; + if (!Object.keys(r).length) { + delete c[key]; + } + } + }); + if (require.length) { + c.require = require; + } + return c; }; + if (browserDetails.version < 38) { + logging('spec: ' + JSON.stringify(constraints)); + if (constraints.audio) { + constraints.audio = constraintsToFF37_(constraints.audio); + } + if (constraints.video) { + constraints.video = constraintsToFF37_(constraints.video); + } + logging('ff37: ' + JSON.stringify(constraints)); + } + return navigator.mozGetUserMedia(constraints, onSuccess, onError); + }; - return _that; - }; + navigator.getUserMedia = getUserMedia_; + + // Returns the result of getUserMedia as a Promise. + var getUserMediaPromise_ = function(constraints) { + return new Promise(function(resolve, reject) { + navigator.getUserMedia(constraints, resolve, reject); + }); + } + + // Shim for mediaDevices on older versions. + if (!navigator.mediaDevices) { + navigator.mediaDevices = {getUserMedia: getUserMediaPromise_, + addEventListener: function() { }, + removeEventListener: function() { } + }; + } + navigator.mediaDevices.enumerateDevices = + navigator.mediaDevices.enumerateDevices || function() { + return new Promise(function(resolve) { + var infos = [ + {kind: 'audioinput', deviceId: 'default', label: '', groupId: ''}, + {kind: 'videoinput', deviceId: 'default', label: '', groupId: ''} + ]; + resolve(infos); + }); + }; - module.exports = FrameGrabber; + if (browserDetails.version < 41) { + // Work around http://bugzil.la/1169665 + var orgEnumerateDevices = + navigator.mediaDevices.enumerateDevices.bind(navigator.mediaDevices); + navigator.mediaDevices.enumerateDevices = function() { + return orgEnumerateDevices().then(undefined, function(e) { + if (e.name === 'NotFoundError') { + return []; + } + throw e; + }); + }; + } + } + /***/ }, -/* 67 */ +/* 153 */ /***/ function(module, exports) { - module.exports = require("ndarray"); + module.e = __WEBPACK_EXTERNAL_MODULE_153__; /***/ }, -/* 68 */ +/* 154 */ +/***/ function(module, exports) { + + module.e = __WEBPACK_EXTERNAL_MODULE_154__; + +/***/ }, +/* 155 */ /***/ function(module, exports) { - module.exports = require("ndarray-linear-interpolate"); + module.e = __WEBPACK_EXTERNAL_MODULE_155__; + +/***/ }, +/* 156 */ +/***/ function(module, exports, __webpack_require__) { + + module.e = __webpack_require__(49); + /***/ } -/******/ ]); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///webpack/bootstrap b0af99d046dca99f8862","webpack:///D:/work/quaggaJS/src/quagga.js","webpack:///D:/work/quaggaJS/src/common/typedefs.js","webpack:///D:/work/quaggaJS/src/common/image_wrapper.js","webpack:///D:/work/quaggaJS/src/common/subImage.js","webpack:///D:/work/quaggaJS/src/common/cv_utils.js","webpack:///D:/work/quaggaJS/src/common/cluster.js","webpack:///external \"gl-matrix\"","webpack:///D:/work/quaggaJS/src/common/array_helper.js","webpack:///D:/work/quaggaJS/src/locator/barcode_locator.js","webpack:///D:/work/quaggaJS/src/common/image_debug.js","webpack:///D:/work/quaggaJS/src/locator/rasterizer.js","webpack:///D:/work/quaggaJS/src/locator/tracer.js","webpack:///D:/work/quaggaJS/src/locator/skeletonizer.js","webpack:///D:/work/quaggaJS/src/decoder/barcode_decoder.js","webpack:///D:/work/quaggaJS/src/decoder/bresenham.js","webpack:///D:/work/quaggaJS/src/reader/code_128_reader.js","webpack:///D:/work/quaggaJS/src/reader/barcode_reader.js","webpack:///D:/work/quaggaJS/src/reader/ean_reader.js","webpack:///D:/work/quaggaJS/src/reader/code_39_reader.js","webpack:///D:/work/quaggaJS/src/reader/code_39_vin_reader.js","webpack:///D:/work/quaggaJS/src/reader/codabar_reader.js","webpack:///D:/work/quaggaJS/src/reader/upc_reader.js","webpack:///D:/work/quaggaJS/src/reader/ean_8_reader.js","webpack:///D:/work/quaggaJS/src/reader/upc_e_reader.js","webpack:///D:/work/quaggaJS/src/reader/i2of5_reader.js","webpack:///./~/lodash/object/merge.js","webpack:///./~/lodash/internal/baseMerge.js","webpack:///./~/lodash/internal/arrayEach.js","webpack:///./~/lodash/internal/baseMergeDeep.js","webpack:///./~/lodash/internal/arrayCopy.js","webpack:///./~/lodash/lang/isArguments.js","webpack:///./~/lodash/internal/isArrayLike.js","webpack:///./~/lodash/internal/getLength.js","webpack:///./~/lodash/internal/baseProperty.js","webpack:///./~/lodash/internal/isLength.js","webpack:///./~/lodash/internal/isObjectLike.js","webpack:///./~/lodash/lang/isArray.js","webpack:///./~/lodash/internal/getNative.js","webpack:///./~/lodash/lang/isNative.js","webpack:///./~/lodash/lang/isFunction.js","webpack:///./~/lodash/lang/isObject.js","webpack:///./~/lodash/lang/isPlainObject.js","webpack:///./~/lodash/internal/baseForIn.js","webpack:///./~/lodash/internal/baseFor.js","webpack:///./~/lodash/internal/createBaseFor.js","webpack:///./~/lodash/internal/toObject.js","webpack:///./~/lodash/object/keysIn.js","webpack:///./~/lodash/internal/isIndex.js","webpack:///./~/lodash/lang/isTypedArray.js","webpack:///./~/lodash/lang/toPlainObject.js","webpack:///./~/lodash/internal/baseCopy.js","webpack:///./~/lodash/object/keys.js","webpack:///./~/lodash/internal/shimKeys.js","webpack:///./~/lodash/internal/createAssigner.js","webpack:///./~/lodash/internal/bindCallback.js","webpack:///./~/lodash/utility/identity.js","webpack:///./~/lodash/internal/isIterateeCall.js","webpack:///./~/lodash/function/restParam.js","webpack:///D:/work/quaggaJS/src/common/events.js","webpack:///D:/work/quaggaJS/src/input/camera_access.js","webpack:///D:/work/quaggaJS/src/analytics/result_collector.js","webpack:///D:/work/quaggaJS/src/config/config.js","webpack:///D:/work/quaggaJS/src/config/config.node.js","webpack:///D:/work/quaggaJS/lib/input_stream.js","webpack:///external \"get-pixels\"","webpack:///D:/work/quaggaJS/lib/frame_grabber.js","webpack:///external \"ndarray\"","webpack:///external \"ndarray-linear-interpolate\""],"names":[],"mappings":"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AC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAA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AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,UAAU;AACrB,YAAW,SAAS;AACpB,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA,gBAAe,mBAAmB,GAAG,iBAAiB;AACtD;AACA;AACA;AACA,gBAAe,YAAY,GAAG,YAAY;AAC1C;AACA;AACA;AACA,WAAU,WAAW,8BAA8B,GAAG,4BAA4B;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAI;AACJ,WAAU;AACV;AACA;;AAEA;;;;;;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;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,IAAG;AACH;AACA;;AAEA;;;;;;;ACvDA;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,SAAS;AACpB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,SAAS;AACpB,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA4C;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;;;;;;;AClEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA,8BAA6B,kBAAkB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjCA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACXA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA,0BAAyB,kBAAkB,EAAE;AAC7C;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvCA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,4DAA2D;AAC3D;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/CA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA,iBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;;;;;;;ACtEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;;AAEA;;;;;;;AChBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,QAAQ;AACnB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/DA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvBA;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa,SAAS;AACtB,WAAU;AACV;AACA,cAAa,SAAS;AACtB,WAAU;AACV;AACA;AACA;AACA;;AAEA;;;;;;;AC9BA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,YAAW,OAAO,WAAW;AAC7B,cAAa,OAAO;AACpB;AACA;AACA,yBAAwB;;AAExB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5CA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxCA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;ACxCA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,YAAW,EAAE;AACb,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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","file":"quagga.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\texports: {},\n \t\t\tid: moduleId,\n \t\t\tloaded: false\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.loaded = 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// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(0);\n\n\n\n/** WEBPACK FOOTER **\n ** webpack/bootstrap b0af99d046dca99f8862\n **/","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 {vec2} from 'gl-matrix';\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\n\r\nconst merge = require('lodash/object/merge');\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, function(err) {\r\n            if (!err) {\r\n                _inputStream.trigger(\"canrecord\");\r\n            } else {\r\n                return cb(err);\r\n            }\r\n        });\r\n    }\r\n\r\n    _inputStream.setAttribute(\"preload\", \"auto\");\r\n    _inputStream.setAttribute(\"autoplay\", true);\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    const resultToPublish = result && (result.barcodes || result);\r\n\r\n    if (result && _onUIThread) {\r\n        transformResult(result);\r\n        addResult(result, imageData);\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: _config\r\n    }, [workerThread.imageData.buffer]);\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();\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, function() {\r\n            Events.once(\"processed\", function(result) {\r\n                _stopped = true;\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};\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/quagga.js\n **/","/*\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\n    navigator.getUserMedia = navigator.getUserMedia ||\r\n        navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;\r\n    window.URL = window.URL || window.webkitURL || window.mozURL || window.msURL;\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\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/common/typedefs.js\n **/","import SubImage from './subImage';\r\nimport CVUtils from '../common/cv_utils';\r\nimport ArrayHelper from '../common/array_helper';\r\nimport {vec2} from 'gl-matrix';\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 : CVUtils.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 ** D:/work/quaggaJS/src/common/image_wrapper.js\n **/","/**\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 ** D:/work/quaggaJS/src/common/subImage.js\n **/","import Cluster2 from './cluster';\r\nimport ArrayHelper from './array_helper';\r\nimport {vec2, vec3} from 'gl-matrix';\r\n\r\nvar CVUtils = {};\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\nCVUtils.imageRef = function(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\nCVUtils.computeIntegralImage2 = function(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\nCVUtils.computeIntegralImage = function(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\nCVUtils.thresholdImage = function(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\nCVUtils.computeHistogram = function(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\nCVUtils.sharpenLine = function(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\nCVUtils.determineOtsuThreshold = function(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 = CVUtils.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\nCVUtils.otsuThreshold = function(imageWrapper, targetWrapper) {\r\n    var threshold = CVUtils.determineOtsuThreshold(imageWrapper);\r\n\r\n    CVUtils.thresholdImage(imageWrapper, threshold, targetWrapper);\r\n    return threshold;\r\n};\r\n\r\n// local thresholding\r\nCVUtils.computeBinaryImage = function(imageWrapper, integralWrapper, targetWrapper) {\r\n    CVUtils.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\nCVUtils.cluster = function(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\nCVUtils.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\nCVUtils.DILATE = 1;\r\nCVUtils.ERODE = 2;\r\n\r\nCVUtils.dilate = function(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\nCVUtils.erode = function(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\nCVUtils.subtract = function(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\nCVUtils.bitwiseOr = function(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\nCVUtils.countNonZero = function(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\nCVUtils.topGeneric = function(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\nCVUtils.grayArrayFromImage = function(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    CVUtils.computeGray(ctxData, array);\r\n};\r\n\r\nCVUtils.grayArrayFromContext = function(ctx, size, offset, array) {\r\n    var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data;\r\n    CVUtils.computeGray(ctxData, array);\r\n};\r\n\r\nCVUtils.grayAndHalfSampleFromCanvasData = function(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] = Math.floor((\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\nCVUtils.computeGray = function(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] = Math.floor(\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\nCVUtils.loadImageArray = function(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        CVUtils.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\nCVUtils.halfSample = function(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\nCVUtils.hsv2rgb = function(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\nCVUtils._computeDivisors = function(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\nCVUtils._computeIntersection = function(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\nCVUtils.calculatePatchSize = function(patchSize, imgSize) {\r\n    var divisorsX = this._computeDivisors(imgSize.x),\r\n        divisorsY = this._computeDivisors(imgSize.y),\r\n        wideSide = Math.max(imgSize.x, imgSize.y),\r\n        common = this._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(this._computeDivisors(wideSide));\r\n        if (!optimalPatchSize) {\r\n            optimalPatchSize = findPatchSizeForDivisors((this._computeDivisors(desiredPatchSize * nrOfPatches)));\r\n        }\r\n    }\r\n    return optimalPatchSize;\r\n};\r\n\r\nCVUtils._parseCSSDimensionValues = function(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\nCVUtils._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\nCVUtils.computeImageArea = function(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 = CVUtils._parseCSSDimensionValues(value),\r\n            calculated = CVUtils._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\r\nexport default CVUtils;\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/common/cv_utils.js\n **/","import {vec2} from 'gl-matrix';\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 ** D:/work/quaggaJS/src/common/cluster.js\n **/","module.exports = require(\"gl-matrix\");\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external \"gl-matrix\"\n ** module id = 7\n ** module chunks = 0\n **/","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 ** D:/work/quaggaJS/src/common/array_helper.js\n **/","import ImageWrapper from '../common/image_wrapper';\r\nimport CVUtils 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\nimport {vec2, mat2} from 'gl-matrix';\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 = CVUtils.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.clone([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    CVUtils.otsuThreshold(_currentImageWrapper, _binaryImageWrapper);\r\n    _binaryImageWrapper.zeroBorder();\r\n    if (_config.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                    CVUtils.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 = CVUtils.cluster(moments, 0.90);\r\n    var topCluster = CVUtils.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, CVUtils.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, CVUtils.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                CVUtils.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            CVUtils.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 = CVUtils.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 = CVUtils.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 ** D:/work/quaggaJS/src/locator/barcode_locator.js\n **/","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 ** D:/work/quaggaJS/src/common/image_debug.js\n **/","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 ** D:/work/quaggaJS/src/locator/rasterizer.js\n **/","/**\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 ** D:/work/quaggaJS/src/locator/tracer.js\n **/","/* @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\r\n    return {\r\n        skeletonize: skeletonize\r\n    };\r\n}\r\n\r\nexport default Skeletonizer;\r\n/* eslint-enable eqeqeq*/\r\n/* @preserve ASM END */\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/locator/skeletonizer.js\n **/","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 UPCEReader from '../reader/upc_e_reader';\r\nimport I2of5Reader from '../reader/i2of5_reader';\r\n\r\nconst READERS = {\r\n    code_128_reader: Code128Reader,\r\n    ean_reader: EANReader,\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};\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\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                _barcodeReaders.push(new READERS[reader](configuration));\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 ** D:/work/quaggaJS/src/decoder/barcode_decoder.js\n **/","import CVUtils from '../common/cv_utils';\r\nimport 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\nBresenham.toOtsuBinaryLine = function(result) {\r\n    var line = result.line,\r\n        image = new ImageWrapper({x: line.length - 1, y: 1}, line),\r\n        threshold = CVUtils.determineOtsuThreshold(image, 5);\r\n\r\n    line = CVUtils.sharpenLine(line);\r\n    CVUtils.thresholdImage(image, threshold);\r\n\r\n    return {\r\n        line: line,\r\n        threshold: threshold\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 ** D:/work/quaggaJS/src/decoder/bresenham.js\n **/","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    MODULO: {value: 11},\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: 1},\r\n    AVG_CODE_ERROR: {value: 0.5},\r\n    FORMAT: {value: \"code_128\", writeable: false}\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) {\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        },\r\n        code,\r\n        error,\r\n        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n                        error = self._matchPattern(normalized, 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                    return bestMatch;\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\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        },\r\n        code,\r\n        error,\r\n        j,\r\n        sum,\r\n        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) {\r\n                        error = self._matchPattern(normalized, 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                        return bestMatch;\r\n                    }\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    };\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);\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\nexport default Code128Reader;\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/reader/code_128_reader.js\n **/","function BarcodeReader(config) {\r\n    this._row = [];\r\n    this.config = config || {};\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) {\r\n    var i,\r\n        error = 0,\r\n        singleError = 0,\r\n        modulo = this.MODULO,\r\n        maxSingleError = this.SINGLE_CODE_ERROR || 1;\r\n\r\n    for (i = 0; i < counter.length; i++) {\r\n        singleError = Math.abs(code[i] - counter[i]);\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._normalize = function(counter, modulo) {\r\n    var i,\r\n        self = this,\r\n        sum = 0,\r\n        ratio,\r\n        numOnes = 0,\r\n        normalized = [],\r\n        norm = 0;\r\n\r\n    if (!modulo) {\r\n        modulo = self.MODULO;\r\n    }\r\n    for (i = 0; i < counter.length; i++) {\r\n        if (counter[i] === 1) {\r\n            numOnes++;\r\n        } else {\r\n            sum += counter[i];\r\n        }\r\n    }\r\n    ratio = sum / (modulo - numOnes);\r\n    if (ratio > 1.0) {\r\n        for (i = 0; i < counter.length; i++) {\r\n            norm = counter[i] === 1 ? counter[i] : counter[i] / ratio;\r\n            normalized.push(norm);\r\n        }\r\n    } else {\r\n        ratio = (sum + numOnes) / modulo;\r\n        for (i = 0; i < counter.length; i++) {\r\n            norm = counter[i] / ratio;\r\n            normalized.push(norm);\r\n        }\r\n    }\r\n    return normalized;\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\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 ** D:/work/quaggaJS/src/reader/barcode_reader.js\n **/","import BarcodeReader from './barcode_reader';\r\n\r\nfunction EANReader(opts) {\r\n    BarcodeReader.call(this, opts);\r\n}\r\n\r\nvar properties = {\r\n    CODE_L_START: {value: 0},\r\n    MODULO: {value: 7},\r\n    CODE_G_START: {value: 10},\r\n    START_PATTERN: {value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7]},\r\n    STOP_PATTERN: {value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7]},\r\n    MIDDLE_PATTERN: {value: [1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7]},\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.67},\r\n    AVG_CODE_ERROR: {value: 0.27},\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        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = 0; code < coderange; code++) {\r\n                        error = self._matchPattern(normalized, 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                }\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        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    error = self._matchPattern(normalized, 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                }\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\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    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    };\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\nexport default (EANReader);\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/reader/ean_reader.js\n **/","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._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\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 ** D:/work/quaggaJS/src/reader/code_39_reader.js\n **/","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 ** D:/work/quaggaJS/src/reader/code_39_vin_reader.js\n **/","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 ** D:/work/quaggaJS/src/reader/codabar_reader.js\n **/","import EANReader from './ean_reader';\r\n\r\nfunction UPCReader() {\r\n    EANReader.call(this);\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 ** D:/work/quaggaJS/src/reader/upc_reader.js\n **/","import EANReader from './ean_reader';\r\n\r\nfunction EAN8Reader() {\r\n    EANReader.call(this);\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 ** D:/work/quaggaJS/src/reader/ean_8_reader.js\n **/","import EANReader from './ean_reader';\r\n\r\nfunction UPCEReader() {\r\n    EANReader.call(this);\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 ** D:/work/quaggaJS/src/reader/upc_e_reader.js\n **/","import BarcodeReader from './barcode_reader';\r\nconst merge = require('lodash/object/merge');\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        MODULO: {value: 10},\r\n        START_PATTERN: {value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5]},\r\n        STOP_PATTERN: {value: [N * 2, N * 2, W * 2]},\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    error = self._matchPattern(normalized, 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                }\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    normalized = self._normalize(counter);\r\n    if (normalized) {\r\n        for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n            error = self._matchPattern(normalized, 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    return null;\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 ** D:/work/quaggaJS/src/reader/i2of5_reader.js\n **/","var baseMerge = require('../internal/baseMerge'),\n    createAssigner = require('../internal/createAssigner');\n\n/**\n * Recursively merges own enumerable properties of the source object(s), that\n * don't resolve to `undefined` into the destination object. Subsequent sources\n * overwrite property assignments of previous sources. If `customizer` is\n * provided it's invoked to produce the merged values of the destination and\n * source properties. If `customizer` returns `undefined` merging is handled\n * by the method instead. The `customizer` is bound to `thisArg` and invoked\n * with five arguments: (objectValue, sourceValue, key, object, source).\n *\n * @static\n * @memberOf _\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {*} [thisArg] The `this` binding of `customizer`.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var users = {\n *   'data': [{ 'user': 'barney' }, { 'user': 'fred' }]\n * };\n *\n * var ages = {\n *   'data': [{ 'age': 36 }, { 'age': 40 }]\n * };\n *\n * _.merge(users, ages);\n * // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] }\n *\n * // using a customizer callback\n * var object = {\n *   'fruits': ['apple'],\n *   'vegetables': ['beet']\n * };\n *\n * var other = {\n *   'fruits': ['banana'],\n *   'vegetables': ['carrot']\n * };\n *\n * _.merge(object, other, function(a, b) {\n *   if (_.isArray(a)) {\n *     return a.concat(b);\n *   }\n * });\n * // => { 'fruits': ['apple', 'banana'], 'vegetables': ['beet', 'carrot'] }\n */\nvar merge = createAssigner(baseMerge);\n\nmodule.exports = merge;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/object/merge.js\n ** module id = 26\n ** module chunks = 0\n **/","var arrayEach = require('./arrayEach'),\n    baseMergeDeep = require('./baseMergeDeep'),\n    isArray = require('../lang/isArray'),\n    isArrayLike = require('./isArrayLike'),\n    isObject = require('../lang/isObject'),\n    isObjectLike = require('./isObjectLike'),\n    isTypedArray = require('../lang/isTypedArray'),\n    keys = require('../object/keys');\n\n/**\n * The base implementation of `_.merge` without support for argument juggling,\n * multiple sources, and `this` binding `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Array} [stackA=[]] Tracks traversed source objects.\n * @param {Array} [stackB=[]] Associates values with source counterparts.\n * @returns {Object} Returns `object`.\n */\nfunction baseMerge(object, source, customizer, stackA, stackB) {\n  if (!isObject(object)) {\n    return object;\n  }\n  var isSrcArr = isArrayLike(source) && (isArray(source) || isTypedArray(source)),\n      props = isSrcArr ? undefined : keys(source);\n\n  arrayEach(props || source, function(srcValue, key) {\n    if (props) {\n      key = srcValue;\n      srcValue = source[key];\n    }\n    if (isObjectLike(srcValue)) {\n      stackA || (stackA = []);\n      stackB || (stackB = []);\n      baseMergeDeep(object, source, key, baseMerge, customizer, stackA, stackB);\n    }\n    else {\n      var value = object[key],\n          result = customizer ? customizer(value, srcValue, key, object, source) : undefined,\n          isCommon = result === undefined;\n\n      if (isCommon) {\n        result = srcValue;\n      }\n      if ((result !== undefined || (isSrcArr && !(key in object))) &&\n          (isCommon || (result === result ? (result !== value) : (value === value)))) {\n        object[key] = result;\n      }\n    }\n  });\n  return object;\n}\n\nmodule.exports = baseMerge;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseMerge.js\n ** module id = 27\n ** module chunks = 0\n **/","/**\n * A specialized version of `_.forEach` for arrays without support for callback\n * shorthands and `this` binding.\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 `array`.\n */\nfunction arrayEach(array, iteratee) {\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    if (iteratee(array[index], index, array) === false) {\n      break;\n    }\n  }\n  return array;\n}\n\nmodule.exports = arrayEach;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/arrayEach.js\n ** module id = 28\n ** module chunks = 0\n **/","var arrayCopy = require('./arrayCopy'),\n    isArguments = require('../lang/isArguments'),\n    isArray = require('../lang/isArray'),\n    isArrayLike = require('./isArrayLike'),\n    isPlainObject = require('../lang/isPlainObject'),\n    isTypedArray = require('../lang/isTypedArray'),\n    toPlainObject = require('../lang/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 {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Array} [stackA=[]] Tracks traversed source objects.\n * @param {Array} [stackB=[]] Associates values with source counterparts.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseMergeDeep(object, source, key, mergeFunc, customizer, stackA, stackB) {\n  var length = stackA.length,\n      srcValue = source[key];\n\n  while (length--) {\n    if (stackA[length] == srcValue) {\n      object[key] = stackB[length];\n      return;\n    }\n  }\n  var value = object[key],\n      result = customizer ? customizer(value, srcValue, key, object, source) : undefined,\n      isCommon = result === undefined;\n\n  if (isCommon) {\n    result = srcValue;\n    if (isArrayLike(srcValue) && (isArray(srcValue) || isTypedArray(srcValue))) {\n      result = isArray(value)\n        ? value\n        : (isArrayLike(value) ? arrayCopy(value) : []);\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      result = isArguments(value)\n        ? toPlainObject(value)\n        : (isPlainObject(value) ? value : {});\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  // Add the source value to the stack of traversed objects and associate\n  // it with its merged value.\n  stackA.push(srcValue);\n  stackB.push(result);\n\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    object[key] = mergeFunc(result, srcValue, customizer, stackA, stackB);\n  } else if (result === result ? (result !== value) : (value === value)) {\n    object[key] = result;\n  }\n}\n\nmodule.exports = baseMergeDeep;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseMergeDeep.js\n ** module id = 29\n ** module chunks = 0\n **/","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction arrayCopy(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 = arrayCopy;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/arrayCopy.js\n ** module id = 30\n ** module chunks = 0\n **/","var isArrayLike = require('../internal/isArrayLike'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Native method references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is classified as an `arguments` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nfunction isArguments(value) {\n  return isObjectLike(value) && isArrayLike(value) &&\n    hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee');\n}\n\nmodule.exports = isArguments;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isArguments.js\n ** module id = 31\n ** module chunks = 0\n **/","var getLength = require('./getLength'),\n    isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(getLength(value));\n}\n\nmodule.exports = isArrayLike;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isArrayLike.js\n ** module id = 32\n ** module chunks = 0\n **/","var baseProperty = require('./baseProperty');\n\n/**\n * Gets the \"length\" property value of `object`.\n *\n * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792)\n * that affects Safari on at least iOS 8.1-8.3 ARM64.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {*} Returns the \"length\" value.\n */\nvar getLength = baseProperty('length');\n\nmodule.exports = getLength;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/getLength.js\n ** module id = 33\n ** module chunks = 0\n **/","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new function.\n */\nfunction baseProperty(key) {\n  return function(object) {\n    return object == null ? undefined : object[key];\n  };\n}\n\nmodule.exports = baseProperty;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseProperty.js\n ** module id = 34\n ** module chunks = 0\n **/","/**\n * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer)\n * of an array-like value.\n */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength).\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n */\nfunction isLength(value) {\n  return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isLength.js\n ** module id = 35\n ** module chunks = 0\n **/","/**\n * Checks if `value` is object-like.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isObjectLike.js\n ** module id = 36\n ** module chunks = 0\n **/","var getNative = require('../internal/getNative'),\n    isLength = require('../internal/isLength'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** `Object#toString` result references. */\nvar arrayTag = '[object Array]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeIsArray = getNative(Array, 'isArray');\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(function() { return arguments; }());\n * // => false\n */\nvar isArray = nativeIsArray || function(value) {\n  return isObjectLike(value) && isLength(value.length) && objToString.call(value) == arrayTag;\n};\n\nmodule.exports = isArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isArray.js\n ** module id = 37\n ** module chunks = 0\n **/","var isNative = require('../lang/isNative');\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 = object == null ? undefined : object[key];\n  return isNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/getNative.js\n ** module id = 38\n ** module chunks = 0\n **/","var isFunction = require('./isFunction'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** Used to detect host constructors (Safari > 5). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar fnToString = Function.prototype.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  fnToString.call(hasOwnProperty).replace(/[\\\\^$.*+?()[\\]{}|]/g, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * Checks if `value` is a native function.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function, else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\nfunction isNative(value) {\n  if (value == null) {\n    return false;\n  }\n  if (isFunction(value)) {\n    return reIsNative.test(fnToString.call(value));\n  }\n  return isObjectLike(value) && reIsHostCtor.test(value);\n}\n\nmodule.exports = isNative;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isNative.js\n ** module id = 39\n ** module chunks = 0\n **/","var isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar funcTag = '[object Function]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in older versions of Chrome and Safari which return 'function' for regexes\n  // and Safari 8 which returns 'object' for typed array constructors.\n  return isObject(value) && objToString.call(value) == funcTag;\n}\n\nmodule.exports = isFunction;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isFunction.js\n ** module id = 40\n ** module chunks = 0\n **/","/**\n * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`.\n * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\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(1);\n * // => false\n */\nfunction isObject(value) {\n  // Avoid a V8 JIT bug in Chrome 19-20.\n  // See https://code.google.com/p/v8/issues/detail?id=2291 for more details.\n  var type = typeof value;\n  return !!value && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isObject.js\n ** module id = 41\n ** module chunks = 0\n **/","var baseForIn = require('../internal/baseForIn'),\n    isArguments = require('./isArguments'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for native 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 [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\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 * **Note:** This method assumes objects created by the `Object` constructor\n * have no inherited enumerable properties.\n *\n * @static\n * @memberOf _\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  var Ctor;\n\n  // Exit early for non `Object` objects.\n  if (!(isObjectLike(value) && objToString.call(value) == objectTag && !isArguments(value)) ||\n      (!hasOwnProperty.call(value, 'constructor') && (Ctor = value.constructor, typeof Ctor == 'function' && !(Ctor instanceof Ctor)))) {\n    return false;\n  }\n  // IE < 9 iterates inherited properties before own properties. If the first\n  // iterated property is an object's own property then there are no inherited\n  // enumerable properties.\n  var result;\n  // In most environments an object's own properties are iterated before\n  // its inherited properties. If the last iterated property is an object's\n  // own property then there are no inherited enumerable properties.\n  baseForIn(value, function(subValue, key) {\n    result = key;\n  });\n  return result === undefined || hasOwnProperty.call(value, result);\n}\n\nmodule.exports = isPlainObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isPlainObject.js\n ** module id = 42\n ** module chunks = 0\n **/","var baseFor = require('./baseFor'),\n    keysIn = require('../object/keysIn');\n\n/**\n * The base implementation of `_.forIn` without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForIn(object, iteratee) {\n  return baseFor(object, iteratee, keysIn);\n}\n\nmodule.exports = baseForIn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseForIn.js\n ** module id = 43\n ** module chunks = 0\n **/","var createBaseFor = require('./createBaseFor');\n\n/**\n * The base implementation of `baseForIn` and `baseForOwn` which iterates\n * over `object` properties returned by `keysFunc` invoking `iteratee` for\n * each property. Iteratee functions may exit iteration early by explicitly\n * 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/internal/baseFor.js\n ** module id = 44\n ** module chunks = 0\n **/","var toObject = require('./toObject');\n\n/**\n * Creates a base function for `_.forIn` or `_.forInRight`.\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 iterable = toObject(object),\n        props = keysFunc(object),\n        length = props.length,\n        index = fromRight ? length : -1;\n\n    while ((fromRight ? index-- : ++index < length)) {\n      var key = props[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/internal/createBaseFor.js\n ** module id = 45\n ** module chunks = 0\n **/","var isObject = require('../lang/isObject');\n\n/**\n * Converts `value` to an object if it's not one.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {Object} Returns the object.\n */\nfunction toObject(value) {\n  return isObject(value) ? value : Object(value);\n}\n\nmodule.exports = toObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/toObject.js\n ** module id = 46\n ** module chunks = 0\n **/","var isArguments = require('../lang/isArguments'),\n    isArray = require('../lang/isArray'),\n    isIndex = require('../internal/isIndex'),\n    isLength = require('../internal/isLength'),\n    isObject = require('../lang/isObject');\n\n/** Used for native 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 own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\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  if (object == null) {\n    return [];\n  }\n  if (!isObject(object)) {\n    object = Object(object);\n  }\n  var length = object.length;\n  length = (length && isLength(length) &&\n    (isArray(object) || isArguments(object)) && length) || 0;\n\n  var Ctor = object.constructor,\n      index = -1,\n      isProto = typeof Ctor == 'function' && Ctor.prototype === object,\n      result = Array(length),\n      skipIndexes = length > 0;\n\n  while (++index < length) {\n    result[index] = (index + '');\n  }\n  for (var key in object) {\n    if (!(skipIndexes && isIndex(key, length)) &&\n        !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = keysIn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/object/keysIn.js\n ** module id = 47\n ** module chunks = 0\n **/","/** Used to detect unsigned integer values. */\nvar reIsUint = /^\\d+$/;\n\n/**\n * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer)\n * of an array-like value.\n */\nvar MAX_SAFE_INTEGER = 9007199254740991;\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  value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1;\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return value > -1 && value % 1 == 0 && value < length;\n}\n\nmodule.exports = isIndex;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isIndex.js\n ** module id = 48\n ** module chunks = 0\n **/","var isLength = require('../internal/isLength'),\n    isObjectLike = require('../internal/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    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[dateTag] = typedArrayTags[errorTag] =\ntypedArrayTags[funcTag] = typedArrayTags[mapTag] =\ntypedArrayTags[numberTag] = typedArrayTags[objectTag] =\ntypedArrayTags[regexpTag] = typedArrayTags[setTag] =\ntypedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nfunction isTypedArray(value) {\n  return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objToString.call(value)];\n}\n\nmodule.exports = isTypedArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/isTypedArray.js\n ** module id = 49\n ** module chunks = 0\n **/","var baseCopy = require('../internal/baseCopy'),\n    keysIn = require('../object/keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable\n * properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\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 baseCopy(value, keysIn(value));\n}\n\nmodule.exports = toPlainObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/lang/toPlainObject.js\n ** module id = 50\n ** module chunks = 0\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 names to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @returns {Object} Returns `object`.\n */\nfunction baseCopy(source, props, object) {\n  object || (object = {});\n\n  var index = -1,\n      length = props.length;\n\n  while (++index < length) {\n    var key = props[index];\n    object[key] = source[key];\n  }\n  return object;\n}\n\nmodule.exports = baseCopy;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/baseCopy.js\n ** module id = 51\n ** module chunks = 0\n **/","var getNative = require('../internal/getNative'),\n    isArrayLike = require('../internal/isArrayLike'),\n    isObject = require('../lang/isObject'),\n    shimKeys = require('../internal/shimKeys');\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = getNative(Object, 'keys');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @memberOf _\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 * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nvar keys = !nativeKeys ? shimKeys : function(object) {\n  var Ctor = object == null ? undefined : object.constructor;\n  if ((typeof Ctor == 'function' && Ctor.prototype === object) ||\n      (typeof object != 'function' && isArrayLike(object))) {\n    return shimKeys(object);\n  }\n  return isObject(object) ? nativeKeys(object) : [];\n};\n\nmodule.exports = keys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/object/keys.js\n ** module id = 52\n ** module chunks = 0\n **/","var isArguments = require('../lang/isArguments'),\n    isArray = require('../lang/isArray'),\n    isIndex = require('./isIndex'),\n    isLength = require('./isLength'),\n    keysIn = require('../object/keysIn');\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A fallback implementation of `Object.keys` which creates an array of the\n * own enumerable property names of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction shimKeys(object) {\n  var props = keysIn(object),\n      propsLength = props.length,\n      length = propsLength && object.length;\n\n  var allowIndexes = !!length && isLength(length) &&\n    (isArray(object) || isArguments(object));\n\n  var index = -1,\n      result = [];\n\n  while (++index < propsLength) {\n    var key = props[index];\n    if ((allowIndexes && isIndex(key, length)) || hasOwnProperty.call(object, key)) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = shimKeys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/shimKeys.js\n ** module id = 53\n ** module chunks = 0\n **/","var bindCallback = require('./bindCallback'),\n    isIterateeCall = require('./isIterateeCall'),\n    restParam = require('../function/restParam');\n\n/**\n * Creates a `_.assign`, `_.defaults`, or `_.merge` function.\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 restParam(function(object, sources) {\n    var index = -1,\n        length = object == null ? 0 : sources.length,\n        customizer = length > 2 ? sources[length - 2] : undefined,\n        guard = length > 2 ? sources[2] : undefined,\n        thisArg = length > 1 ? sources[length - 1] : undefined;\n\n    if (typeof customizer == 'function') {\n      customizer = bindCallback(customizer, thisArg, 5);\n      length -= 2;\n    } else {\n      customizer = typeof thisArg == 'function' ? thisArg : undefined;\n      length -= (customizer ? 1 : 0);\n    }\n    if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n      customizer = length < 3 ? undefined : customizer;\n      length = 1;\n    }\n    while (++index < length) {\n      var source = sources[index];\n      if (source) {\n        assigner(object, source, customizer);\n      }\n    }\n    return object;\n  });\n}\n\nmodule.exports = createAssigner;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/createAssigner.js\n ** module id = 54\n ** module chunks = 0\n **/","var identity = require('../utility/identity');\n\n/**\n * A specialized version of `baseCallback` which only supports `this` binding\n * and specifying the number of arguments to provide to `func`.\n *\n * @private\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {number} [argCount] The number of arguments to provide to `func`.\n * @returns {Function} Returns the callback.\n */\nfunction bindCallback(func, thisArg, argCount) {\n  if (typeof func != 'function') {\n    return identity;\n  }\n  if (thisArg === undefined) {\n    return func;\n  }\n  switch (argCount) {\n    case 1: return function(value) {\n      return func.call(thisArg, value);\n    };\n    case 3: return function(value, index, collection) {\n      return func.call(thisArg, value, index, collection);\n    };\n    case 4: return function(accumulator, value, index, collection) {\n      return func.call(thisArg, accumulator, value, index, collection);\n    };\n    case 5: return function(value, other, key, object, source) {\n      return func.call(thisArg, value, other, key, object, source);\n    };\n  }\n  return function() {\n    return func.apply(thisArg, arguments);\n  };\n}\n\nmodule.exports = bindCallback;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/bindCallback.js\n ** module id = 55\n ** module chunks = 0\n **/","/**\n * This method returns the first argument provided to it.\n *\n * @static\n * @memberOf _\n * @category Utility\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'user': 'fred' };\n *\n * _.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/utility/identity.js\n ** module id = 56\n ** module chunks = 0\n **/","var isArrayLike = require('./isArrayLike'),\n    isIndex = require('./isIndex'),\n    isObject = require('../lang/isObject');\n\n/**\n * Checks if the provided 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, 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    var other = object[index];\n    return value === value ? (value === other) : (other !== other);\n  }\n  return false;\n}\n\nmodule.exports = isIterateeCall;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/internal/isIterateeCall.js\n ** module id = 57\n ** module chunks = 0\n **/","/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as an array.\n *\n * **Note:** This method is based on the [rest parameter](https://developer.mozilla.org/Web/JavaScript/Reference/Functions/rest_parameters).\n *\n * @static\n * @memberOf _\n * @category Function\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 * @example\n *\n * var say = _.restParam(function(what, names) {\n *   return what + ' ' + _.initial(names).join(', ') +\n *     (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\nfunction restParam(func, start) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  start = nativeMax(start === undefined ? (func.length - 1) : (+start || 0), 0);\n  return function() {\n    var args = arguments,\n        index = -1,\n        length = nativeMax(args.length - start, 0),\n        rest = Array(length);\n\n    while (++index < length) {\n      rest[index] = args[start + index];\n    }\n    switch (start) {\n      case 0: return func.call(this, rest);\n      case 1: return func.call(this, args[0], rest);\n      case 2: return func.call(this, args[0], args[1], rest);\n    }\n    var otherArgs = Array(start + 1);\n    index = -1;\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = rest;\n    return func.apply(this, otherArgs);\n  };\n}\n\nmodule.exports = restParam;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/function/restParam.js\n ** module id = 58\n ** module chunks = 0\n **/","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            event.subscribers = subscribers.filter(function(subscriber) {\r\n                publishSubscription(subscriber, data);\r\n                return !subscriber.once;\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 ** D:/work/quaggaJS/src/common/events.js\n **/","const merge = require('lodash/object/merge');\r\n\r\nvar streamRef,\r\n    loadedDataHandler;\r\n\r\n/**\r\n * Wraps browser-specific getUserMedia\r\n * @param {Object} constraints\r\n * @param {Object} success Callback\r\n * @param {Object} failure Callback\r\n */\r\nfunction getUserMedia(constraints, success, failure) {\r\n    if (typeof navigator.getUserMedia !== 'undefined') {\r\n        navigator.getUserMedia(constraints, function (stream) {\r\n            streamRef = stream;\r\n            var videoSrc = (window.URL && window.URL.createObjectURL(stream)) || stream;\r\n            success.apply(null, [videoSrc]);\r\n        }, failure);\r\n    } else {\r\n        failure(new TypeError(\"getUserMedia not available\"));\r\n    }\r\n}\r\n\r\nfunction loadedData(video, callback) {\r\n    var attempts = 10;\r\n\r\n    function checkVideo() {\r\n        if (attempts > 0) {\r\n            if (video.videoWidth > 0 && video.videoHeight > 0) {\r\n                if (ENV.development) {\r\n                    console.log(video.videoWidth + \"px x \" + video.videoHeight + \"px\");\r\n                }\r\n                callback();\r\n            } else {\r\n                window.setTimeout(checkVideo, 500);\r\n            }\r\n        } else {\r\n            callback('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 * 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 * @param {Object} callback\r\n */\r\nfunction initCamera(constraints, video, callback) {\r\n    getUserMedia(constraints, function(src) {\r\n        video.src = src;\r\n        if (loadedDataHandler) {\r\n            video.removeEventListener(\"loadeddata\", loadedDataHandler, false);\r\n        }\r\n        loadedDataHandler = loadedData.bind(null, video, callback);\r\n        video.addEventListener('loadeddata', loadedDataHandler, false);\r\n        video.play();\r\n    }, function(e) {\r\n        callback(e);\r\n    });\r\n}\r\n\r\n/**\r\n * Normalizes the incoming constraints to satisfy the current browser\r\n * @param config\r\n * @param cb Callback which is called whenever constraints are created\r\n * @returns {*}\r\n */\r\nfunction normalizeConstraints(config, cb) {\r\n    var constraints = {\r\n            audio: false,\r\n            video: true\r\n        },\r\n        videoConstraints = merge({\r\n            width: 640,\r\n            height: 480,\r\n            minAspectRatio: 0,\r\n            maxAspectRatio: 100,\r\n            facing: \"environment\"\r\n        }, config);\r\n\r\n    if ( typeof MediaStreamTrack !== 'undefined' && typeof MediaStreamTrack.getSources !== 'undefined') {\r\n        MediaStreamTrack.getSources(function(sourceInfos) {\r\n            var videoSourceId;\r\n            for (var i = 0; i < sourceInfos.length; ++i) {\r\n                var sourceInfo = sourceInfos[i];\r\n                if (sourceInfo.kind === \"video\" && sourceInfo.facing === videoConstraints.facing) {\r\n                    videoSourceId = sourceInfo.id;\r\n                }\r\n            }\r\n            constraints.video = {\r\n                mandatory: {\r\n                    minWidth: videoConstraints.width,\r\n                    minHeight: videoConstraints.height,\r\n                    minAspectRatio: videoConstraints.minAspectRatio,\r\n                    maxAspectRatio: videoConstraints.maxAspectRatio\r\n                },\r\n                optional: [{\r\n                    sourceId: videoSourceId\r\n                }]\r\n            };\r\n            return cb(constraints);\r\n        });\r\n    } else {\r\n        constraints.video = {\r\n            mediaSource: \"camera\",\r\n            width: { min: videoConstraints.width, max: videoConstraints.width },\r\n            height: { min: videoConstraints.height, max: videoConstraints.height },\r\n            require: [\"width\", \"height\"]\r\n        };\r\n        return cb(constraints);\r\n    }\r\n}\r\n\r\n/**\r\n * Requests the back-facing camera of the user. The callback is called\r\n * whenever the stream is ready to be consumed, or if an error occures.\r\n * @param {Object} video\r\n * @param {Object} callback\r\n */\r\nfunction request(video, videoConstraints, callback) {\r\n    normalizeConstraints(videoConstraints, function(constraints) {\r\n        initCamera(constraints, video, callback);\r\n    });\r\n}\r\n\r\nexport default {\r\n    request: function(video, constraints, callback) {\r\n        request(video, constraints, callback);\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};\r\n\n\n\n/** WEBPACK FOOTER **\n ** D:/work/quaggaJS/src/input/camera_access.js\n **/","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 ** D:/work/quaggaJS/src/analytics/result_collector.js\n **/","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 ** D:/work/quaggaJS/src/config/config.js\n **/","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 ** D:/work/quaggaJS/src/config/config.node.js\n **/","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, 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 ** D:/work/quaggaJS/lib/input_stream.js\n **/","module.exports = require(\"get-pixels\");\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external \"get-pixels\"\n ** module id = 65\n ** module chunks = 0\n **/","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 ** D:/work/quaggaJS/lib/frame_grabber.js\n **/","module.exports = require(\"ndarray\");\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external \"ndarray\"\n ** module id = 67\n ** module chunks = 0\n **/","module.exports = require(\"ndarray-linear-interpolate\");\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external \"ndarray-linear-interpolate\"\n ** module id = 68\n ** module chunks = 0\n **/"],"sourceRoot":""} \ No newline at end of file +/******/ ]) +}); +; +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 105c4a383e3cd44f8f38","webpack:///./~/webrtc-adapter/src/js/utils.js","webpack:///./~/lodash/_root.js","webpack:///./~/lodash/isObject.js","webpack:///./~/lodash/_Map.js","webpack:///./~/lodash/isArray.js","webpack:///./src/reader/barcode_reader.js","webpack:///./~/gl-vec2/clone.js","webpack:///./~/lodash/isObjectLike.js","webpack:///./src/common/array_helper.js","webpack:///./src/common/image_debug.js","webpack:///./src/reader/ean_reader.js","webpack:///./~/lodash/_assocIndexOf.js","webpack:///./~/lodash/_getNative.js","webpack:///./~/lodash/_isKeyable.js","webpack:///./~/lodash/_nativeCreate.js","webpack:///./~/lodash/eq.js","webpack:///./~/lodash/isFunction.js","webpack:///./src/common/cv_utils.js","webpack:///./src/common/image_wrapper.js","webpack:///./~/lodash/_arrayReduce.js","webpack:///./~/lodash/_copyObject.js","webpack:///./~/lodash/_isHostObject.js","webpack:///./~/lodash/_isIndex.js","webpack:///./~/lodash/_isPrototype.js","webpack:///./~/lodash/isArguments.js","webpack:///./~/lodash/isArrayLike.js","webpack:///./~/lodash/isArrayLikeObject.js","webpack:///./~/lodash/isLength.js","webpack:///./~/lodash/merge.js","webpack:///./src/locator/tracer.js","webpack:///./src/reader/code_39_reader.js","webpack:///./~/gl-vec2/dot.js","webpack:///./~/lodash/_Stack.js","webpack:///./~/lodash/_arrayEach.js","webpack:///./~/lodash/_assignMergeValue.js","webpack:///./~/lodash/_assignValue.js","webpack:///./~/lodash/_assocDelete.js","webpack:///./~/lodash/_assocGet.js","webpack:///./~/lodash/_assocHas.js","webpack:///./~/lodash/_assocSet.js","webpack:///./~/lodash/_cloneArrayBuffer.js","webpack:///./~/lodash/_copyArray.js","webpack:///./~/lodash/_hashHas.js","webpack:///./~/lodash/_indexKeys.js","webpack:///./~/lodash/isTypedArray.js","webpack:///./~/lodash/keys.js","webpack:///./~/lodash/keysIn.js","webpack:///./~/lodash/rest.js","webpack:///(webpack)/buildin/module.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/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/codabar_reader.js","webpack:///./src/reader/code_128_reader.js","webpack:///./src/reader/code_39_vin_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/_MapCache.js","webpack:///./~/lodash/_Reflect.js","webpack:///./~/lodash/_Set.js","webpack:///./~/lodash/_Symbol.js","webpack:///./~/lodash/_Uint8Array.js","webpack:///./~/lodash/_WeakMap.js","webpack:///./~/lodash/_addMapEntry.js","webpack:///./~/lodash/_addSetEntry.js","webpack:///./~/lodash/_apply.js","webpack:///./~/lodash/_arrayPush.js","webpack:///./~/lodash/_baseAssign.js","webpack:///./~/lodash/_baseClone.js","webpack:///./~/lodash/_baseCreate.js","webpack:///./~/lodash/_baseFlatten.js","webpack:///./~/lodash/_baseFor.js","webpack:///./~/lodash/_baseForOwn.js","webpack:///./~/lodash/_baseHas.js","webpack:///./~/lodash/_baseKeys.js","webpack:///./~/lodash/_baseKeysIn.js","webpack:///./~/lodash/_baseMerge.js","webpack:///./~/lodash/_baseMergeDeep.js","webpack:///./~/lodash/_basePick.js","webpack:///./~/lodash/_baseProperty.js","webpack:///./~/lodash/_baseTimes.js","webpack:///./~/lodash/_checkGlobal.js","webpack:///./~/lodash/_cloneBuffer.js","webpack:///./~/lodash/_cloneMap.js","webpack:///./~/lodash/_cloneRegExp.js","webpack:///./~/lodash/_cloneSet.js","webpack:///./~/lodash/_cloneSymbol.js","webpack:///./~/lodash/_cloneTypedArray.js","webpack:///./~/lodash/_copyObjectWith.js","webpack:///./~/lodash/_copySymbols.js","webpack:///./~/lodash/_createAssigner.js","webpack:///./~/lodash/_createBaseFor.js","webpack:///./~/lodash/_getLength.js","webpack:///./~/lodash/_getSymbols.js","webpack:///./~/lodash/_getTag.js","webpack:///./~/lodash/_hashDelete.js","webpack:///./~/lodash/_hashGet.js","webpack:///./~/lodash/_hashSet.js","webpack:///./~/lodash/_initCloneArray.js","webpack:///./~/lodash/_initCloneByTag.js","webpack:///./~/lodash/_initCloneObject.js","webpack:///./~/lodash/_isIterateeCall.js","webpack:///./~/lodash/_iteratorToArray.js","webpack:///./~/lodash/_mapClear.js","webpack:///./~/lodash/_mapDelete.js","webpack:///./~/lodash/_mapGet.js","webpack:///./~/lodash/_mapHas.js","webpack:///./~/lodash/_mapSet.js","webpack:///./~/lodash/_mapToArray.js","webpack:///./~/lodash/_setToArray.js","webpack:///./~/lodash/_stackClear.js","webpack:///./~/lodash/_stackDelete.js","webpack:///./~/lodash/_stackGet.js","webpack:///./~/lodash/_stackHas.js","webpack:///./~/lodash/_stackSet.js","webpack:///./~/lodash/constant.js","webpack:///./~/lodash/isBuffer.js","webpack:///./~/lodash/isNative.js","webpack:///./~/lodash/isPlainObject.js","webpack:///./~/lodash/isString.js","webpack:///./~/lodash/pick.js","webpack:///./~/lodash/toInteger.js","webpack:///./~/lodash/toNumber.js","webpack:///./~/lodash/toPlainObject.js","webpack:///./~/webrtc-adapter/src/js/adapter_core.js","webpack:///./~/webrtc-adapter/src/js/chrome/chrome_shim.js","webpack:///./~/webrtc-adapter/src/js/chrome/getusermedia.js","webpack:///./~/webrtc-adapter/src/js/edge/edge_sdp.js","webpack:///./~/webrtc-adapter/src/js/edge/edge_shim.js","webpack:///./~/webrtc-adapter/src/js/firefox/firefox_shim.js","webpack:///./~/webrtc-adapter/src/js/firefox/getusermedia.js","webpack:///external \"get-pixels\"","webpack:///external \"ndarray\"","webpack:///external \"ndarray-linear-interpolate\""],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,iBAAS;AACT;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,cAAa,QAAQ;AACrB,cAAa,QAAQ;AACrB,cAAa,QAAQ;AACrB,eAAc,QAAQ;AACtB;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,eAAc,OAAO;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACpGA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA,iBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACNA;AACA;AACA;AACA;A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uB,OAAO,CAAP,CAAvB,CALa;AAMb,cAAK,SAAS,CAAT,GAAa,CAAb,CAAL,GAAuB,GAAvB,CANa;MAAjB;AAQA,SAAI,YAAJ,CAAiB,KAAjB,EAAwB,KAAK,CAAL,EAAQ,KAAK,CAAL,CAAhC,CArB2D;EAA9B;;mBAwBlB,a;;;;;;AC5Vf;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,SAAS;AACpB,YAAW,EAAE;AACb,YAAW,QAAQ;AACnB,cAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,YAAW,OAAO,WAAW;AAC7B,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA,8BAA6B,kBAAkB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1CA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;A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,CAhBmC;AAiBnC,yBAAQ,CAAR,IAAa,CAAb,CAjBmC;AAkBnC,8BAlBmC;cAAvC,MAmBO;AACH,8BADG;cAnBP;AAsBA,qBAAQ,UAAR,IAAsB,CAAtB,CAvBG;AAwBH,uBAAU,CAAC,OAAD,CAxBP;UAFP;MADJ;AA8BA,YAAO,IAAP,CAzC2C;EAAX;;mBA4CrB,a;;;;;;ACtNf;;AAEA;AACA;AACA;AACA,YAAW,KAAK;AAChB,YAAW,KAAK;AAChB,cAAa,OAAO;AACpB;AACA;AACA;AACA,E;;;;;;ACXA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,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,YAAW,MAAM;AACjB,YAAW,SAAS;AACpB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;;;;;;;AC9BA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,YAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,YAAY;AACvB,cAAa,YAAY;AACzB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,WAAW;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvBA;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1EA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;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;;AAEA;;;;;;;ACtDA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;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;;AAEA;;;;;;;ACrDA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA,KAAI;AACJ;AACA;AACA;AACA;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;AACA;AACA;;AAEA;;;;;;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAoB,iBAAiB,EAAE;AACvC,sBAAqB,qBAAqB;AAC1C,IAAG;AACH;AACA;AACA;AACA,qBAAoB,iBAAiB;AACrC,IAAG;AACH;AACA;AACA;AACA,qBAAoB,iBAAiB;AACrC,IAAG;AACH;AACA;AACA;AACA;;;;;;;;;;;;;;;ACzBA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;;;AAEA,KAAM,OAAO;AACT,YAAO,oBAAQ,CAAR,CAAP;EADE;;;AAIN,KAAI,YAAJ;KACI,aADJ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B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,E;;;;;;ACdA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAa,OAAO;AACpB;AACA;;AAEA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACNA;;AAEA;AACA;;AAEA;;;;;;;ACLA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACNA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,YAAW,EAAE;AACb,YAAW,KAAK;AAChB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;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;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;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;AACA,YAAW,EAAE;AACb,YAAW,QAAQ;AACnB,YAAW,QAAQ;AACnB,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA0C;AAC1C;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;;;;;;;AClIA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,YAAW,OAAO;AAClB,YAAW,QAAQ;AACnB,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;;AAEA;;;;;;;AChBA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,aAAa;AACxB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,8CAA6C,eAAe;AAC5D;AACA;AACA;AACA;;AAEA;;;;;;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,YAAW,SAAS;AACpB,YAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjFA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG,IAAI;AACP;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,YAAY;AACzB;AACA;AACA;AACA;;AAEA;;;;;;;ACXA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,QAAQ;AACnB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,QAAQ;AACnB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,YAAW,OAAO,WAAW;AAC7B,YAAW,SAAS;AACpB,cAAa,OAAO;AACpB;AACA;AACA,yBAAwB;;AAExB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO,WAAW;AAC7B,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;ACpCA;AACA;AACA;AACA;AACA,YAAW,QAAQ;AACnB,cAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;;AAEA;;;;;;;ACdA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1DA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,EAAE;AACb;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,MAAM;AACjB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB,YAAW,QAAQ;AACnB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;ACzEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,YAAW,EAAE;AACb,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAG;AACH;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAG;AACH;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAmB;AACnB;;AAEA;;;;;;;ACXA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,cAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,SAAS;AACtB;AACA;AACA,kBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;AC/CA;AACA;AACA;;AAEA;AACA,qCAAoC;;AAEpC;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpDA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,qBAAqB;AAChC;AACA,cAAa,OAAO;AACpB;AACA;AACA,kBAAiB;AACjB;AACA;AACA,WAAU;AACV;AACA;AACA,6BAA4B;AAC5B,EAAC;;AAED;;;;;;;ACzBA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;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;;;;;;;AC3CA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;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;;;;;;;AC1DA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,EAAE;AACb,cAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa,SAAS;AACtB,WAAU;AACV;AACA,cAAa,SAAS;AACtB,WAAU;AACV;AACA;AACA;AACA;;AAEA;;;;;;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAC;;;;;;;AC1ED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,0BAAyB,sBAAsB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA,cAAa;AACb;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA,cAAa;AACb,YAAW;AACX;AACA,QAAO;AACP;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA,UAAS;AACT;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qEAAoE;AACpE;AACA,yEAAwE;AACxE;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA,YAAW;;AAEX;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAiB;AACjB,YAAW;AACX;AACA;AACA,UAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA,QAAO;AACP;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX,UAAS;AACT;AACA;AACA;AACA,MAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAe;AACf;AACA;AACA;AACA;AACA;AACA,gBAAe;AACf;AACA,UAAS;AACT;AACA,MAAK;AACL,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA,MAAK;AACL;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AClPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL;;AAEA;AACA,+BAA8B;AAC9B;AACA;AACA,sBAAqB;AACrB;AACA;AACA,qBAAoB;AACpB;AACA;AACA;AACA,YAAW;AACX,UAAS;AACT,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;AAGA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,kBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAuC;AACvC;AACA,qCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,6CAA4C;AAC5C,wEAAuE;AACvE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qBAAoB;AACpB,2BAA0B;AAC1B;AACA;AACA;AACA,0DAAyD;AACzD,kBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL,kDAAiD;AACjD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,0DAAyD;AACzD;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0DAAyD;AACzD;AACA;AACA;AACA,MAAK;AACL;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAiB,kBAAkB,OAAO;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,6CAA4C;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;;;;;ACjYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,0CAAyC,0BAA0B;AACnE,2CAA0C,2BAA2B;;AAErE;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA,QAAO;AACP;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,cAAa;AACb;AACA;AACA;AACA,UAAS;AACT;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAAyB,qBAAqB;AAC9C;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAuB,sCAAsC;AAC7D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA,wBAAuB,gDAAgD;AACvE;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA2B;;AAE3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,UAAS;AACT;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;;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;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA;AACA,cAAa;AACb;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAiB;AACjB;AACA,YAAW;AACX,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;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;AACA,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA,QAAO;AACP;AACA,QAAO;AACP;AACA,QAAO;AACP;AACA,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;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,YAAW;AACX;AACA;AACA,YAAW;AACX;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,wBAAuB,8BAA8B;AACrD;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;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb,YAAW;AACX;AACA;AACA;AACA;AACA,UAAS;AACT,QAAO;AACP;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACj4BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,0BAAyB,sBAAsB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA,cAAa;AACb,YAAW;AACX;AACA,QAAO;AACP;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA,UAAS;AACT;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA2B,gCAAgC;AAC3D;AACA;AACA,gCAA+B,wBAAwB;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA,kEAAiE;AACjE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA;AACA;AACA,UAAS;AACT;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAwB;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAAyB;AACzB,cAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,QAAO;AACP;;AAEA;AACA;AACA,iCAAgC;AAChC,uCAAsC,EAAE;AACxC,0CAAyC;AACzC;AACA;AACA;AACA;AACA;AACA;AACA,YAAW,gEAAgE;AAC3E,YAAW;AACX;AACA;AACA,QAAO;AACP;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACtOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAuB;AACvB,YAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL;;AAEA;AACA;AACA,+BAA8B;AAC9B,qCAAoC,EAAE;AACtC,wCAAuC;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,UAAS,gEAAgE;AACzE,UAAS;AACT;AACA;AACA,MAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;;;;;;;AChHA,4C;;;;;;ACAA,4C;;;;;;ACAA,4C","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_153__, __WEBPACK_EXTERNAL_MODULE_154__, __WEBPACK_EXTERNAL_MODULE_155__) {\nreturn \n\n\n/** WEBPACK FOOTER **\n ** webpack/universalModuleDefinition\n **/"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].e;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\te: {},\n \t\t\ti: moduleId,\n \t\t\tl: false\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.e, module, module.e, __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.e;\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// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 156);\n\n\n\n/** WEBPACK FOOTER **\n ** webpack/bootstrap 105c4a383e3cd44f8f38\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\nvar logDisabled_ = false;\n\n// Utility methods.\nvar utils = {\n  disableLog: function(bool) {\n    if (typeof bool !== 'boolean') {\n      return new Error('Argument type: ' + typeof bool +\n          '. Please use a boolean.');\n    }\n    logDisabled_ = bool;\n    return (bool) ? 'adapter.js logging disabled' :\n        'adapter.js logging enabled';\n  },\n\n  log: function() {\n    if (typeof window === 'object') {\n      if (logDisabled_) {\n        return;\n      }\n      console.log.apply(console, arguments);\n    }\n  },\n\n   /**\n   * Extract browser version out of the provided user agent string.\n   * @param {!string} uastring userAgent string.\n   * @param {!string} expr Regular expression used as match criteria.\n   * @param {!number} pos position in the version string to be returned.\n   * @return {!number} browser version.\n   */\n  extractVersion: function(uastring, expr, pos) {\n    var match = uastring.match(expr);\n    return match && match.length >= pos && parseInt(match[pos], 10);\n  },\n\n  /**\n   * Browser detector.\n   * @return {object} result containing browser, version and minVersion\n   *     properties.\n   */\n  detectBrowser: function() {\n    // Returned result object.\n    var result = {};\n    result.browser = null;\n    result.version = null;\n    result.minVersion = null;\n\n    if (typeof window === 'undefined' || !window.navigator) {\n      result.browser = 'Not a browser.';\n      return result;\n    } else if (navigator.mozGetUserMedia) {\n      // Firefox.\n      result.browser = 'firefox';\n      result.version = this.extractVersion(navigator.userAgent,\n          /Firefox\\/([0-9]+)\\./, 1);\n      result.minVersion = 31;\n    } else if (navigator.webkitGetUserMedia && window.webkitRTCPeerConnection) {\n      // Chrome, Chromium, WebView, Opera and other WebKit browsers.\n      result.browser = 'chrome';\n      result.version = this.extractVersion(navigator.userAgent,\n          /Chrom(e|ium)\\/([0-9]+)\\./, 2);\n      result.minVersion = 38;\n    } else if(navigator.mediaDevices &&\n        navigator.userAgent.match(/Edge\\/(\\d+).(\\d+)$/)) {\n      // Edge.\n      result.browser = 'edge';\n      result.version = this.extractVersion(navigator.userAgent,\n          /Edge\\/(\\d+).(\\d+)$/, 2);\n      result.minVersion = 10547;\n    } else {\n      result.browser = 'Not a supported browser.';\n      return result;\n    }\n\n    // Warn if version is less than minVersion.\n    if (result.version < result.minVersion) {\n      utils.log('Browser: ' + result.browser + ' Version: ' + result.version +\n          ' < minimum supported version: ' + result.minVersion +\n          '\\n some things might not work!');\n    }\n\n    return result;\n  }\n};\n\n// Export.\nmodule.exports = {\n  log: utils.log,\n  disableLog: utils.disableLog,\n  browserDetails: utils.detectBrowser(),\n  extractVersion: utils.extractVersion\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/utils.js\n ** module id = 0\n ** module chunks = 0\n **/","var checkGlobal = require('./_checkGlobal');\n\n/** Used to determine if values are of the language type `Object`. */\nvar objectTypes = {\n  'function': true,\n  'object': true\n};\n\n/** Detect free variable `exports`. */\nvar freeExports = (objectTypes[typeof exports] && exports && !exports.nodeType)\n  ? exports\n  : undefined;\n\n/** Detect free variable `module`. */\nvar freeModule = (objectTypes[typeof module] && module && !module.nodeType)\n  ? module\n  : undefined;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = checkGlobal(freeExports && freeModule && typeof global == 'object' && global);\n\n/** Detect free variable `self`. */\nvar freeSelf = checkGlobal(objectTypes[typeof self] && self);\n\n/** Detect free variable `window`. */\nvar freeWindow = checkGlobal(objectTypes[typeof window] && window);\n\n/** Detect `this` as the global object. */\nvar thisGlobal = checkGlobal(objectTypes[typeof this] && this);\n\n/**\n * Used as a reference to the global object.\n *\n * The `this` value is used if it's the global object to avoid Greasemonkey's\n * restricted `window` object, otherwise the `window` object is used.\n */\nvar root = freeGlobal ||\n  ((freeWindow !== (thisGlobal && thisGlobal.window)) && freeWindow) ||\n    freeSelf || thisGlobal || Function('return this')();\n\nmodule.exports = root;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_root.js\n ** module id = 1\n ** module chunks = 0\n **/","/**\n * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`.\n * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\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 && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isObject.js\n ** module id = 2\n ** module chunks = 0\n **/","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_Map.js\n ** module id = 3\n ** module chunks = 0\n **/","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @type {Function}\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, 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 = 4\n ** module chunks = 0\n **/","function BarcodeReader(config) {\r\n    this._row = [];\r\n    this.config = config || {};\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) {\r\n    var i,\r\n        error = 0,\r\n        singleError = 0,\r\n        modulo = this.MODULO,\r\n        maxSingleError = this.SINGLE_CODE_ERROR || 1;\r\n\r\n    for (i = 0; i < counter.length; i++) {\r\n        singleError = Math.abs(code[i] - counter[i]);\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._normalize = function(counter, modulo) {\r\n    var i,\r\n        self = this,\r\n        sum = 0,\r\n        ratio,\r\n        numOnes = 0,\r\n        normalized = [],\r\n        norm = 0;\r\n\r\n    if (!modulo) {\r\n        modulo = self.MODULO;\r\n    }\r\n    for (i = 0; i < counter.length; i++) {\r\n        if (counter[i] === 1) {\r\n            numOnes++;\r\n        } else {\r\n            sum += counter[i];\r\n        }\r\n    }\r\n    ratio = sum / (modulo - numOnes);\r\n    if (ratio > 1.0) {\r\n        for (i = 0; i < counter.length; i++) {\r\n            norm = counter[i] === 1 ? counter[i] : counter[i] / ratio;\r\n            normalized.push(norm);\r\n        }\r\n    } else {\r\n        ratio = (sum + numOnes) / modulo;\r\n        for (i = 0; i < counter.length; i++) {\r\n            norm = counter[i] / ratio;\r\n            normalized.push(norm);\r\n        }\r\n    }\r\n    return normalized;\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\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 **/","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 = 6\n ** module chunks = 0\n **/","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @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 && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isObjectLike.js\n ** module id = 7\n ** module chunks = 0\n **/","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\n **/","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\n **/","import BarcodeReader from './barcode_reader';\r\n\r\nfunction EANReader(opts) {\r\n    BarcodeReader.call(this, opts);\r\n}\r\n\r\nvar properties = {\r\n    CODE_L_START: {value: 0},\r\n    MODULO: {value: 7},\r\n    CODE_G_START: {value: 10},\r\n    START_PATTERN: {value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7]},\r\n    STOP_PATTERN: {value: [1 / 3 * 7, 1 / 3 * 7, 1 / 3 * 7]},\r\n    MIDDLE_PATTERN: {value: [1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7, 1 / 5 * 7]},\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.67},\r\n    AVG_CODE_ERROR: {value: 0.27},\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        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = 0; code < coderange; code++) {\r\n                        error = self._matchPattern(normalized, 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                }\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        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    error = self._matchPattern(normalized, 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                }\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\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    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    };\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\nexport default (EANReader);\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/reader/ean_reader.js\n **/","var eq = require('./eq');\n\n/**\n * Gets the index at which the first occurrence of `key` is found in `array`\n * of key-value pairs.\n *\n * @private\n * @param {Array} array The array to search.\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 = 11\n ** module chunks = 0\n **/","var isNative = require('./isNative');\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 = object[key];\n  return isNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_getNative.js\n ** module id = 12\n ** module chunks = 0\n **/","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n  var type = typeof value;\n  return type == 'number' || type == 'boolean' ||\n    (type == 'string' && value != '__proto__') || value == null;\n}\n\nmodule.exports = isKeyable;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_isKeyable.js\n ** module id = 13\n ** module chunks = 0\n **/","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_nativeCreate.js\n ** module id = 14\n ** module chunks = 0\n **/","/**\n * Performs a [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\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 = { 'user': 'fred' };\n * var other = { 'user': 'fred' };\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 = 15\n ** module chunks = 0\n **/","var isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 8 which returns 'object' for typed array and weak map constructors,\n  // and PhantomJS 1.9 which returns 'function' for `NodeList` instances.\n  var tag = isObject(value) ? objectToString.call(value) : '';\n  return tag == funcTag || tag == genTag;\n}\n\nmodule.exports = isFunction;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isFunction.js\n ** module id = 16\n ** module chunks = 0\n **/","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] = Math.floor((\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] = Math.floor(\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\n **/","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\n **/","/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n  var index = -1,\n      length = array.length;\n\n  if (initAccum && length) {\n    accumulator = array[++index];\n  }\n  while (++index < length) {\n    accumulator = iteratee(accumulator, array[index], index, array);\n  }\n  return accumulator;\n}\n\nmodule.exports = arrayReduce;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_arrayReduce.js\n ** module id = 19\n ** module chunks = 0\n **/","var copyObjectWith = require('./_copyObjectWith');\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 names to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object) {\n  return copyObjectWith(source, props, object);\n}\n\nmodule.exports = copyObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_copyObject.js\n ** module id = 20\n ** module chunks = 0\n **/","/**\n * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nfunction isHostObject(value) {\n  // Many host objects are `Object` objects that can coerce to strings\n  // despite having improperly defined `toString` methods.\n  var result = false;\n  if (value != null && typeof value.toString != 'function') {\n    try {\n      result = !!(value + '');\n    } catch (e) {}\n  }\n  return result;\n}\n\nmodule.exports = isHostObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_isHostObject.js\n ** module id = 21\n ** module chunks = 0\n **/","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1;\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return 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 = 22\n ** module chunks = 0\n **/","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\nmodule.exports = isPrototype;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_isPrototype.js\n ** module id = 23\n ** module chunks = 0\n **/","var isArrayLikeObject = require('./isArrayLikeObject');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\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 [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\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 * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nfunction isArguments(value) {\n  // Safari 8.1 incorrectly makes `arguments.callee` enumerable in strict mode.\n  return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&\n    (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);\n}\n\nmodule.exports = isArguments;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isArguments.js\n ** module id = 24\n ** module chunks = 0\n **/","var getLength = require('./_getLength'),\n    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 * @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(getLength(value)) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isArrayLike.js\n ** module id = 25\n ** module chunks = 0\n **/","var isArrayLike = require('./isArrayLike'),\n    isObjectLike = require('./isObjectLike');\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object, 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 = 26\n ** module chunks = 0\n **/","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This function is loosely based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength).\n *\n * @static\n * @memberOf _\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 = 27\n ** module chunks = 0\n **/","var baseMerge = require('./_baseMerge'),\n    createAssigner = require('./_createAssigner');\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable properties of source objects into the destination\n * object. Source properties that resolve to `undefined` are skipped if a\n * destination value exists. Array and plain object properties are merged\n * recursively.Other objects and value types are overridden by assignment.\n * Source objects are applied from left to right. Subsequent sources\n * overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\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 users = {\n *   'data': [{ 'user': 'barney' }, { 'user': 'fred' }]\n * };\n *\n * var ages = {\n *   'data': [{ 'age': 36 }, { 'age': 40 }]\n * };\n *\n * _.merge(users, ages);\n * // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] }\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\n **/","/**\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\n **/","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._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\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\n **/","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 = 31\n ** module chunks = 0\n **/","var 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} [values] The values to cache.\n */\nfunction Stack(values) {\n  var index = -1,\n      length = values ? values.length : 0;\n\n  this.clear();\n  while (++index < length) {\n    var entry = values[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add functions to the `Stack` cache.\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 = 32\n ** module chunks = 0\n **/","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee 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 `array`.\n */\nfunction arrayEach(array, iteratee) {\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    if (iteratee(array[index], index, array) === false) {\n      break;\n    }\n  }\n  return array;\n}\n\nmodule.exports = arrayEach;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_arrayEach.js\n ** module id = 33\n ** module chunks = 0\n **/","var 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      (typeof key == 'number' && value === undefined && !(key in object))) {\n    object[key] = value;\n  }\n}\n\nmodule.exports = assignMergeValue;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assignMergeValue.js\n ** module id = 34\n ** module chunks = 0\n **/","var 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/6.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    object[key] = value;\n  }\n}\n\nmodule.exports = assignValue;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assignValue.js\n ** module id = 35\n ** module chunks = 0\n **/","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the associative array.\n *\n * @private\n * @param {Array} array The array to query.\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 assocDelete(array, key) {\n  var index = assocIndexOf(array, key);\n  if (index < 0) {\n    return false;\n  }\n  var lastIndex = array.length - 1;\n  if (index == lastIndex) {\n    array.pop();\n  } else {\n    splice.call(array, index, 1);\n  }\n  return true;\n}\n\nmodule.exports = assocDelete;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assocDelete.js\n ** module id = 36\n ** module chunks = 0\n **/","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the associative array value for `key`.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction assocGet(array, key) {\n  var index = assocIndexOf(array, key);\n  return index < 0 ? undefined : array[index][1];\n}\n\nmodule.exports = assocGet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assocGet.js\n ** module id = 37\n ** module chunks = 0\n **/","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if an associative array value for `key` exists.\n *\n * @private\n * @param {Array} array The array to query.\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 assocHas(array, key) {\n  return assocIndexOf(array, key) > -1;\n}\n\nmodule.exports = assocHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assocHas.js\n ** module id = 38\n ** module chunks = 0\n **/","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the associative array `key` to `value`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n */\nfunction assocSet(array, key, value) {\n  var index = assocIndexOf(array, key);\n  if (index < 0) {\n    array.push([key, value]);\n  } else {\n    array[index][1] = value;\n  }\n}\n\nmodule.exports = assocSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_assocSet.js\n ** module id = 39\n ** module chunks = 0\n **/","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n  new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n  return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneArrayBuffer.js\n ** module id = 40\n ** module chunks = 0\n **/","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n  var index = -1,\n      length = source.length;\n\n  array || (array = Array(length));\n  while (++index < length) {\n    array[index] = source[index];\n  }\n  return array;\n}\n\nmodule.exports = copyArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_copyArray.js\n ** module id = 41\n ** module chunks = 0\n **/","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @param {Object} hash The hash to query.\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(hash, key) {\n  return nativeCreate ? hash[key] !== undefined : hasOwnProperty.call(hash, key);\n}\n\nmodule.exports = hashHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_hashHas.js\n ** module id = 42\n ** module chunks = 0\n **/","var baseTimes = require('./_baseTimes'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isLength = require('./isLength'),\n    isString = require('./isString');\n\n/**\n * Creates an array of index keys for `object` values of arrays,\n * `arguments` objects, and strings, otherwise `null` is returned.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array|null} Returns index keys, else `null`.\n */\nfunction indexKeys(object) {\n  var length = object ? object.length : undefined;\n  if (isLength(length) &&\n      (isArray(object) || isString(object) || isArguments(object))) {\n    return baseTimes(length, String);\n  }\n  return null;\n}\n\nmodule.exports = indexKeys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_indexKeys.js\n ** module id = 43\n ** module chunks = 0\n **/","var 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    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[dateTag] = typedArrayTags[errorTag] =\ntypedArrayTags[funcTag] = typedArrayTags[mapTag] =\ntypedArrayTags[numberTag] = typedArrayTags[objectTag] =\ntypedArrayTags[regexpTag] = typedArrayTags[setTag] =\ntypedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nfunction isTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[objectToString.call(value)];\n}\n\nmodule.exports = isTypedArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isTypedArray.js\n ** module id = 44\n ** module chunks = 0\n **/","var baseHas = require('./_baseHas'),\n    baseKeys = require('./_baseKeys'),\n    indexKeys = require('./_indexKeys'),\n    isArrayLike = require('./isArrayLike'),\n    isIndex = require('./_isIndex'),\n    isPrototype = require('./_isPrototype');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @memberOf _\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 * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n  var isProto = isPrototype(object);\n  if (!(isProto || isArrayLike(object))) {\n    return baseKeys(object);\n  }\n  var indexes = indexKeys(object),\n      skipIndexes = !!indexes,\n      result = indexes || [],\n      length = result.length;\n\n  for (var key in object) {\n    if (baseHas(object, key) &&\n        !(skipIndexes && (key == 'length' || isIndex(key, length))) &&\n        !(isProto && key == 'constructor')) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = keys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/keys.js\n ** module id = 45\n ** module chunks = 0\n **/","var baseKeysIn = require('./_baseKeysIn'),\n    indexKeys = require('./_indexKeys'),\n    isIndex = require('./_isIndex'),\n    isPrototype = require('./_isPrototype');\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 own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\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  var index = -1,\n      isProto = isPrototype(object),\n      props = baseKeysIn(object),\n      propsLength = props.length,\n      indexes = indexKeys(object),\n      skipIndexes = !!indexes,\n      result = indexes || [],\n      length = result.length;\n\n  while (++index < propsLength) {\n    var key = props[index];\n    if (!(skipIndexes && (key == 'length' || isIndex(key, length))) &&\n        !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = keysIn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/keysIn.js\n ** module id = 46\n ** module chunks = 0\n **/","var apply = require('./_apply'),\n    toInteger = require('./toInteger');\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as an array.\n *\n * **Note:** This method is based on the [rest parameter](https://mdn.io/rest_parameters).\n *\n * @static\n * @memberOf _\n * @category Function\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 * @example\n *\n * var say = _.rest(function(what, names) {\n *   return what + ' ' + _.initial(names).join(', ') +\n *     (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\nfunction rest(func, start) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  start = nativeMax(start === undefined ? (func.length - 1) : toInteger(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    switch (start) {\n      case 0: return func.call(this, array);\n      case 1: return func.call(this, args[0], array);\n      case 2: return func.call(this, args[0], args[1], array);\n    }\n    var otherArgs = Array(start + 1);\n    index = -1;\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = array;\n    return apply(func, this, otherArgs);\n  };\n}\n\nmodule.exports = rest;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/rest.js\n ** module id = 47\n ** module chunks = 0\n **/","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\tmodule.children = [];\r\n\t\tObject.defineProperty(module, \"exports\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tconfigurable: false,\r\n\t\t\tget: function() { return module.e; },\r\n\t\t\tset: function(v) { return module.e = v; }\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tconfigurable: false,\r\n\t\t\tget: function() { return module.l; }\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tconfigurable: false,\r\n\t\t\tget: function() { return module.i; }\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 = 48\n ** module chunks = 0\n **/","import TypeDefs from './common/typedefs'; // eslint-disable-line no-unused-vars\r\nimport WebrtcAdapter from 'webrtc-adapter'; // 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.setAttribute(\"autoplay\", true);\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    const resultToPublish = result && (result.barcodes || result);\r\n\r\n    if (result && _onUIThread) {\r\n        transformResult(result);\r\n        addResult(result, imageData);\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: _config\r\n    }, [workerThread.imageData.buffer]);\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};\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/quagga.js\n **/","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\n **/","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, 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\n **/","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\n **/","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\n **/","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            event.subscribers = subscribers.filter(function(subscriber) {\r\n                publishSubscription(subscriber, data);\r\n                return !subscriber.once;\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\n **/","/**\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\n **/","/*\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\n\n\n/** WEBPACK FOOTER **\n ** ./src/common/typedefs.js\n **/","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\n **/","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\n **/","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 UPCEReader from '../reader/upc_e_reader';\r\nimport I2of5Reader from '../reader/i2of5_reader';\r\n\r\nconst READERS = {\r\n    code_128_reader: Code128Reader,\r\n    ean_reader: EANReader,\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};\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\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                _barcodeReaders.push(new READERS[reader](configuration));\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\n **/","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\n **/","import {merge, pick} from 'lodash';\r\n\r\nvar streamRef,\r\n    loadedDataHandler;\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 > 0 && video.videoHeight > 0) {\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 navigator.mediaDevices.getUserMedia(constraints)\r\n    .then((stream) => {\r\n        return new Promise((resolve, reject) => {\r\n            streamRef = stream;\r\n            video.src = window.URL.createObjectURL(stream);\r\n            video.onloadedmetadata = (e) => {\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\nfunction applyCameraFacing(facing, constraints) {\r\n    if (typeof constraints.video.deviceId !== 'undefined' || !facing){\r\n        return Promise.resolve(constraints);\r\n    }\r\n    if ( typeof MediaStreamTrack !== 'undefined' &&\r\n            typeof MediaStreamTrack.getSources !== 'undefined') {\r\n        return new Promise((resolve, reject) => {\r\n            MediaStreamTrack.getSources((sourceInfos) => {\r\n                const videoSource = sourceInfos.filter((sourceInfo) => (\r\n                    sourceInfo.kind === \"video\" && sourceInfo.facing === facing\r\n                ))[0];\r\n                if (videoSource) {\r\n                    return resolve(merge({}, constraints,\r\n                        {video: {deviceId: videoSource.id}}));\r\n                }\r\n                return resolve(constraints);\r\n            });\r\n        });\r\n    }\r\n    return Promise.resolve(merge({}, constraints, {video: {facingMode: facing}}));\r\n}\r\n\r\nfunction pickConstraints(videoConstraints) {\r\n    const constraints = {\r\n        audio: false,\r\n        video: deprecatedConstraints(videoConstraints)\r\n    };\r\n    return applyCameraFacing(constraints.video.facingMode, constraints);\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};\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/input/camera_access.js\n **/","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 (_config.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\n **/","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\n **/","/* @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\n **/","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\n **/","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    MODULO: {value: 11},\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: 1},\r\n    AVG_CODE_ERROR: {value: 0.5},\r\n    FORMAT: {value: \"code_128\", writeable: false}\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) {\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        },\r\n        code,\r\n        error,\r\n        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n                        error = self._matchPattern(normalized, 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                    return bestMatch;\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\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        },\r\n        code,\r\n        error,\r\n        j,\r\n        sum,\r\n        normalized;\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) {\r\n                        error = self._matchPattern(normalized, 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                        return bestMatch;\r\n                    }\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    };\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);\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\nexport default Code128Reader;\r\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/reader/code_128_reader.js\n **/","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\n **/","import EANReader from './ean_reader';\r\n\r\nfunction EAN8Reader() {\r\n    EANReader.call(this);\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\n **/","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        MODULO: {value: 10},\r\n        START_PATTERN: {value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5]},\r\n        STOP_PATTERN: {value: [N * 2, N * 2, W * 2]},\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                normalized = self._normalize(counter);\r\n                if (normalized) {\r\n                    error = self._matchPattern(normalized, 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                }\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    normalized = self._normalize(counter);\r\n    if (normalized) {\r\n        for (code = 0; code < self.CODE_PATTERN.length; code++) {\r\n            error = self._matchPattern(normalized, 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    return null;\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\n **/","import EANReader from './ean_reader';\r\n\r\nfunction UPCEReader() {\r\n    EANReader.call(this);\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\n **/","import EANReader from './ean_reader';\r\n\r\nfunction UPCReader() {\r\n    EANReader.call(this);\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\n **/","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 = 72\n ** module chunks = 0\n **/","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 = 73\n ** module chunks = 0\n **/","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 = 74\n ** module chunks = 0\n **/","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 = 75\n ** module chunks = 0\n **/","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 = 76\n ** module chunks = 0\n **/","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 = 77\n ** module chunks = 0\n **/","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Creates an hash object.\n *\n * @private\n * @constructor\n * @returns {Object} Returns the new hash object.\n */\nfunction Hash() {}\n\n// Avoid inheriting from `Object.prototype` when possible.\nHash.prototype = nativeCreate ? nativeCreate(null) : objectProto;\n\nmodule.exports = Hash;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_Hash.js\n ** module id = 78\n ** module chunks = 0\n **/","var mapClear = require('./_mapClear'),\n    mapDelete = require('./_mapDelete'),\n    mapGet = require('./_mapGet'),\n    mapHas = require('./_mapHas'),\n    mapSet = require('./_mapSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction MapCache(values) {\n  var index = -1,\n      length = values ? values.length : 0;\n\n  this.clear();\n  while (++index < length) {\n    var entry = values[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add functions to the `MapCache`.\nMapCache.prototype.clear = mapClear;\nMapCache.prototype['delete'] = mapDelete;\nMapCache.prototype.get = mapGet;\nMapCache.prototype.has = mapHas;\nMapCache.prototype.set = mapSet;\n\nmodule.exports = MapCache;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_MapCache.js\n ** module id = 79\n ** module chunks = 0\n **/","var root = require('./_root');\n\n/** Built-in value references. */\nvar Reflect = root.Reflect;\n\nmodule.exports = Reflect;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_Reflect.js\n ** module id = 80\n ** module chunks = 0\n **/","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_Set.js\n ** module id = 81\n ** module chunks = 0\n **/","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 = 82\n ** module chunks = 0\n **/","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 = 83\n ** module chunks = 0\n **/","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_WeakMap.js\n ** module id = 84\n ** module chunks = 0\n **/","/**\n * Adds the key-value `pair` to `map`.\n *\n * @private\n * @param {Object} map The map to modify.\n * @param {Array} pair The key-value pair to add.\n * @returns {Object} Returns `map`.\n */\nfunction addMapEntry(map, pair) {\n  // Don't return `Map#set` because it doesn't return the map instance in IE 11.\n  map.set(pair[0], pair[1]);\n  return map;\n}\n\nmodule.exports = addMapEntry;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_addMapEntry.js\n ** module id = 85\n ** module chunks = 0\n **/","/**\n * Adds `value` to `set`.\n *\n * @private\n * @param {Object} set The set to modify.\n * @param {*} value The value to add.\n * @returns {Object} Returns `set`.\n */\nfunction addSetEntry(set, value) {\n  set.add(value);\n  return set;\n}\n\nmodule.exports = addSetEntry;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_addSetEntry.js\n ** module id = 86\n ** module chunks = 0\n **/","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {...*} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n  var length = args.length;\n  switch (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 = 87\n ** module chunks = 0\n **/","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n  var index = -1,\n      length = values.length,\n      offset = array.length;\n\n  while (++index < length) {\n    array[offset + index] = values[index];\n  }\n  return array;\n}\n\nmodule.exports = arrayPush;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_arrayPush.js\n ** module id = 88\n ** module chunks = 0\n **/","var copyObject = require('./_copyObject'),\n    keys = require('./keys');\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n  return object && copyObject(source, keys(source), object);\n}\n\nmodule.exports = baseAssign;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseAssign.js\n ** module id = 89\n ** module chunks = 0\n **/","var Stack = require('./_Stack'),\n    arrayEach = require('./_arrayEach'),\n    assignValue = require('./_assignValue'),\n    baseAssign = require('./_baseAssign'),\n    baseForOwn = require('./_baseForOwn'),\n    cloneBuffer = require('./_cloneBuffer'),\n    copyArray = require('./_copyArray'),\n    copySymbols = require('./_copySymbols'),\n    getTag = require('./_getTag'),\n    initCloneArray = require('./_initCloneArray'),\n    initCloneByTag = require('./_initCloneByTag'),\n    initCloneObject = require('./_initCloneObject'),\n    isArray = require('./isArray'),\n    isBuffer = require('./isBuffer'),\n    isHostObject = require('./_isHostObject'),\n    isObject = require('./isObject');\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    genTag = '[object GeneratorFunction]',\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    symbolTag = '[object Symbol]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\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 supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[boolTag] =\ncloneableTags[dateTag] = cloneableTags[float32Tag] =\ncloneableTags[float64Tag] = cloneableTags[int8Tag] =\ncloneableTags[int16Tag] = cloneableTags[int32Tag] =\ncloneableTags[mapTag] = cloneableTags[numberTag] =\ncloneableTags[objectTag] = cloneableTags[regexpTag] =\ncloneableTags[setTag] = cloneableTags[stringTag] =\ncloneableTags[symbolTag] = cloneableTags[uint8Tag] =\ncloneableTags[uint8ClampedTag] = cloneableTags[uint16Tag] =\ncloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @param {boolean} [isFull] Specify a clone including symbols.\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, isDeep, isFull, customizer, key, object, stack) {\n  var result;\n  if (customizer) {\n    result = object ? customizer(value, key, object, stack) : customizer(value);\n  }\n  if (result !== undefined) {\n    return result;\n  }\n  if (!isObject(value)) {\n    return value;\n  }\n  var isArr = isArray(value);\n  if (isArr) {\n    result = initCloneArray(value);\n    if (!isDeep) {\n      return copyArray(value, result);\n    }\n  } else {\n    var tag = getTag(value),\n        isFunc = tag == funcTag || tag == genTag;\n\n    if (isBuffer(value)) {\n      return cloneBuffer(value, isDeep);\n    }\n    if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n      if (isHostObject(value)) {\n        return object ? value : {};\n      }\n      result = initCloneObject(isFunc ? {} : value);\n      if (!isDeep) {\n        result = baseAssign(result, value);\n        return isFull ? copySymbols(value, result) : result;\n      }\n    } else {\n      if (!cloneableTags[tag]) {\n        return object ? value : {};\n      }\n      result = initCloneByTag(value, tag, isDeep);\n    }\n  }\n  // Check for circular references and return its corresponding clone.\n  stack || (stack = new Stack);\n  var stacked = stack.get(value);\n  if (stacked) {\n    return stacked;\n  }\n  stack.set(value, result);\n\n  // Recursively populate clone (susceptible to call stack limits).\n  (isArr ? arrayEach : baseForOwn)(value, function(subValue, key) {\n    assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack));\n  });\n  return (isFull && !isArr) ? copySymbols(value, result) : result;\n}\n\nmodule.exports = baseClone;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseClone.js\n ** module id = 90\n ** module chunks = 0\n **/","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} prototype The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nfunction baseCreate(proto) {\n  return isObject(proto) ? objectCreate(proto) : {};\n}\n\nmodule.exports = baseCreate;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseCreate.js\n ** module id = 91\n ** module chunks = 0\n **/","var arrayPush = require('./_arrayPush'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isArrayLikeObject = require('./isArrayLikeObject');\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} [isStrict] Restrict flattening to arrays-like objects.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, isStrict, result) {\n  result || (result = []);\n\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    var value = array[index];\n    if (depth > 0 && isArrayLikeObject(value) &&\n        (isStrict || isArray(value) || isArguments(value))) {\n      if (depth > 1) {\n        // Recursively flatten arrays (susceptible to call stack limits).\n        baseFlatten(value, depth - 1, 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 = 92\n ** module chunks = 0\n **/","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForIn` and `baseForOwn` which iterates\n * over `object` properties returned by `keysFunc` invoking `iteratee` for\n * each property. Iteratee functions may exit iteration early by explicitly\n * 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 = 93\n ** module chunks = 0\n **/","var baseFor = require('./_baseFor'),\n    keys = require('./keys');\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n  return object && baseFor(object, iteratee, keys);\n}\n\nmodule.exports = baseForOwn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseForOwn.js\n ** module id = 94\n ** module chunks = 0\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 getPrototypeOf = Object.getPrototypeOf;\n\n/**\n * The base implementation of `_.has` 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 baseHas(object, key) {\n  // Avoid a bug in IE 10-11 where objects with a [[Prototype]] of `null`,\n  // that are composed entirely of index properties, return `false` for\n  // `hasOwnProperty` checks of them.\n  return hasOwnProperty.call(object, key) ||\n    (typeof object == 'object' && key in object && getPrototypeOf(object) === null);\n}\n\nmodule.exports = baseHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseHas.js\n ** module id = 95\n ** module chunks = 0\n **/","/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = Object.keys;\n\n/**\n * The base implementation of `_.keys` which doesn't skip the constructor\n * property of prototypes or 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 baseKeys(object) {\n  return nativeKeys(Object(object));\n}\n\nmodule.exports = baseKeys;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseKeys.js\n ** module id = 96\n ** module chunks = 0\n **/","var Reflect = require('./_Reflect'),\n    iteratorToArray = require('./_iteratorToArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar enumerate = Reflect ? Reflect.enumerate : undefined,\n    propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * The base implementation of `_.keysIn` which doesn't skip the constructor\n * property of prototypes or 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  object = object == null ? object : Object(object);\n\n  var result = [];\n  for (var key in object) {\n    result.push(key);\n  }\n  return result;\n}\n\n// Fallback for IE < 9 with es6-shim.\nif (enumerate && !propertyIsEnumerable.call({ 'valueOf': 1 }, 'valueOf')) {\n  baseKeysIn = function(object) {\n    return iteratorToArray(enumerate(object));\n  };\n}\n\nmodule.exports = baseKeysIn;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseKeysIn.js\n ** module id = 97\n ** module chunks = 0\n **/","var Stack = require('./_Stack'),\n    arrayEach = require('./_arrayEach'),\n    assignMergeValue = require('./_assignMergeValue'),\n    baseMergeDeep = require('./_baseMergeDeep'),\n    isArray = require('./isArray'),\n    isObject = require('./isObject'),\n    isTypedArray = require('./isTypedArray'),\n    keysIn = require('./keysIn');\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 counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n  if (object === source) {\n    return;\n  }\n  var props = (isArray(source) || isTypedArray(source))\n    ? undefined\n    : keysIn(source);\n\n  arrayEach(props || source, function(srcValue, key) {\n    if (props) {\n      key = srcValue;\n      srcValue = source[key];\n    }\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(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  });\n}\n\nmodule.exports = baseMerge;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseMerge.js\n ** module id = 98\n ** module chunks = 0\n **/","var assignMergeValue = require('./_assignMergeValue'),\n    baseClone = require('./_baseClone'),\n    copyArray = require('./_copyArray'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isArrayLikeObject = require('./isArrayLikeObject'),\n    isFunction = require('./isFunction'),\n    isObject = require('./isObject'),\n    isPlainObject = require('./isPlainObject'),\n    isTypedArray = require('./isTypedArray'),\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 counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n  var objValue = object[key],\n      srcValue = 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    newValue = srcValue;\n    if (isArray(srcValue) || isTypedArray(srcValue)) {\n      if (isArray(objValue)) {\n        newValue = objValue;\n      }\n      else if (isArrayLikeObject(objValue)) {\n        newValue = copyArray(objValue);\n      }\n      else {\n        isCommon = false;\n        newValue = baseClone(srcValue, !customizer);\n      }\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      if (isArguments(objValue)) {\n        newValue = toPlainObject(objValue);\n      }\n      else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) {\n        isCommon = false;\n        newValue = baseClone(srcValue, !customizer);\n      }\n      else {\n        newValue = objValue;\n      }\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  stack.set(srcValue, newValue);\n\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n  }\n  stack['delete'](srcValue);\n  assignMergeValue(object, key, newValue);\n}\n\nmodule.exports = baseMergeDeep;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseMergeDeep.js\n ** module id = 99\n ** module chunks = 0\n **/","var arrayReduce = require('./_arrayReduce');\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property names.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} props The property names to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, props) {\n  object = Object(object);\n  return arrayReduce(props, function(result, key) {\n    if (key in object) {\n      result[key] = object[key];\n    }\n    return result;\n  }, {});\n}\n\nmodule.exports = basePick;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_basePick.js\n ** module id = 100\n ** module chunks = 0\n **/","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new function.\n */\nfunction baseProperty(key) {\n  return function(object) {\n    return object == null ? undefined : object[key];\n  };\n}\n\nmodule.exports = baseProperty;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseProperty.js\n ** module id = 101\n ** module chunks = 0\n **/","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n  var index = -1,\n      result = Array(n);\n\n  while (++index < n) {\n    result[index] = iteratee(index);\n  }\n  return result;\n}\n\nmodule.exports = baseTimes;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_baseTimes.js\n ** module id = 102\n ** module chunks = 0\n **/","/**\n * Checks if `value` is a global object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {null|Object} Returns `value` if it's a global object, else `null`.\n */\nfunction checkGlobal(value) {\n  return (value && value.Object === Object) ? value : null;\n}\n\nmodule.exports = checkGlobal;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_checkGlobal.js\n ** module id = 103\n ** module chunks = 0\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 result = new buffer.constructor(buffer.length);\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 = 104\n ** module chunks = 0\n **/","var addMapEntry = require('./_addMapEntry'),\n    arrayReduce = require('./_arrayReduce'),\n    mapToArray = require('./_mapToArray');\n\n/**\n * Creates a clone of `map`.\n *\n * @private\n * @param {Object} map The map to clone.\n * @returns {Object} Returns the cloned map.\n */\nfunction cloneMap(map) {\n  return arrayReduce(mapToArray(map), addMapEntry, new map.constructor);\n}\n\nmodule.exports = cloneMap;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneMap.js\n ** module id = 105\n ** module chunks = 0\n **/","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n  var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n  result.lastIndex = regexp.lastIndex;\n  return result;\n}\n\nmodule.exports = cloneRegExp;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneRegExp.js\n ** module id = 106\n ** module chunks = 0\n **/","var addSetEntry = require('./_addSetEntry'),\n    arrayReduce = require('./_arrayReduce'),\n    setToArray = require('./_setToArray');\n\n/**\n * Creates a clone of `set`.\n *\n * @private\n * @param {Object} set The set to clone.\n * @returns {Object} Returns the cloned set.\n */\nfunction cloneSet(set) {\n  return arrayReduce(setToArray(set), addSetEntry, new set.constructor);\n}\n\nmodule.exports = cloneSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneSet.js\n ** module id = 107\n ** module chunks = 0\n **/","var Symbol = require('./_Symbol');\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n  return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nmodule.exports = cloneSymbol;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneSymbol.js\n ** module id = 108\n ** module chunks = 0\n **/","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_cloneTypedArray.js\n ** module id = 109\n ** module chunks = 0\n **/","var assignValue = require('./_assignValue');\n\n/**\n * This function is like `copyObject` except that it accepts a function to\n * customize copied values.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property names 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 copyObjectWith(source, props, object, customizer) {\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      : source[key];\n\n    assignValue(object, key, newValue);\n  }\n  return object;\n}\n\nmodule.exports = copyObjectWith;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_copyObjectWith.js\n ** module id = 110\n ** module chunks = 0\n **/","var copyObject = require('./_copyObject'),\n    getSymbols = require('./_getSymbols');\n\n/**\n * Copies own symbol properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n  return copyObject(source, getSymbols(source), object);\n}\n\nmodule.exports = copySymbols;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_copySymbols.js\n ** module id = 111\n ** module chunks = 0\n **/","var isIterateeCall = require('./_isIterateeCall'),\n    rest = require('./rest');\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 rest(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 = 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 = 112\n ** module chunks = 0\n **/","/**\n * Creates a base function for methods like `_.forIn`.\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 = 113\n ** module chunks = 0\n **/","var baseProperty = require('./_baseProperty');\n\n/**\n * Gets the \"length\" property value of `object`.\n *\n * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792)\n * that affects Safari on at least iOS 8.1-8.3 ARM64.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {*} Returns the \"length\" value.\n */\nvar getLength = baseProperty('length');\n\nmodule.exports = getLength;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_getLength.js\n ** module id = 114\n ** module chunks = 0\n **/","/** Built-in value references. */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own symbol properties of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = getOwnPropertySymbols || function() {\n  return [];\n};\n\nmodule.exports = getSymbols;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_getSymbols.js\n ** module id = 115\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    Set = require('./_Set'),\n    WeakMap = require('./_WeakMap');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    objectTag = '[object Object]',\n    setTag = '[object Set]',\n    weakMapTag = '[object WeakMap]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = Function.prototype.toString;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Used to detect maps, sets, and weakmaps. */\nvar mapCtorString = Map ? funcToString.call(Map) : '',\n    setCtorString = Set ? funcToString.call(Set) : '',\n    weakMapCtorString = WeakMap ? funcToString.call(WeakMap) : '';\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction getTag(value) {\n  return objectToString.call(value);\n}\n\n// Fallback for IE 11 providing `toStringTag` values for maps, sets, and weakmaps.\nif ((Map && getTag(new Map) != mapTag) ||\n    (Set && getTag(new Set) != setTag) ||\n    (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n  getTag = function(value) {\n    var result = objectToString.call(value),\n        Ctor = result == objectTag ? value.constructor : null,\n        ctorString = typeof Ctor == 'function' ? funcToString.call(Ctor) : '';\n\n    if (ctorString) {\n      switch (ctorString) {\n        case mapCtorString: return mapTag;\n        case setCtorString: return setTag;\n        case weakMapCtorString: return weakMapTag;\n      }\n    }\n    return result;\n  };\n}\n\nmodule.exports = getTag;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_getTag.js\n ** module id = 116\n ** module chunks = 0\n **/","var hashHas = require('./_hashHas');\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\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(hash, key) {\n  return hashHas(hash, key) && delete hash[key];\n}\n\nmodule.exports = hashDelete;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_hashDelete.js\n ** module id = 117\n ** module chunks = 0\n **/","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @param {Object} hash The hash to query.\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(hash, key) {\n  if (nativeCreate) {\n    var result = hash[key];\n    return result === HASH_UNDEFINED ? undefined : result;\n  }\n  return hasOwnProperty.call(hash, key) ? hash[key] : undefined;\n}\n\nmodule.exports = hashGet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_hashGet.js\n ** module id = 118\n ** module chunks = 0\n **/","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n */\nfunction hashSet(hash, key, value) {\n  hash[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n}\n\nmodule.exports = hashSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_hashSet.js\n ** module id = 119\n ** module chunks = 0\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 * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n  var length = array.length,\n      result = array.constructor(length);\n\n  // Add properties assigned by `RegExp#exec`.\n  if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n    result.index = array.index;\n    result.input = array.input;\n  }\n  return result;\n}\n\nmodule.exports = initCloneArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_initCloneArray.js\n ** module id = 120\n ** module chunks = 0\n **/","var cloneArrayBuffer = require('./_cloneArrayBuffer'),\n    cloneMap = require('./_cloneMap'),\n    cloneRegExp = require('./_cloneRegExp'),\n    cloneSet = require('./_cloneSet'),\n    cloneSymbol = require('./_cloneSymbol'),\n    cloneTypedArray = require('./_cloneTypedArray');\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\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/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n  var Ctor = object.constructor;\n  switch (tag) {\n    case arrayBufferTag:\n      return cloneArrayBuffer(object);\n\n    case boolTag:\n    case dateTag:\n      return new Ctor(+object);\n\n    case float32Tag: case float64Tag:\n    case int8Tag: case int16Tag: case int32Tag:\n    case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n      return cloneTypedArray(object, isDeep);\n\n    case mapTag:\n      return cloneMap(object);\n\n    case numberTag:\n    case stringTag:\n      return new Ctor(object);\n\n    case regexpTag:\n      return cloneRegExp(object);\n\n    case setTag:\n      return cloneSet(object);\n\n    case symbolTag:\n      return cloneSymbol(object);\n  }\n}\n\nmodule.exports = initCloneByTag;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_initCloneByTag.js\n ** module id = 121\n ** module chunks = 0\n **/","var baseCreate = require('./_baseCreate'),\n    isPrototype = require('./_isPrototype');\n\n/** Built-in value references. */\nvar getPrototypeOf = Object.getPrototypeOf;\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(getPrototypeOf(object))\n    : {};\n}\n\nmodule.exports = initCloneObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_initCloneObject.js\n ** module id = 122\n ** module chunks = 0\n **/","var eq = require('./eq'),\n    isArrayLike = require('./isArrayLike'),\n    isIndex = require('./_isIndex'),\n    isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call, 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    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 = 123\n ** module chunks = 0\n **/","/**\n * Converts `iterator` to an array.\n *\n * @private\n * @param {Object} iterator The iterator to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction iteratorToArray(iterator) {\n  var data,\n      result = [];\n\n  while (!(data = iterator.next()).done) {\n    result.push(data.value);\n  }\n  return result;\n}\n\nmodule.exports = iteratorToArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_iteratorToArray.js\n ** module id = 124\n ** module chunks = 0\n **/","var Hash = require('./_Hash'),\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 mapClear() {\n  this.__data__ = {\n    'hash': new Hash,\n    'map': Map ? new Map : [],\n    'string': new Hash\n  };\n}\n\nmodule.exports = mapClear;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapClear.js\n ** module id = 125\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    assocDelete = require('./_assocDelete'),\n    hashDelete = require('./_hashDelete'),\n    isKeyable = require('./_isKeyable');\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 mapDelete(key) {\n  var data = this.__data__;\n  if (isKeyable(key)) {\n    return hashDelete(typeof key == 'string' ? data.string : data.hash, key);\n  }\n  return Map ? data.map['delete'](key) : assocDelete(data.map, key);\n}\n\nmodule.exports = mapDelete;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapDelete.js\n ** module id = 126\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    assocGet = require('./_assocGet'),\n    hashGet = require('./_hashGet'),\n    isKeyable = require('./_isKeyable');\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 mapGet(key) {\n  var data = this.__data__;\n  if (isKeyable(key)) {\n    return hashGet(typeof key == 'string' ? data.string : data.hash, key);\n  }\n  return Map ? data.map.get(key) : assocGet(data.map, key);\n}\n\nmodule.exports = mapGet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapGet.js\n ** module id = 127\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    assocHas = require('./_assocHas'),\n    hashHas = require('./_hashHas'),\n    isKeyable = require('./_isKeyable');\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 mapHas(key) {\n  var data = this.__data__;\n  if (isKeyable(key)) {\n    return hashHas(typeof key == 'string' ? data.string : data.hash, key);\n  }\n  return Map ? data.map.has(key) : assocHas(data.map, key);\n}\n\nmodule.exports = mapHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapHas.js\n ** module id = 128\n ** module chunks = 0\n **/","var Map = require('./_Map'),\n    assocSet = require('./_assocSet'),\n    hashSet = require('./_hashSet'),\n    isKeyable = require('./_isKeyable');\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 object.\n */\nfunction mapSet(key, value) {\n  var data = this.__data__;\n  if (isKeyable(key)) {\n    hashSet(typeof key == 'string' ? data.string : data.hash, key, value);\n  } else if (Map) {\n    data.map.set(key, value);\n  } else {\n    assocSet(data.map, key, value);\n  }\n  return this;\n}\n\nmodule.exports = mapSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapSet.js\n ** module id = 129\n ** module chunks = 0\n **/","/**\n * Converts `map` to an array.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction mapToArray(map) {\n  var index = -1,\n      result = Array(map.size);\n\n  map.forEach(function(value, key) {\n    result[++index] = [key, value];\n  });\n  return result;\n}\n\nmodule.exports = mapToArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_mapToArray.js\n ** module id = 130\n ** module chunks = 0\n **/","/**\n * Converts `set` to an array.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction setToArray(set) {\n  var index = -1,\n      result = Array(set.size);\n\n  set.forEach(function(value) {\n    result[++index] = value;\n  });\n  return result;\n}\n\nmodule.exports = setToArray;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_setToArray.js\n ** module id = 131\n ** module chunks = 0\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__ = { 'array': [], 'map': null };\n}\n\nmodule.exports = stackClear;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackClear.js\n ** module id = 132\n ** module chunks = 0\n **/","var assocDelete = require('./_assocDelete');\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n  var data = this.__data__,\n      array = data.array;\n\n  return array ? assocDelete(array, key) : data.map['delete'](key);\n}\n\nmodule.exports = stackDelete;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackDelete.js\n ** module id = 133\n ** module chunks = 0\n **/","var assocGet = require('./_assocGet');\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n  var data = this.__data__,\n      array = data.array;\n\n  return array ? assocGet(array, key) : data.map.get(key);\n}\n\nmodule.exports = stackGet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackGet.js\n ** module id = 134\n ** module chunks = 0\n **/","var assocHas = require('./_assocHas');\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n  var data = this.__data__,\n      array = data.array;\n\n  return array ? assocHas(array, key) : data.map.has(key);\n}\n\nmodule.exports = stackHas;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackHas.js\n ** module id = 135\n ** module chunks = 0\n **/","var MapCache = require('./_MapCache'),\n    assocSet = require('./_assocSet');\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 object.\n */\nfunction stackSet(key, value) {\n  var data = this.__data__,\n      array = data.array;\n\n  if (array) {\n    if (array.length < (LARGE_ARRAY_SIZE - 1)) {\n      assocSet(array, key, value);\n    } else {\n      data.array = null;\n      data.map = new MapCache(array);\n    }\n  }\n  var map = data.map;\n  if (map) {\n    map.set(key, value);\n  }\n  return this;\n}\n\nmodule.exports = stackSet;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/_stackSet.js\n ** module id = 136\n ** module chunks = 0\n **/","/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var object = { 'user': 'fred' };\n * var getter = _.constant(object);\n *\n * getter() === object;\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 = 137\n ** module chunks = 0\n **/","var constant = require('./constant'),\n    root = require('./_root');\n\n/** Used to determine if values are of the language type `Object`. */\nvar objectTypes = {\n  'function': true,\n  'object': true\n};\n\n/** Detect free variable `exports`. */\nvar freeExports = (objectTypes[typeof exports] && exports && !exports.nodeType)\n  ? exports\n  : undefined;\n\n/** Detect free variable `module`. */\nvar freeModule = (objectTypes[typeof module] && module && !module.nodeType)\n  ? module\n  : undefined;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = (freeModule && freeModule.exports === freeExports)\n  ? freeExports\n  : undefined;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\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 = !Buffer ? constant(false) : function(value) {\n  return value instanceof Buffer;\n};\n\nmodule.exports = isBuffer;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isBuffer.js\n ** module id = 138\n ** module chunks = 0\n **/","var isFunction = require('./isFunction'),\n    isHostObject = require('./_isHostObject'),\n    isObjectLike = require('./isObjectLike');\n\n/** Used to match `RegExp` [syntax characters](http://ecma-international.org/ecma-262/6.0/#sec-patterns). */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari > 5). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = Function.prototype.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 * Checks if `value` is a native function.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function, else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\nfunction isNative(value) {\n  if (value == null) {\n    return false;\n  }\n  if (isFunction(value)) {\n    return reIsNative.test(funcToString.call(value));\n  }\n  return isObjectLike(value) &&\n    (isHostObject(value) ? reIsNative : reIsHostCtor).test(value);\n}\n\nmodule.exports = isNative;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isNative.js\n ** module id = 139\n ** module chunks = 0\n **/","var isHostObject = require('./_isHostObject'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = Function.prototype.toString;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar getPrototypeOf = Object.getPrototypeOf;\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 * @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) ||\n      objectToString.call(value) != objectTag || isHostObject(value)) {\n    return false;\n  }\n  var proto = getPrototypeOf(value);\n  if (proto === null) {\n    return true;\n  }\n  var Ctor = proto.constructor;\n  return (typeof Ctor == 'function' &&\n    Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString);\n}\n\nmodule.exports = isPlainObject;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isPlainObject.js\n ** module id = 140\n ** module chunks = 0\n **/","var isArray = require('./isArray'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar stringTag = '[object String]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n  return typeof value == 'string' ||\n    (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag);\n}\n\nmodule.exports = isString;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/isString.js\n ** module id = 141\n ** module chunks = 0\n **/","var baseFlatten = require('./_baseFlatten'),\n    basePick = require('./_basePick'),\n    rest = require('./rest');\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [props] The property names to pick, specified\n *  individually or in arrays.\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 = rest(function(object, props) {\n  return object == null ? {} : basePick(object, baseFlatten(props, 1));\n});\n\nmodule.exports = pick;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/pick.js\n ** module id = 142\n ** module chunks = 0\n **/","var toNumber = require('./toNumber');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n    MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This function is loosely based on [`ToInteger`](http://www.ecma-international.org/ecma-262/6.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3');\n * // => 3\n */\nfunction toInteger(value) {\n  if (!value) {\n    return value === 0 ? value : 0;\n  }\n  value = toNumber(value);\n  if (value === INFINITY || value === -INFINITY) {\n    var sign = (value < 0 ? -1 : 1);\n    return sign * MAX_INTEGER;\n  }\n  var remainder = value % 1;\n  return value === value ? (remainder ? value - remainder : value) : 0;\n}\n\nmodule.exports = toInteger;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/toInteger.js\n ** module id = 143\n ** module chunks = 0\n **/","var isFunction = require('./isFunction'),\n    isObject = require('./isObject');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3);\n * // => 3\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3');\n * // => 3\n */\nfunction toNumber(value) {\n  if (isObject(value)) {\n    var other = isFunction(value.valueOf) ? value.valueOf() : value;\n    value = isObject(other) ? (other + '') : other;\n  }\n  if (typeof value != 'string') {\n    return value === 0 ? value : +value;\n  }\n  value = value.replace(reTrim, '');\n  var isBinary = reIsBinary.test(value);\n  return (isBinary || reIsOctal.test(value))\n    ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n    : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lodash/toNumber.js\n ** module id = 144\n ** module chunks = 0\n **/","var copyObject = require('./_copyObject'),\n    keysIn = require('./keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable\n * properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\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 = 145\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\n// Shimming starts here.\n(function() {\n  // Utils.\n  var logging = require('./utils').log;\n  var browserDetails = require('./utils').browserDetails;\n  // Export to the adapter global object visible in the browser.\n  module.exports.browserDetails = browserDetails;\n  module.exports.extractVersion = require('./utils').extractVersion;\n  module.exports.disableLog = require('./utils').disableLog;\n\n  // Uncomment if you do not want any logging at all including the switch\n  // statement below. Can also be turned off in the browser via\n  // adapter.disableLog(true) but then logging from the switch statement below\n  // will still appear.\n  //require('./utils').disableLog(true);\n\n  // Browser shims.\n  var chromeShim = require('./chrome/chrome_shim') || null;\n  var edgeShim = require('./edge/edge_shim') || null;\n  var firefoxShim = require('./firefox/firefox_shim') || null;\n\n  // Shim browser if found.\n  switch (browserDetails.browser) {\n    case 'chrome':\n      if (!chromeShim || !chromeShim.shimPeerConnection) {\n        logging('Chrome shim is not included in this adapter release.');\n        return;\n      }\n      logging('adapter.js shimming chrome!');\n      // Export to the adapter global object visible in the browser.\n      module.exports.browserShim = chromeShim;\n\n      chromeShim.shimGetUserMedia();\n      chromeShim.shimSourceObject();\n      chromeShim.shimPeerConnection();\n      chromeShim.shimOnTrack();\n      break;\n    case 'edge':\n      if (!edgeShim || !edgeShim.shimPeerConnection) {\n        logging('MS edge shim is not included in this adapter release.');\n        return;\n      }\n      logging('adapter.js shimming edge!');\n      // Export to the adapter global object visible in the browser.\n      module.exports.browserShim = edgeShim;\n\n      edgeShim.shimPeerConnection();\n      break;\n    case 'firefox':\n      if (!firefoxShim || !firefoxShim.shimPeerConnection) {\n        logging('Firefox shim is not included in this adapter release.');\n        return;\n      }\n      logging('adapter.js shimming firefox!');\n      // Export to the adapter global object visible in the browser.\n      module.exports.browserShim = firefoxShim;\n\n      firefoxShim.shimGetUserMedia();\n      firefoxShim.shimSourceObject();\n      firefoxShim.shimPeerConnection();\n      firefoxShim.shimOnTrack();\n      break;\n    default:\n      logging('Unsupported browser!');\n  }\n})();\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/adapter_core.js\n ** module id = 146\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\nvar logging = require('../utils.js').log;\nvar browserDetails = require('../utils.js').browserDetails;\n\nvar chromeShim = {\n  shimOnTrack: function() {\n    if (typeof window === 'object' && window.RTCPeerConnection && !('ontrack' in\n        window.RTCPeerConnection.prototype)) {\n      Object.defineProperty(window.RTCPeerConnection.prototype, 'ontrack', {\n        get: function() { return this._ontrack; },\n        set: function(f) {\n          var self = this;\n          if (this._ontrack) {\n            this.removeEventListener('track', this._ontrack);\n            this.removeEventListener('addstream', this._ontrackpoly);\n          }\n          this.addEventListener('track', this._ontrack = f);\n          this.addEventListener('addstream', this._ontrackpoly = function(e) {\n            // onaddstream does not fire when a track is added to an existing stream.\n            // but stream.onaddtrack is implemented so we use that\n            e.stream.addEventListener('addtrack', function(te) {\n              var event = new Event('track');\n              event.track = te.track;\n              event.receiver = {track: te.track};\n              event.streams = [e.stream];\n              self.dispatchEvent(event);\n            });\n            e.stream.getTracks().forEach(function(track) {\n              var event = new Event('track');\n              event.track = track;\n              event.receiver = {track: track};\n              event.streams = [e.stream];\n              this.dispatchEvent(event);\n            }.bind(this));\n          }.bind(this));\n        }\n      });\n    }\n  },\n\n  shimSourceObject: function() {\n    if (typeof window === 'object') {\n      if (window.HTMLMediaElement &&\n        !('srcObject' in window.HTMLMediaElement.prototype)) {\n        // Shim the srcObject property, once, when HTMLMediaElement is found.\n        Object.defineProperty(window.HTMLMediaElement.prototype, 'srcObject', {\n          get: function() {\n            return this._srcObject;\n          },\n          set: function(stream) {\n            var self = this;\n            // Use _srcObject as a private property for this shim\n            this._srcObject = stream;\n            if (this.src) {\n              URL.revokeObjectURL(this.src);\n            }\n\n            if (!stream) {\n              this.src = '';\n              return;\n            }\n            this.src = URL.createObjectURL(stream);\n            // We need to recreate the blob url when a track is added or removed.\n            // Doing it manually since we want to avoid a recursion.\n            stream.addEventListener('addtrack', function() {\n              if (self.src) {\n                URL.revokeObjectURL(self.src);\n              }\n              self.src = URL.createObjectURL(stream);\n            });\n            stream.addEventListener('removetrack', function() {\n              if (self.src) {\n                URL.revokeObjectURL(self.src);\n              }\n              self.src = URL.createObjectURL(stream);\n            });\n          }\n        });\n      }\n    }\n  },\n\n  shimPeerConnection: function() {\n    // The RTCPeerConnection object.\n    window.RTCPeerConnection = function(pcConfig, pcConstraints) {\n      // Translate iceTransportPolicy to iceTransports,\n      // see https://code.google.com/p/webrtc/issues/detail?id=4869\n      logging('PeerConnection');\n      if (pcConfig && pcConfig.iceTransportPolicy) {\n        pcConfig.iceTransports = pcConfig.iceTransportPolicy;\n      }\n\n      var pc = new webkitRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors\n      var origGetStats = pc.getStats.bind(pc);\n      pc.getStats = function(selector, successCallback, errorCallback) { // jshint ignore: line\n        var self = this;\n        var args = arguments;\n\n        // If selector is a function then we are in the old style stats so just\n        // pass back the original getStats format to avoid breaking old users.\n        if (arguments.length > 0 && typeof selector === 'function') {\n          return origGetStats(selector, successCallback);\n        }\n\n        var fixChromeStats_ = function(response) {\n          var standardReport = {};\n          var reports = response.result();\n          reports.forEach(function(report) {\n            var standardStats = {\n              id: report.id,\n              timestamp: report.timestamp,\n              type: report.type\n            };\n            report.names().forEach(function(name) {\n              standardStats[name] = report.stat(name);\n            });\n            standardReport[standardStats.id] = standardStats;\n          });\n\n          return standardReport;\n        };\n\n        if (arguments.length >= 2) {\n          var successCallbackWrapper_ = function(response) {\n            args[1](fixChromeStats_(response));\n          };\n\n          return origGetStats.apply(this, [successCallbackWrapper_, arguments[0]]);\n        }\n\n        // promise-support\n        return new Promise(function(resolve, reject) {\n          if (args.length === 1 && selector === null) {\n            origGetStats.apply(self, [\n                function(response) {\n                  resolve.apply(null, [fixChromeStats_(response)]);\n                }, reject]);\n          } else {\n            origGetStats.apply(self, [resolve, reject]);\n          }\n        });\n      };\n\n      return pc;\n    };\n    window.RTCPeerConnection.prototype = webkitRTCPeerConnection.prototype;\n\n    // wrap static methods. Currently just generateCertificate.\n    if (webkitRTCPeerConnection.generateCertificate) {\n      Object.defineProperty(window.RTCPeerConnection, 'generateCertificate', {\n        get: function() {\n          if (arguments.length) {\n            return webkitRTCPeerConnection.generateCertificate.apply(null,\n                arguments);\n          } else {\n            return webkitRTCPeerConnection.generateCertificate;\n          }\n        }\n      });\n    }\n\n    // add promise support\n    ['createOffer', 'createAnswer'].forEach(function(method) {\n      var nativeMethod = webkitRTCPeerConnection.prototype[method];\n      webkitRTCPeerConnection.prototype[method] = function() {\n        var self = this;\n        if (arguments.length < 1 || (arguments.length === 1 &&\n            typeof(arguments[0]) === 'object')) {\n          var opts = arguments.length === 1 ? arguments[0] : undefined;\n          return new Promise(function(resolve, reject) {\n            nativeMethod.apply(self, [resolve, reject, opts]);\n          });\n        } else {\n          return nativeMethod.apply(this, arguments);\n        }\n      };\n    });\n\n    ['setLocalDescription', 'setRemoteDescription',\n        'addIceCandidate'].forEach(function(method) {\n      var nativeMethod = webkitRTCPeerConnection.prototype[method];\n      webkitRTCPeerConnection.prototype[method] = function() {\n        var args = arguments;\n        var self = this;\n        return new Promise(function(resolve, reject) {\n          nativeMethod.apply(self, [args[0],\n              function() {\n                resolve();\n                if (args.length >= 2) {\n                  args[1].apply(null, []);\n                }\n              },\n              function(err) {\n                reject(err);\n                if (args.length >= 3) {\n                  args[2].apply(null, [err]);\n                }\n              }]\n            );\n        });\n      };\n    });\n  },\n\n  // Attach a media stream to an element.\n  attachMediaStream: function(element, stream) {\n    logging('DEPRECATED, attachMediaStream will soon be removed.');\n    if (browserDetails.version >= 43) {\n      element.srcObject = stream;\n    } else if (typeof element.src !== 'undefined') {\n      element.src = URL.createObjectURL(stream);\n    } else {\n      logging('Error attaching stream to element.');\n    }\n  },\n\n  reattachMediaStream: function(to, from) {\n    logging('DEPRECATED, reattachMediaStream will soon be removed.');\n    if (browserDetails.version >= 43) {\n      to.srcObject = from.srcObject;\n    } else {\n      to.src = from.src;\n    }\n  }\n}\n\n\n// Expose public methods.\nmodule.exports = {\n  shimOnTrack: chromeShim.shimOnTrack,\n  shimSourceObject: chromeShim.shimSourceObject,\n  shimPeerConnection: chromeShim.shimPeerConnection,\n  shimGetUserMedia: require('./getusermedia'),\n  attachMediaStream: chromeShim.attachMediaStream,\n  reattachMediaStream: chromeShim.reattachMediaStream\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/chrome/chrome_shim.js\n ** module id = 147\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\nvar logging = require('../utils.js').log;\n\n// Expose public methods.\nmodule.exports = function() {\n  var constraintsToChrome_ = function(c) {\n    if (typeof c !== 'object' || c.mandatory || c.optional) {\n      return c;\n    }\n    var cc = {};\n    Object.keys(c).forEach(function(key) {\n      if (key === 'require' || key === 'advanced' || key === 'mediaSource') {\n        return;\n      }\n      var r = (typeof c[key] === 'object') ? c[key] : {ideal: c[key]};\n      if (r.exact !== undefined && typeof r.exact === 'number') {\n        r.min = r.max = r.exact;\n      }\n      var oldname_ = function(prefix, name) {\n        if (prefix) {\n          return prefix + name.charAt(0).toUpperCase() + name.slice(1);\n        }\n        return (name === 'deviceId') ? 'sourceId' : name;\n      };\n      if (r.ideal !== undefined) {\n        cc.optional = cc.optional || [];\n        var oc = {};\n        if (typeof r.ideal === 'number') {\n          oc[oldname_('min', key)] = r.ideal;\n          cc.optional.push(oc);\n          oc = {};\n          oc[oldname_('max', key)] = r.ideal;\n          cc.optional.push(oc);\n        } else {\n          oc[oldname_('', key)] = r.ideal;\n          cc.optional.push(oc);\n        }\n      }\n      if (r.exact !== undefined && typeof r.exact !== 'number') {\n        cc.mandatory = cc.mandatory || {};\n        cc.mandatory[oldname_('', key)] = r.exact;\n      } else {\n        ['min', 'max'].forEach(function(mix) {\n          if (r[mix] !== undefined) {\n            cc.mandatory = cc.mandatory || {};\n            cc.mandatory[oldname_(mix, key)] = r[mix];\n          }\n        });\n      }\n    });\n    if (c.advanced) {\n      cc.optional = (cc.optional || []).concat(c.advanced);\n    }\n    return cc;\n  };\n\n  var getUserMedia_ = function(constraints, onSuccess, onError) {\n    if (constraints.audio) {\n      constraints.audio = constraintsToChrome_(constraints.audio);\n    }\n    if (constraints.video) {\n      constraints.video = constraintsToChrome_(constraints.video);\n    }\n    logging('chrome: ' + JSON.stringify(constraints));\n    return navigator.webkitGetUserMedia(constraints, onSuccess, onError);\n  };\n  navigator.getUserMedia = getUserMedia_;\n\n  // Returns the result of getUserMedia as a Promise.\n  var getUserMediaPromise_ = function(constraints) {\n    return new Promise(function(resolve, reject) {\n      navigator.getUserMedia(constraints, resolve, reject);\n    });\n  }\n\n  if (!navigator.mediaDevices) {\n    navigator.mediaDevices = {getUserMedia: getUserMediaPromise_,\n                             enumerateDevices: function() {\n      return new Promise(function(resolve) {\n        var kinds = {audio: 'audioinput', video: 'videoinput'};\n        return MediaStreamTrack.getSources(function(devices) {\n          resolve(devices.map(function(device) {\n            return {label: device.label,\n                    kind: kinds[device.kind],\n                    deviceId: device.id,\n                    groupId: ''};\n          }));\n        });\n      });\n    }};\n  }\n\n  // A shim for getUserMedia method on the mediaDevices object.\n  // TODO(KaptenJansson) remove once implemented in Chrome stable.\n  if (!navigator.mediaDevices.getUserMedia) {\n    navigator.mediaDevices.getUserMedia = function(constraints) {\n      return getUserMediaPromise_(constraints);\n    };\n  } else {\n    // Even though Chrome 45 has navigator.mediaDevices and a getUserMedia\n    // function which returns a Promise, it does not accept spec-style\n    // constraints.\n    var origGetUserMedia = navigator.mediaDevices.getUserMedia.\n        bind(navigator.mediaDevices);\n    navigator.mediaDevices.getUserMedia = function(c) {\n      if (c) {\n        logging('spec:   ' + JSON.stringify(c)); // whitespace for alignment\n        c.audio = constraintsToChrome_(c.audio);\n        c.video = constraintsToChrome_(c.video);\n        logging('chrome: ' + JSON.stringify(c));\n      }\n      return origGetUserMedia(c);\n    }.bind(this);\n  }\n\n  // Dummy devicechange event methods.\n  // TODO(KaptenJansson) remove once implemented in Chrome stable.\n  if (typeof navigator.mediaDevices.addEventListener === 'undefined') {\n    navigator.mediaDevices.addEventListener = function() {\n      logging('Dummy mediaDevices.addEventListener called.');\n    };\n  }\n  if (typeof navigator.mediaDevices.removeEventListener === 'undefined') {\n    navigator.mediaDevices.removeEventListener = function() {\n      logging('Dummy mediaDevices.removeEventListener called.');\n    };\n  }\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/chrome/getusermedia.js\n ** module id = 148\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\n// SDP helpers.\nvar SDPUtils = {};\n\n// Generate an alphanumeric identifier for cname or mids.\n// TODO: use UUIDs instead? https://gist.github.com/jed/982883\nSDPUtils.generateIdentifier = function() {\n  return Math.random().toString(36).substr(2, 10);\n};\n\n// The RTCP CNAME used by all peerconnections from the same JS.\nSDPUtils.localCName = SDPUtils.generateIdentifier();\n\n\n// Splits SDP into lines, dealing with both CRLF and LF.\nSDPUtils.splitLines = function(blob) {\n  return blob.trim().split('\\n').map(function(line) {\n    return line.trim();\n  });\n};\n// Splits SDP into sessionpart and mediasections. Ensures CRLF.\nSDPUtils.splitSections = function(blob) {\n  var parts = blob.split('\\r\\nm=');\n  return parts.map(function(part, index) {\n    return (index > 0 ? 'm=' + part : part).trim() + '\\r\\n';\n  });\n};\n\n// Returns lines that start with a certain prefix.\nSDPUtils.matchPrefix = function(blob, prefix) {\n  return SDPUtils.splitLines(blob).filter(function(line) {\n    return line.indexOf(prefix) === 0;\n  });\n};\n\n// Parses an ICE candidate line. Sample input:\n// candidate:702786350 2 udp 41819902 8.8.8.8 60769 typ relay raddr 8.8.8.8 rport 55996\"\nSDPUtils.parseCandidate = function(line) {\n  var parts;\n  // Parse both variants.\n  if (line.indexOf('a=candidate:') === 0) {\n    parts = line.substring(12).split(' ');\n  } else {\n    parts = line.substring(10).split(' ');\n  }\n\n  var candidate = {\n    foundation: parts[0],\n    component: parts[1],\n    protocol: parts[2].toLowerCase(),\n    priority: parseInt(parts[3], 10),\n    ip: parts[4],\n    port: parseInt(parts[5], 10),\n    // skip parts[6] == 'typ'\n    type: parts[7]\n  };\n\n  for (var i = 8; i < parts.length; i += 2) {\n    switch (parts[i]) {\n      case 'raddr':\n        candidate.relatedAddress = parts[i + 1];\n        break;\n      case 'rport':\n        candidate.relatedPort = parseInt(parts[i + 1], 10);\n        break;\n      case 'tcptype':\n        candidate.tcpType = parts[i + 1];\n        break;\n      default: // Unknown extensions are silently ignored.\n        break;\n    }\n  }\n  return candidate;\n};\n\n// Translates a candidate object into SDP candidate attribute.\nSDPUtils.writeCandidate = function(candidate) {\n  var sdp = [];\n  sdp.push(candidate.foundation);\n  sdp.push(candidate.component);\n  sdp.push(candidate.protocol.toUpperCase());\n  sdp.push(candidate.priority);\n  sdp.push(candidate.ip);\n  sdp.push(candidate.port);\n\n  var type = candidate.type;\n  sdp.push('typ');\n  sdp.push(type);\n  if (type !== 'host' && candidate.relatedAddress &&\n      candidate.relatedPort) {\n    sdp.push('raddr');\n    sdp.push(candidate.relatedAddress); // was: relAddr\n    sdp.push('rport');\n    sdp.push(candidate.relatedPort); // was: relPort\n  }\n  if (candidate.tcpType && candidate.protocol.toLowerCase() === 'tcp') {\n    sdp.push('tcptype');\n    sdp.push(candidate.tcpType);\n  }\n  return 'candidate:' + sdp.join(' ');\n};\n\n// Parses an rtpmap line, returns RTCRtpCoddecParameters. Sample input:\n// a=rtpmap:111 opus/48000/2\nSDPUtils.parseRtpMap = function(line) {\n  var parts = line.substr(9).split(' ');\n  var parsed = {\n    payloadType: parseInt(parts.shift(), 10) // was: id\n  };\n\n  parts = parts[0].split('/');\n\n  parsed.name = parts[0];\n  parsed.clockRate = parseInt(parts[1], 10); // was: clockrate\n  parsed.numChannels = parts.length === 3 ? parseInt(parts[2], 10) : 1; // was: channels\n  return parsed;\n};\n\n// Generate an a=rtpmap line from RTCRtpCodecCapability or RTCRtpCodecParameters.\nSDPUtils.writeRtpMap = function(codec) {\n  var pt = codec.payloadType;\n  if (codec.preferredPayloadType !== undefined) {\n    pt = codec.preferredPayloadType;\n  }\n  return 'a=rtpmap:' + pt + ' ' + codec.name + '/' + codec.clockRate +\n      (codec.numChannels !== 1 ? '/' + codec.numChannels : '') + '\\r\\n';\n};\n\n// Parses an ftmp line, returns dictionary. Sample input:\n// a=fmtp:96 vbr=on;cng=on\n// Also deals with vbr=on; cng=on\nSDPUtils.parseFmtp = function(line) {\n  var parsed = {};\n  var kv;\n  var parts = line.substr(line.indexOf(' ') + 1).split(';');\n  for (var j = 0; j < parts.length; j++) {\n    kv = parts[j].trim().split('=');\n    parsed[kv[0].trim()] = kv[1];\n  }\n  return parsed;\n};\n\n// Generates an a=ftmp line from RTCRtpCodecCapability or RTCRtpCodecParameters.\nSDPUtils.writeFtmp = function(codec) {\n  var line = '';\n  var pt = codec.payloadType;\n  if (codec.preferredPayloadType !== undefined) {\n    pt = codec.preferredPayloadType;\n  }\n  if (codec.parameters && codec.parameters.length) {\n    var params = [];\n    Object.keys(codec.parameters).forEach(function(param) {\n      params.push(param + '=' + codec.parameters[param]);\n    });\n    line += 'a=fmtp:' + pt + ' ' + params.join(';') + '\\r\\n';\n  }\n  return line;\n};\n\n// Parses an rtcp-fb line, returns RTCPRtcpFeedback object. Sample input:\n// a=rtcp-fb:98 nack rpsi\nSDPUtils.parseRtcpFb = function(line) {\n  var parts = line.substr(line.indexOf(' ') + 1).split(' ');\n  return {\n    type: parts.shift(),\n    parameter: parts.join(' ')\n  };\n};\n// Generate a=rtcp-fb lines from RTCRtpCodecCapability or RTCRtpCodecParameters.\nSDPUtils.writeRtcpFb = function(codec) {\n  var lines = '';\n  var pt = codec.payloadType;\n  if (codec.preferredPayloadType !== undefined) {\n    pt = codec.preferredPayloadType;\n  }\n  if (codec.rtcpFeedback && codec.rtcpFeedback.length) {\n    // FIXME: special handling for trr-int?\n    codec.rtcpFeedback.forEach(function(fb) {\n      lines += 'a=rtcp-fb:' + pt + ' ' + fb.type + ' ' + fb.parameter +\n          '\\r\\n';\n    });\n  }\n  return lines;\n};\n\n// Parses an RFC 5576 ssrc media attribute. Sample input:\n// a=ssrc:3735928559 cname:something\nSDPUtils.parseSsrcMedia = function(line) {\n  var sp = line.indexOf(' ');\n  var parts = {\n    ssrc: line.substr(7, sp - 7),\n  };\n  var colon = line.indexOf(':', sp);\n  if (colon > -1) {\n    parts.attribute = line.substr(sp + 1, colon - sp - 1);\n    parts.value = line.substr(colon + 1);\n  } else {\n    parts.attribute = line.substr(sp + 1);\n  }\n  return parts;\n};\n\n// Extracts DTLS parameters from SDP media section or sessionpart.\n// FIXME: for consistency with other functions this should only\n//   get the fingerprint line as input. See also getIceParameters.\nSDPUtils.getDtlsParameters = function(mediaSection, sessionpart) {\n  var lines = SDPUtils.splitLines(mediaSection);\n  lines = lines.concat(SDPUtils.splitLines(sessionpart)); // Search in session part, too.\n  var fpLine = lines.filter(function(line) {\n    return line.indexOf('a=fingerprint:') === 0;\n  })[0].substr(14);\n  // Note: a=setup line is ignored since we use the 'auto' role.\n  var dtlsParameters = {\n    role: 'auto',\n    fingerprints: [{\n      algorithm: fpLine.split(' ')[0],\n      value: fpLine.split(' ')[1]\n    }]\n  };\n  return dtlsParameters;\n};\n\n// Serializes DTLS parameters to SDP.\nSDPUtils.writeDtlsParameters = function(params, setupType) {\n  var sdp = 'a=setup:' + setupType + '\\r\\n';\n  params.fingerprints.forEach(function(fp) {\n    sdp += 'a=fingerprint:' + fp.algorithm + ' ' + fp.value + '\\r\\n';\n  });\n  return sdp;\n};\n// Parses ICE information from SDP media section or sessionpart.\n// FIXME: for consistency with other functions this should only\n//   get the ice-ufrag and ice-pwd lines as input.\nSDPUtils.getIceParameters = function(mediaSection, sessionpart) {\n  var lines = SDPUtils.splitLines(mediaSection);\n  lines = lines.concat(SDPUtils.splitLines(sessionpart)); // Search in session part, too.\n  var iceParameters = {\n    usernameFragment: lines.filter(function(line) {\n      return line.indexOf('a=ice-ufrag:') === 0;\n    })[0].substr(12),\n    password: lines.filter(function(line) {\n      return line.indexOf('a=ice-pwd:') === 0;\n    })[0].substr(10)\n  };\n  return iceParameters;\n};\n\n// Serializes ICE parameters to SDP.\nSDPUtils.writeIceParameters = function(params) {\n  return 'a=ice-ufrag:' + params.usernameFragment + '\\r\\n' +\n      'a=ice-pwd:' + params.password + '\\r\\n';\n};\n\n// Parses the SDP media section and returns RTCRtpParameters.\nSDPUtils.parseRtpParameters = function(mediaSection) {\n  var description = {\n    codecs: [],\n    headerExtensions: [],\n    fecMechanisms: [],\n    rtcp: []\n  };\n  var lines = SDPUtils.splitLines(mediaSection);\n  var mline = lines[0].split(' ');\n  for (var i = 3; i < mline.length; i++) { // find all codecs from mline[3..]\n    var pt = mline[i];\n    var rtpmapline = SDPUtils.matchPrefix(\n        mediaSection, 'a=rtpmap:' + pt + ' ')[0];\n    if (rtpmapline) {\n      var codec = SDPUtils.parseRtpMap(rtpmapline);\n      var fmtps = SDPUtils.matchPrefix(\n          mediaSection, 'a=fmtp:' + pt + ' ');\n      // Only the first a=fmtp:<pt> is considered.\n      codec.parameters = fmtps.length ? SDPUtils.parseFmtp(fmtps[0]) : {};\n      codec.rtcpFeedback = SDPUtils.matchPrefix(\n          mediaSection, 'a=rtcp-fb:' + pt + ' ')\n        .map(SDPUtils.parseRtcpFb);\n      description.codecs.push(codec);\n    }\n  }\n  // FIXME: parse headerExtensions, fecMechanisms and rtcp.\n  return description;\n};\n\n// Generates parts of the SDP media section describing the capabilities / parameters.\nSDPUtils.writeRtpDescription = function(kind, caps) {\n  var sdp = '';\n\n  // Build the mline.\n  sdp += 'm=' + kind + ' ';\n  sdp += caps.codecs.length > 0 ? '9' : '0'; // reject if no codecs.\n  sdp += ' UDP/TLS/RTP/SAVPF ';\n  sdp += caps.codecs.map(function(codec) {\n    if (codec.preferredPayloadType !== undefined) {\n      return codec.preferredPayloadType;\n    }\n    return codec.payloadType;\n  }).join(' ') + '\\r\\n';\n\n  sdp += 'c=IN IP4 0.0.0.0\\r\\n';\n  sdp += 'a=rtcp:9 IN IP4 0.0.0.0\\r\\n';\n\n  // Add a=rtpmap lines for each codec. Also fmtp and rtcp-fb.\n  caps.codecs.forEach(function(codec) {\n    sdp += SDPUtils.writeRtpMap(codec);\n    sdp += SDPUtils.writeFtmp(codec);\n    sdp += SDPUtils.writeRtcpFb(codec);\n  });\n  // FIXME: add headerExtensions, fecMechanismş and rtcp.\n  sdp += 'a=rtcp-mux\\r\\n';\n  return sdp;\n};\n\nSDPUtils.writeSessionBoilerplate = function() {\n  // FIXME: sess-id should be an NTP timestamp.\n  return 'v=0\\r\\n' +\n      'o=thisisadapterortc 8169639915646943137 2 IN IP4 127.0.0.1\\r\\n' +\n      's=-\\r\\n' +\n      't=0 0\\r\\n';\n};\n\nSDPUtils.writeMediaSection = function(transceiver, caps, type, stream) {\n  var sdp = SDPUtils.writeRtpDescription(transceiver.kind, caps);\n\n  // Map ICE parameters (ufrag, pwd) to SDP.\n  sdp += SDPUtils.writeIceParameters(\n      transceiver.iceGatherer.getLocalParameters());\n\n  // Map DTLS parameters to SDP.\n  sdp += SDPUtils.writeDtlsParameters(\n      transceiver.dtlsTransport.getLocalParameters(),\n      type === 'offer' ? 'actpass' : 'active');\n\n  sdp += 'a=mid:' + transceiver.mid + '\\r\\n';\n\n  if (transceiver.rtpSender && transceiver.rtpReceiver) {\n    sdp += 'a=sendrecv\\r\\n';\n  } else if (transceiver.rtpSender) {\n    sdp += 'a=sendonly\\r\\n';\n  } else if (transceiver.rtpReceiver) {\n    sdp += 'a=recvonly\\r\\n';\n  } else {\n    sdp += 'a=inactive\\r\\n';\n  }\n\n  // FIXME: for RTX there might be multiple SSRCs. Not implemented in Edge yet.\n  if (transceiver.rtpSender) {\n    var msid = 'msid:' + stream.id + ' ' +\n        transceiver.rtpSender.track.id + '\\r\\n';\n    sdp += 'a=' + msid;\n    sdp += 'a=ssrc:' + transceiver.sendSsrc + ' ' + msid;\n  }\n  // FIXME: this should be written by writeRtpDescription.\n  sdp += 'a=ssrc:' + transceiver.sendSsrc + ' cname:' +\n      SDPUtils.localCName + '\\r\\n';\n  return sdp;\n};\n\n// Gets the direction from the mediaSection or the sessionpart.\nSDPUtils.getDirection = function(mediaSection, sessionpart) {\n  // Look for sendrecv, sendonly, recvonly, inactive, default to sendrecv.\n  var lines = SDPUtils.splitLines(mediaSection);\n  for (var i = 0; i < lines.length; i++) {\n    switch (lines[i]) {\n      case 'a=sendrecv':\n      case 'a=sendonly':\n      case 'a=recvonly':\n      case 'a=inactive':\n        return lines[i].substr(2);\n    }\n  }\n  if (sessionpart) {\n    return SDPUtils.getDirection(sessionpart);\n  }\n  return 'sendrecv';\n};\n\n// Expose public methods.\nmodule.exports = SDPUtils;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/edge/edge_sdp.js\n ** module id = 149\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\nvar SDPUtils = require('./edge_sdp');\nvar logging = require('../utils').log;\nvar browserDetails = require('../utils').browserDetails;\n\nvar edgeShim = {\n  shimPeerConnection: function() {\n    if (window.RTCIceGatherer) {\n      // ORTC defines an RTCIceCandidate object but no constructor.\n      // Not implemented in Edge.\n      if (!window.RTCIceCandidate) {\n        window.RTCIceCandidate = function(args) {\n          return args;\n        };\n      }\n      // ORTC does not have a session description object but\n      // other browsers (i.e. Chrome) that will support both PC and ORTC\n      // in the future might have this defined already.\n      if (!window.RTCSessionDescription) {\n        window.RTCSessionDescription = function(args) {\n          return args;\n        };\n      }\n    }\n\n    window.RTCPeerConnection = function(config) {\n      var self = this;\n\n      var _eventTarget = document.createDocumentFragment();\n      ['addEventListener', 'removeEventListener', 'dispatchEvent'].forEach(\n          function(method) {\n        self[method] = _eventTarget[method].bind(_eventTarget);\n      });\n\n      this.onicecandidate = null;\n      this.onaddstream = null;\n      this.ontrack = null;\n      this.onremovestream = null;\n      this.onsignalingstatechange = null;\n      this.oniceconnectionstatechange = null;\n      this.onnegotiationneeded = null;\n      this.ondatachannel = null;\n\n      this.localStreams = [];\n      this.remoteStreams = [];\n      this.getLocalStreams = function() { return self.localStreams; };\n      this.getRemoteStreams = function() { return self.remoteStreams; };\n\n      this.localDescription = new RTCSessionDescription({\n        type: '',\n        sdp: ''\n      });\n      this.remoteDescription = new RTCSessionDescription({\n        type: '',\n        sdp: ''\n      });\n      this.signalingState = 'stable';\n      this.iceConnectionState = 'new';\n      this.iceGatheringState = 'new';\n\n      this.iceOptions = {\n        gatherPolicy: 'all',\n        iceServers: []\n      };\n      if (config && config.iceTransportPolicy) {\n        switch (config.iceTransportPolicy) {\n          case 'all':\n          case 'relay':\n            this.iceOptions.gatherPolicy = config.iceTransportPolicy;\n            break;\n          case 'none':\n            // FIXME: remove once implementation and spec have added this.\n            throw new TypeError('iceTransportPolicy \"none\" not supported');\n        }\n      }\n      if (config && config.iceServers) {\n        // Edge does not like\n        // 1) stun:\n        // 2) turn: that does not have all of turn:host:port?transport=udp\n        this.iceOptions.iceServers = config.iceServers.filter(function(server) {\n          if (server && server.urls) {\n            server.urls = server.urls.filter(function(url) {\n              return url.indexOf('transport=udp') !== -1;\n            })[0];\n            return true;\n          }\n          return false;\n        });\n      }\n\n      // per-track iceGathers, iceTransports, dtlsTransports, rtpSenders, ...\n      // everything that is needed to describe a SDP m-line.\n      this.transceivers = [];\n\n      // since the iceGatherer is currently created in createOffer but we\n      // must not emit candidates until after setLocalDescription we buffer\n      // them in this array.\n      this._localIceCandidatesBuffer = [];\n    };\n\n    window.RTCPeerConnection.prototype._emitBufferedCandidates = function() {\n      var self = this;\n      var sections = SDPUtils.splitSections(self.localDescription.sdp);\n      // FIXME: need to apply ice candidates in a way which is async but in-order\n      this._localIceCandidatesBuffer.forEach(function(event) {\n        var end = !event.candidate || Object.keys(event.candidate).length == 0;\n        if (end) {\n          for (var j = 1; j < sections.length; j++) {\n            sections[j] += 'a=end-of-candidates\\r\\n';\n          }\n        } else {\n          sections[event.candidate.sdpMLineIndex + 1] +=\n              'a=' + event.candidate.candidate + '\\r\\n';\n        }\n        self.dispatchEvent(event);\n        if (self.onicecandidate !== null) {\n          self.onicecandidate(event);\n        }\n        if (!event.candidate) {\n          self.iceGatheringState = 'complete';\n        }\n      });\n      this._localIceCandidatesBuffer = [];\n      this.localDescription.sdp = sections.join('');\n    };\n\n    window.RTCPeerConnection.prototype.addStream = function(stream) {\n      // Clone is necessary for local demos mostly, attaching directly\n      // to two different senders does not work (build 10547).\n      this.localStreams.push(stream.clone());\n      this._maybeFireNegotiationNeeded();\n    };\n\n    window.RTCPeerConnection.prototype.removeStream = function(stream) {\n      var idx = this.localStreams.indexOf(stream);\n      if (idx > -1) {\n        this.localStreams.splice(idx, 1);\n        this._maybeFireNegotiationNeeded();\n      }\n    };\n\n    // Determines the intersection of local and remote capabilities.\n    window.RTCPeerConnection.prototype._getCommonCapabilities =\n        function(localCapabilities, remoteCapabilities) {\n      var commonCapabilities = {\n        codecs: [],\n        headerExtensions: [],\n        fecMechanisms: []\n      };\n      localCapabilities.codecs.forEach(function(lCodec) {\n        for (var i = 0; i < remoteCapabilities.codecs.length; i++) {\n          var rCodec = remoteCapabilities.codecs[i];\n          if (lCodec.name.toLowerCase() === rCodec.name.toLowerCase() &&\n              lCodec.clockRate === rCodec.clockRate &&\n              lCodec.numChannels === rCodec.numChannels) {\n            // push rCodec so we reply with offerer payload type\n            commonCapabilities.codecs.push(rCodec);\n\n            // FIXME: also need to determine intersection between\n            // .rtcpFeedback and .parameters\n            break;\n          }\n        }\n      });\n\n      localCapabilities.headerExtensions.forEach(function(lHeaderExtension) {\n        for (var i = 0; i < remoteCapabilities.headerExtensions.length; i++) {\n          var rHeaderExtension = remoteCapabilities.headerExtensions[i];\n          if (lHeaderExtension.uri === rHeaderExtension.uri) {\n            commonCapabilities.headerExtensions.push(rHeaderExtension);\n            break;\n          }\n        }\n      });\n\n      // FIXME: fecMechanisms\n      return commonCapabilities;\n    };\n\n    // Create ICE gatherer, ICE transport and DTLS transport.\n    window.RTCPeerConnection.prototype._createIceAndDtlsTransports =\n        function(mid, sdpMLineIndex) {\n      var self = this;\n      var iceGatherer = new RTCIceGatherer(self.iceOptions);\n      var iceTransport = new RTCIceTransport(iceGatherer);\n      iceGatherer.onlocalcandidate = function(evt) {\n        var event = new Event('icecandidate');\n        event.candidate = {sdpMid: mid, sdpMLineIndex: sdpMLineIndex};\n\n        var cand = evt.candidate;\n        var end = !cand || Object.keys(cand).length === 0;\n        // Edge emits an empty object for RTCIceCandidateComplete‥\n        if (end) {\n          // polyfill since RTCIceGatherer.state is not implemented in Edge 10547 yet.\n          if (iceGatherer.state === undefined) {\n            iceGatherer.state = 'completed';\n          }\n\n          // Emit a candidate with type endOfCandidates to make the samples work.\n          // Edge requires addIceCandidate with this empty candidate to start checking.\n          // The real solution is to signal end-of-candidates to the other side when\n          // getting the null candidate but some apps (like the samples) don't do that.\n          event.candidate.candidate =\n              'candidate:1 1 udp 1 0.0.0.0 9 typ endOfCandidates';\n        } else {\n          // RTCIceCandidate doesn't have a component, needs to be added\n          cand.component = iceTransport.component === 'RTCP' ? 2 : 1;\n          event.candidate.candidate = SDPUtils.writeCandidate(cand);\n        }\n\n        var complete = self.transceivers.every(function(transceiver) {\n          return transceiver.iceGatherer &&\n              transceiver.iceGatherer.state === 'completed';\n        });\n        // update .localDescription with candidate and (potentially) end-of-candidates.\n        //     To make this harder, the gatherer might emit candidates before localdescription\n        //     is set. To make things worse, gather.getLocalCandidates still errors in\n        //     Edge 10547 when no candidates have been gathered yet.\n        if (self.localDescription && self.localDescription.type !== '') {\n          var sections = SDPUtils.splitSections(self.localDescription.sdp);\n          sections[sdpMLineIndex + 1] += (!end ? 'a=' + event.candidate.candidate :\n              'a=end-of-candidates') + '\\r\\n';\n          self.localDescription.sdp = sections.join('');\n        }\n\n        // Emit candidate if localDescription is set.\n        // Also emits null candidate when all gatherers are complete.\n        switch(self.iceGatheringState) {\n        case 'new':\n          self._localIceCandidatesBuffer.push(event);\n          if (complete) {\n            self._localIceCandidatesBuffer.push(new Event('icecandidate'));\n          }\n          break;\n        case 'gathering':\n          self._emitBufferedCandidates();\n          self.dispatchEvent(event);\n          if (self.onicecandidate !== null) {\n            self.onicecandidate(event);\n          }\n          if (complete) {\n            self.dispatchEvent(new Event('icecandidate'));\n            if (self.onicecandidate !== null) {\n              self.onicecandidate(new Event('icecandidate'));\n            }\n            self.iceGatheringState = 'complete';\n          }\n          break;\n        case 'complete':\n          // should not happen... currently!\n          break;\n        }\n      };\n      iceTransport.onicestatechange = function() {\n        self._updateConnectionState();\n      };\n\n      var dtlsTransport = new RTCDtlsTransport(iceTransport);\n      dtlsTransport.ondtlsstatechange = function() {\n        self._updateConnectionState();\n      };\n      dtlsTransport.onerror = function() {\n        // onerror does not set state to failed by itself.\n        dtlsTransport.state = 'failed';\n        self._updateConnectionState();\n      };\n\n      return {\n        iceGatherer: iceGatherer,\n        iceTransport: iceTransport,\n        dtlsTransport: dtlsTransport\n      };\n    };\n\n    // Start the RTP Sender and Receiver for a transceiver.\n    window.RTCPeerConnection.prototype._transceive = function(transceiver,\n        send, recv) {\n      var params = this._getCommonCapabilities(transceiver.localCapabilities,\n          transceiver.remoteCapabilities);\n      if (send && transceiver.rtpSender) {\n        params.encodings = [{\n          ssrc: transceiver.sendSsrc\n        }];\n        params.rtcp = {\n          cname: SDPUtils.localCName,\n          ssrc: transceiver.recvSsrc\n        };\n        transceiver.rtpSender.send(params);\n      }\n      if (recv && transceiver.rtpReceiver) {\n        params.encodings = [{\n          ssrc: transceiver.recvSsrc\n        }];\n        params.rtcp = {\n          cname: transceiver.cname,\n          ssrc: transceiver.sendSsrc\n        };\n        transceiver.rtpReceiver.receive(params);\n      }\n    };\n\n    window.RTCPeerConnection.prototype.setLocalDescription =\n        function(description) {\n      var self = this;\n      if (description.type === 'offer') {\n        if (!this._pendingOffer) {\n        } else {\n          this.transceivers = this._pendingOffer;\n          delete this._pendingOffer;\n        }\n      } else if (description.type === 'answer') {\n        var sections = SDPUtils.splitSections(self.remoteDescription.sdp);\n        var sessionpart = sections.shift();\n        sections.forEach(function(mediaSection, sdpMLineIndex) {\n          var transceiver = self.transceivers[sdpMLineIndex];\n          var iceGatherer = transceiver.iceGatherer;\n          var iceTransport = transceiver.iceTransport;\n          var dtlsTransport = transceiver.dtlsTransport;\n          var localCapabilities = transceiver.localCapabilities;\n          var remoteCapabilities = transceiver.remoteCapabilities;\n          var rejected = mediaSection.split('\\n', 1)[0]\n              .split(' ', 2)[1] === '0';\n\n          if (!rejected) {\n            var remoteIceParameters = SDPUtils.getIceParameters(mediaSection,\n                sessionpart);\n            iceTransport.start(iceGatherer, remoteIceParameters, 'controlled');\n\n            var remoteDtlsParameters = SDPUtils.getDtlsParameters(mediaSection,\n              sessionpart);\n            dtlsTransport.start(remoteDtlsParameters);\n\n            // Calculate intersection of capabilities.\n            var params = self._getCommonCapabilities(localCapabilities,\n                remoteCapabilities);\n\n            // Start the RTCRtpSender. The RTCRtpReceiver for this transceiver\n            // has already been started in setRemoteDescription.\n            self._transceive(transceiver,\n                params.codecs.length > 0,\n                false);\n          }\n        });\n      }\n\n      this.localDescription = {\n        type: description.type,\n        sdp: description.sdp\n      };\n      switch (description.type) {\n        case 'offer':\n          this._updateSignalingState('have-local-offer');\n          break;\n        case 'answer':\n          this._updateSignalingState('stable');\n          break;\n        default:\n          throw new TypeError('unsupported type \"' + description.type + '\"');\n      }\n\n      // If a success callback was provided, emit ICE candidates after it has been\n      // executed. Otherwise, emit callback after the Promise is resolved.\n      var hasCallback = arguments.length > 1 &&\n        typeof arguments[1] === 'function';\n      if (hasCallback) {\n        var cb = arguments[1];\n        window.setTimeout(function() {\n          cb();\n          if (self.iceGatheringState === 'new') {\n            self.iceGatheringState = 'gathering';\n          }\n          self._emitBufferedCandidates();\n        }, 0);\n      }\n      var p = Promise.resolve();\n      p.then(function() {\n        if (!hasCallback) {\n          if (self.iceGatheringState === 'new') {\n            self.iceGatheringState = 'gathering';\n          }\n          // Usually candidates will be emitted earlier.\n          window.setTimeout(self._emitBufferedCandidates.bind(self), 500);\n        }\n      });\n      return p;\n    };\n\n    window.RTCPeerConnection.prototype.setRemoteDescription =\n        function(description) {\n      var self = this;\n      var stream = new MediaStream();\n      var receiverList = [];\n      var sections = SDPUtils.splitSections(description.sdp);\n      var sessionpart = sections.shift();\n      sections.forEach(function(mediaSection, sdpMLineIndex) {\n        var lines = SDPUtils.splitLines(mediaSection);\n        var mline = lines[0].substr(2).split(' ');\n        var kind = mline[0];\n        var rejected = mline[1] === '0';\n        var direction = SDPUtils.getDirection(mediaSection, sessionpart);\n\n        var transceiver;\n        var iceGatherer;\n        var iceTransport;\n        var dtlsTransport;\n        var rtpSender;\n        var rtpReceiver;\n        var sendSsrc;\n        var recvSsrc;\n        var localCapabilities;\n\n        var track;\n        // FIXME: ensure the mediaSection has rtcp-mux set.\n        var remoteCapabilities = SDPUtils.parseRtpParameters(mediaSection);\n        var remoteIceParameters;\n        var remoteDtlsParameters;\n        if (!rejected) {\n          remoteIceParameters = SDPUtils.getIceParameters(mediaSection,\n              sessionpart);\n          remoteDtlsParameters = SDPUtils.getDtlsParameters(mediaSection,\n              sessionpart);\n        }\n        var mid = SDPUtils.matchPrefix(mediaSection, 'a=mid:')[0].substr(6);\n\n        var cname;\n        // Gets the first SSRC. Note that with RTX there might be multiple SSRCs.\n        var remoteSsrc = SDPUtils.matchPrefix(mediaSection, 'a=ssrc:')\n            .map(function(line) {\n              return SDPUtils.parseSsrcMedia(line);\n            })\n            .filter(function(obj) {\n              return obj.attribute === 'cname';\n            })[0];\n        if (remoteSsrc) {\n          recvSsrc = parseInt(remoteSsrc.ssrc, 10);\n          cname = remoteSsrc.value;\n        }\n\n        if (description.type === 'offer') {\n          var transports = self._createIceAndDtlsTransports(mid, sdpMLineIndex);\n\n          localCapabilities = RTCRtpReceiver.getCapabilities(kind);\n          sendSsrc = (2 * sdpMLineIndex + 2) * 1001;\n\n          rtpReceiver = new RTCRtpReceiver(transports.dtlsTransport, kind);\n\n          track = rtpReceiver.track;\n          receiverList.push([track, rtpReceiver]);\n          // FIXME: not correct when there are multiple streams but that is\n          // not currently supported in this shim.\n          stream.addTrack(track);\n\n          // FIXME: look at direction.\n          if (self.localStreams.length > 0 &&\n              self.localStreams[0].getTracks().length >= sdpMLineIndex) {\n            // FIXME: actually more complicated, needs to match types etc\n            var localtrack = self.localStreams[0].getTracks()[sdpMLineIndex];\n            rtpSender = new RTCRtpSender(localtrack, transports.dtlsTransport);\n          }\n\n          self.transceivers[sdpMLineIndex] = {\n            iceGatherer: transports.iceGatherer,\n            iceTransport: transports.iceTransport,\n            dtlsTransport: transports.dtlsTransport,\n            localCapabilities: localCapabilities,\n            remoteCapabilities: remoteCapabilities,\n            rtpSender: rtpSender,\n            rtpReceiver: rtpReceiver,\n            kind: kind,\n            mid: mid,\n            cname: cname,\n            sendSsrc: sendSsrc,\n            recvSsrc: recvSsrc\n          };\n          // Start the RTCRtpReceiver now. The RTPSender is started in setLocalDescription.\n          self._transceive(self.transceivers[sdpMLineIndex],\n              false,\n              direction === 'sendrecv' || direction === 'sendonly');\n        } else if (description.type === 'answer' && !rejected) {\n          transceiver = self.transceivers[sdpMLineIndex];\n          iceGatherer = transceiver.iceGatherer;\n          iceTransport = transceiver.iceTransport;\n          dtlsTransport = transceiver.dtlsTransport;\n          rtpSender = transceiver.rtpSender;\n          rtpReceiver = transceiver.rtpReceiver;\n          sendSsrc = transceiver.sendSsrc;\n          //recvSsrc = transceiver.recvSsrc;\n          localCapabilities = transceiver.localCapabilities;\n\n          self.transceivers[sdpMLineIndex].recvSsrc = recvSsrc;\n          self.transceivers[sdpMLineIndex].remoteCapabilities =\n              remoteCapabilities;\n          self.transceivers[sdpMLineIndex].cname = cname;\n\n          iceTransport.start(iceGatherer, remoteIceParameters, 'controlling');\n          dtlsTransport.start(remoteDtlsParameters);\n\n          self._transceive(transceiver,\n              direction === 'sendrecv' || direction === 'recvonly',\n              direction === 'sendrecv' || direction === 'sendonly');\n\n          if (rtpReceiver &&\n              (direction === 'sendrecv' || direction === 'sendonly')) {\n            track = rtpReceiver.track;\n            receiverList.push([track, rtpReceiver]);\n            stream.addTrack(track);\n          } else {\n            // FIXME: actually the receiver should be created later.\n            delete transceiver.rtpReceiver;\n          }\n        }\n      });\n\n      this.remoteDescription = {\n          type: description.type,\n          sdp: description.sdp\n      };\n      switch (description.type) {\n        case 'offer':\n          this._updateSignalingState('have-remote-offer');\n          break;\n        case 'answer':\n          this._updateSignalingState('stable');\n          break;\n        default:\n          throw new TypeError('unsupported type \"' + description.type + '\"');\n      }\n      if (stream.getTracks().length) {\n        self.remoteStreams.push(stream);\n        window.setTimeout(function() {\n          var event = new Event('addstream');\n          event.stream = stream;\n          self.dispatchEvent(event);\n          if (self.onaddstream !== null) {\n            window.setTimeout(function() {\n              self.onaddstream(event);\n            }, 0);\n          }\n\n          receiverList.forEach(function(item) {\n            var track = item[0];\n            var receiver = item[1];\n            var event = new Event('track');\n            event.track = track;\n            event.receiver = receiver;\n            event.streams = [stream];\n            self.dispatchEvent(event);\n            if (self.ontrack !== null) {\n                window.setTimeout(function() {\n                  self.ontrack(event);\n                }, 0);\n            }\n          });\n        }, 0);\n      }\n      if (arguments.length > 1 && typeof arguments[1] === 'function') {\n        window.setTimeout(arguments[1], 0);\n      }\n      return Promise.resolve();\n    };\n\n    window.RTCPeerConnection.prototype.close = function() {\n      this.transceivers.forEach(function(transceiver) {\n        /* not yet\n        if (transceiver.iceGatherer) {\n          transceiver.iceGatherer.close();\n        }\n        */\n        if (transceiver.iceTransport) {\n          transceiver.iceTransport.stop();\n        }\n        if (transceiver.dtlsTransport) {\n          transceiver.dtlsTransport.stop();\n        }\n        if (transceiver.rtpSender) {\n          transceiver.rtpSender.stop();\n        }\n        if (transceiver.rtpReceiver) {\n          transceiver.rtpReceiver.stop();\n        }\n      });\n      // FIXME: clean up tracks, local streams, remote streams, etc\n      this._updateSignalingState('closed');\n    };\n\n    // Update the signaling state.\n    window.RTCPeerConnection.prototype._updateSignalingState =\n        function(newState) {\n      this.signalingState = newState;\n      var event = new Event('signalingstatechange');\n      this.dispatchEvent(event);\n      if (this.onsignalingstatechange !== null) {\n        this.onsignalingstatechange(event);\n      }\n    };\n\n    // Determine whether to fire the negotiationneeded event.\n    window.RTCPeerConnection.prototype._maybeFireNegotiationNeeded =\n        function() {\n      // Fire away (for now).\n      var event = new Event('negotiationneeded');\n      this.dispatchEvent(event);\n      if (this.onnegotiationneeded !== null) {\n        this.onnegotiationneeded(event);\n      }\n    };\n\n    // Update the connection state.\n    window.RTCPeerConnection.prototype._updateConnectionState =\n        function() {\n      var self = this;\n      var newState;\n      var states = {\n        'new': 0,\n        closed: 0,\n        connecting: 0,\n        checking: 0,\n        connected: 0,\n        completed: 0,\n        failed: 0\n      };\n      this.transceivers.forEach(function(transceiver) {\n        states[transceiver.iceTransport.state]++;\n        states[transceiver.dtlsTransport.state]++;\n      });\n      // ICETransport.completed and connected are the same for this purpose.\n      states['connected'] += states['completed'];\n\n      newState = 'new';\n      if (states['failed'] > 0) {\n        newState = 'failed';\n      } else if (states['connecting'] > 0 || states['checking'] > 0) {\n        newState = 'connecting';\n      } else if (states['disconnected'] > 0) {\n        newState = 'disconnected';\n      } else if (states['new'] > 0) {\n        newState = 'new';\n      } else if (states['connecting'] > 0 || states['completed'] > 0) {\n        newState = 'connected';\n      }\n\n      if (newState !== self.iceConnectionState) {\n        self.iceConnectionState = newState;\n        var event = new Event('iceconnectionstatechange');\n        this.dispatchEvent(event);\n        if (this.oniceconnectionstatechange !== null) {\n          this.oniceconnectionstatechange(event);\n        }\n      }\n    };\n\n    window.RTCPeerConnection.prototype.createOffer = function() {\n      var self = this;\n      if (this._pendingOffer) {\n        throw new Error('createOffer called while there is a pending offer.');\n      }\n      var offerOptions;\n      if (arguments.length === 1 && typeof arguments[0] !== 'function') {\n        offerOptions = arguments[0];\n      } else if (arguments.length === 3) {\n        offerOptions = arguments[2];\n      }\n\n      var tracks = [];\n      var numAudioTracks = 0;\n      var numVideoTracks = 0;\n      // Default to sendrecv.\n      if (this.localStreams.length) {\n        numAudioTracks = this.localStreams[0].getAudioTracks().length;\n        numVideoTracks = this.localStreams[0].getVideoTracks().length;\n      }\n      // Determine number of audio and video tracks we need to send/recv.\n      if (offerOptions) {\n        // Reject Chrome legacy constraints.\n        if (offerOptions.mandatory || offerOptions.optional) {\n          throw new TypeError(\n              'Legacy mandatory/optional constraints not supported.');\n        }\n        if (offerOptions.offerToReceiveAudio !== undefined) {\n          numAudioTracks = offerOptions.offerToReceiveAudio;\n        }\n        if (offerOptions.offerToReceiveVideo !== undefined) {\n          numVideoTracks = offerOptions.offerToReceiveVideo;\n        }\n      }\n      if (this.localStreams.length) {\n        // Push local streams.\n        this.localStreams[0].getTracks().forEach(function(track) {\n          tracks.push({\n            kind: track.kind,\n            track: track,\n            wantReceive: track.kind === 'audio' ?\n                numAudioTracks > 0 : numVideoTracks > 0\n          });\n          if (track.kind === 'audio') {\n            numAudioTracks--;\n          } else if (track.kind === 'video') {\n            numVideoTracks--;\n          }\n        });\n      }\n      // Create M-lines for recvonly streams.\n      while (numAudioTracks > 0 || numVideoTracks > 0) {\n        if (numAudioTracks > 0) {\n          tracks.push({\n            kind: 'audio',\n            wantReceive: true\n          });\n          numAudioTracks--;\n        }\n        if (numVideoTracks > 0) {\n          tracks.push({\n            kind: 'video',\n            wantReceive: true\n          });\n          numVideoTracks--;\n        }\n      }\n\n      var sdp = SDPUtils.writeSessionBoilerplate();\n      var transceivers = [];\n      tracks.forEach(function(mline, sdpMLineIndex) {\n        // For each track, create an ice gatherer, ice transport, dtls transport,\n        // potentially rtpsender and rtpreceiver.\n        var track = mline.track;\n        var kind = mline.kind;\n        var mid = SDPUtils.generateIdentifier();\n\n        var transports = self._createIceAndDtlsTransports(mid, sdpMLineIndex);\n\n        var localCapabilities = RTCRtpSender.getCapabilities(kind);\n        var rtpSender;\n        var rtpReceiver;\n\n        // generate an ssrc now, to be used later in rtpSender.send\n        var sendSsrc = (2 * sdpMLineIndex + 1) * 1001;\n        if (track) {\n          rtpSender = new RTCRtpSender(track, transports.dtlsTransport);\n        }\n\n        if (mline.wantReceive) {\n          rtpReceiver = new RTCRtpReceiver(transports.dtlsTransport, kind);\n        }\n\n        transceivers[sdpMLineIndex] = {\n          iceGatherer: transports.iceGatherer,\n          iceTransport: transports.iceTransport,\n          dtlsTransport: transports.dtlsTransport,\n          localCapabilities: localCapabilities,\n          remoteCapabilities: null,\n          rtpSender: rtpSender,\n          rtpReceiver: rtpReceiver,\n          kind: kind,\n          mid: mid,\n          sendSsrc: sendSsrc,\n          recvSsrc: null\n        };\n        var transceiver = transceivers[sdpMLineIndex];\n        sdp += SDPUtils.writeMediaSection(transceiver,\n            transceiver.localCapabilities, 'offer', self.localStreams[0]);\n      });\n\n      this._pendingOffer = transceivers;\n      var desc = new RTCSessionDescription({\n        type: 'offer',\n        sdp: sdp\n      });\n      if (arguments.length && typeof arguments[0] === 'function') {\n        window.setTimeout(arguments[0], 0, desc);\n      }\n      return Promise.resolve(desc);\n    };\n\n    window.RTCPeerConnection.prototype.createAnswer = function() {\n      var self = this;\n      var answerOptions;\n      if (arguments.length === 1 && typeof arguments[0] !== 'function') {\n        answerOptions = arguments[0];\n      } else if (arguments.length === 3) {\n        answerOptions = arguments[2];\n      }\n\n      var sdp = SDPUtils.writeSessionBoilerplate();\n      this.transceivers.forEach(function(transceiver) {\n        // Calculate intersection of capabilities.\n        var commonCapabilities = self._getCommonCapabilities(\n            transceiver.localCapabilities,\n            transceiver.remoteCapabilities);\n\n        sdp += SDPUtils.writeMediaSection(transceiver, commonCapabilities,\n            'answer', self.localStreams[0]);\n      });\n\n      var desc = new RTCSessionDescription({\n        type: 'answer',\n        sdp: sdp\n      });\n      if (arguments.length && typeof arguments[0] === 'function') {\n        window.setTimeout(arguments[0], 0, desc);\n      }\n      return Promise.resolve(desc);\n    };\n\n    window.RTCPeerConnection.prototype.addIceCandidate = function(candidate) {\n      var mLineIndex = candidate.sdpMLineIndex;\n      if (candidate.sdpMid) {\n        for (var i = 0; i < this.transceivers.length; i++) {\n          if (this.transceivers[i].mid === candidate.sdpMid) {\n            mLineIndex = i;\n            break;\n          }\n        }\n      }\n      var transceiver = this.transceivers[mLineIndex];\n      if (transceiver) {\n        var cand = Object.keys(candidate.candidate).length > 0 ?\n            SDPUtils.parseCandidate(candidate.candidate) : {};\n        // Ignore Chrome's invalid candidates since Edge does not like them.\n        if (cand.protocol === 'tcp' && cand.port === 0) {\n          return;\n        }\n        // Ignore RTCP candidates, we assume RTCP-MUX.\n        if (cand.component !== '1') {\n          return;\n        }\n        // A dirty hack to make samples work.\n        if (cand.type === 'endOfCandidates') {\n          cand = {};\n        }\n        transceiver.iceTransport.addRemoteCandidate(cand);\n\n        // update the remoteDescription.\n        var sections = SDPUtils.splitSections(this.remoteDescription.sdp);\n        sections[mLineIndex + 1] += (cand.type ? candidate.candidate.trim()\n            : 'a=end-of-candidates') + '\\r\\n';\n        this.remoteDescription.sdp = sections.join('');\n      }\n      if (arguments.length > 1 && typeof arguments[1] === 'function') {\n        window.setTimeout(arguments[1], 0);\n      }\n      return Promise.resolve();\n    };\n\n    window.RTCPeerConnection.prototype.getStats = function() {\n      var promises = [];\n      this.transceivers.forEach(function(transceiver) {\n        ['rtpSender', 'rtpReceiver', 'iceGatherer', 'iceTransport',\n            'dtlsTransport'].forEach(function(method) {\n          if (transceiver[method]) {\n            promises.push(transceiver[method].getStats());\n          }\n        });\n      });\n      var cb = arguments.length > 1 && typeof arguments[1] === 'function' &&\n          arguments[1];\n      return new Promise(function(resolve) {\n        var results = {};\n        Promise.all(promises).then(function(res) {\n          res.forEach(function(result) {\n            Object.keys(result).forEach(function(id) {\n              results[id] = result[id];\n            });\n          });\n          if (cb) {\n            window.setTimeout(cb, 0, results);\n          }\n          resolve(results);\n        });\n      });\n    };\n  },\n\n  // Attach a media stream to an element.\n  attachMediaStream: function(element, stream) {\n    logging('DEPRECATED, attachMediaStream will soon be removed.');\n    element.srcObject = stream;\n  },\n\n  reattachMediaStream: function(to, from) {\n    logging('DEPRECATED, reattachMediaStream will soon be removed.');\n    to.srcObject = from.srcObject;\n  }\n}\n\n// Expose public methods.\nmodule.exports = {\n  shimPeerConnection: edgeShim.shimPeerConnection,\n  attachMediaStream: edgeShim.attachMediaStream,\n  reattachMediaStream: edgeShim.reattachMediaStream\n}\n\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/edge/edge_shim.js\n ** module id = 150\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\nvar logging = require('../utils').log;\nvar browserDetails = require('../utils').browserDetails;\n\nvar firefoxShim = {\n  shimOnTrack: function() {\n    if (typeof window === 'object' && window.RTCPeerConnection && !('ontrack' in\n        window.RTCPeerConnection.prototype)) {\n      Object.defineProperty(window.RTCPeerConnection.prototype, 'ontrack', {\n        get: function() { return this._ontrack; },\n        set: function(f) {\n          var self = this;\n          if (this._ontrack) {\n            this.removeEventListener('track', this._ontrack);\n            this.removeEventListener('addstream', this._ontrackpoly);\n          }\n          this.addEventListener('track', this._ontrack = f);\n          this.addEventListener('addstream', this._ontrackpoly = function(e) {\n            e.stream.getTracks().forEach(function(track) {\n              var event = new Event('track');\n              event.track = track;\n              event.receiver = {track: track};\n              event.streams = [e.stream];\n              this.dispatchEvent(event);\n            }.bind(this));\n          }.bind(this));\n        }\n      });\n    }\n  },\n\n  shimSourceObject: function() {\n    // Firefox has supported mozSrcObject since FF22, unprefixed in 42.\n    if (typeof window === 'object') {\n      if (window.HTMLMediaElement &&\n        !('srcObject' in window.HTMLMediaElement.prototype)) {\n        // Shim the srcObject property, once, when HTMLMediaElement is found.\n        Object.defineProperty(window.HTMLMediaElement.prototype, 'srcObject', {\n          get: function() {\n            return this.mozSrcObject;\n          },\n          set: function(stream) {\n            this.mozSrcObject = stream;\n          }\n        });\n      }\n    }\n  },\n\n  shimPeerConnection: function() {\n    // The RTCPeerConnection object.\n    if (!window.RTCPeerConnection) {\n      window.RTCPeerConnection = function(pcConfig, pcConstraints) {\n        if (browserDetails.version < 38) {\n          // .urls is not supported in FF < 38.\n          // create RTCIceServers with a single url.\n          if (pcConfig && pcConfig.iceServers) {\n            var newIceServers = [];\n            for (var i = 0; i < pcConfig.iceServers.length; i++) {\n              var server = pcConfig.iceServers[i];\n              if (server.hasOwnProperty('urls')) {\n                for (var j = 0; j < server.urls.length; j++) {\n                  var newServer = {\n                    url: server.urls[j]\n                  };\n                  if (server.urls[j].indexOf('turn') === 0) {\n                    newServer.username = server.username;\n                    newServer.credential = server.credential;\n                  }\n                  newIceServers.push(newServer);\n                }\n              } else {\n                newIceServers.push(pcConfig.iceServers[i]);\n              }\n            }\n            pcConfig.iceServers = newIceServers;\n          }\n        }\n        return new mozRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors\n      };\n      window.RTCPeerConnection.prototype = mozRTCPeerConnection.prototype;\n\n      // wrap static methods. Currently just generateCertificate.\n      if (mozRTCPeerConnection.generateCertificate) {\n        Object.defineProperty(window.RTCPeerConnection, 'generateCertificate', {\n          get: function() {\n            if (arguments.length) {\n              return mozRTCPeerConnection.generateCertificate.apply(null,\n                  arguments);\n            } else {\n              return mozRTCPeerConnection.generateCertificate;\n            }\n          }\n        });\n      }\n\n      window.RTCSessionDescription = mozRTCSessionDescription;\n      window.RTCIceCandidate = mozRTCIceCandidate;\n    }\n  },\n\n  shimGetUserMedia: function() {\n    // getUserMedia constraints shim.\n    var getUserMedia_ = function(constraints, onSuccess, onError) {\n      var constraintsToFF37_ = function(c) {\n        if (typeof c !== 'object' || c.require) {\n          return c;\n        }\n        var require = [];\n        Object.keys(c).forEach(function(key) {\n          if (key === 'require' || key === 'advanced' || key === 'mediaSource') {\n            return;\n          }\n          var r = c[key] = (typeof c[key] === 'object') ?\n              c[key] : {ideal: c[key]};\n          if (r.min !== undefined ||\n              r.max !== undefined || r.exact !== undefined) {\n            require.push(key);\n          }\n          if (r.exact !== undefined) {\n            if (typeof r.exact === 'number') {\n              r. min = r.max = r.exact;\n            } else {\n              c[key] = r.exact;\n            }\n            delete r.exact;\n          }\n          if (r.ideal !== undefined) {\n            c.advanced = c.advanced || [];\n            var oc = {};\n            if (typeof r.ideal === 'number') {\n              oc[key] = {min: r.ideal, max: r.ideal};\n            } else {\n              oc[key] = r.ideal;\n            }\n            c.advanced.push(oc);\n            delete r.ideal;\n            if (!Object.keys(r).length) {\n              delete c[key];\n            }\n          }\n        });\n        if (require.length) {\n          c.require = require;\n        }\n        return c;\n      };\n      if (browserDetails.version < 38) {\n        logging('spec: ' + JSON.stringify(constraints));\n        if (constraints.audio) {\n          constraints.audio = constraintsToFF37_(constraints.audio);\n        }\n        if (constraints.video) {\n          constraints.video = constraintsToFF37_(constraints.video);\n        }\n        logging('ff37: ' + JSON.stringify(constraints));\n      }\n      return navigator.mozGetUserMedia(constraints, onSuccess, onError);\n    };\n\n    navigator.getUserMedia = getUserMedia_;\n\n    // Returns the result of getUserMedia as a Promise.\n    var getUserMediaPromise_ = function(constraints) {\n      return new Promise(function(resolve, reject) {\n        navigator.getUserMedia(constraints, resolve, reject);\n      });\n    }\n\n    // Shim for mediaDevices on older versions.\n    if (!navigator.mediaDevices) {\n      navigator.mediaDevices = {getUserMedia: getUserMediaPromise_,\n        addEventListener: function() { },\n        removeEventListener: function() { }\n      };\n    }\n    navigator.mediaDevices.enumerateDevices =\n        navigator.mediaDevices.enumerateDevices || function() {\n      return new Promise(function(resolve) {\n        var infos = [\n          {kind: 'audioinput', deviceId: 'default', label: '', groupId: ''},\n          {kind: 'videoinput', deviceId: 'default', label: '', groupId: ''}\n        ];\n        resolve(infos);\n      });\n    };\n\n    if (browserDetails.version < 41) {\n      // Work around http://bugzil.la/1169665\n      var orgEnumerateDevices =\n          navigator.mediaDevices.enumerateDevices.bind(navigator.mediaDevices);\n      navigator.mediaDevices.enumerateDevices = function() {\n        return orgEnumerateDevices().then(undefined, function(e) {\n          if (e.name === 'NotFoundError') {\n            return [];\n          }\n          throw e;\n        });\n      };\n    }\n  },\n\n  // Attach a media stream to an element.\n  attachMediaStream: function(element, stream) {\n    logging('DEPRECATED, attachMediaStream will soon be removed.');\n    element.srcObject = stream;\n  },\n\n  reattachMediaStream: function(to, from) {\n    logging('DEPRECATED, reattachMediaStream will soon be removed.');\n    to.srcObject = from.srcObject;\n  }\n}\n\n// Expose public methods.\nmodule.exports = {\n  shimOnTrack: firefoxShim.shimOnTrack,\n  shimSourceObject: firefoxShim.shimSourceObject,\n  shimPeerConnection: firefoxShim.shimPeerConnection,\n  shimGetUserMedia: require('./getusermedia'),\n  attachMediaStream: firefoxShim.attachMediaStream,\n  reattachMediaStream: firefoxShim.reattachMediaStream\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/firefox/firefox_shim.js\n ** module id = 151\n ** module chunks = 0\n **/","/*\n *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.\n *\n *  Use of this source code is governed by a BSD-style license\n *  that can be found in the LICENSE file in the root of the source\n *  tree.\n */\n'use strict';\n\nvar logging = require('../utils').log;\nvar browserDetails = require('../utils').browserDetails;\n\n// Expose public methods.\nmodule.exports = function() {\n  // getUserMedia constraints shim.\n  var getUserMedia_ = function(constraints, onSuccess, onError) {\n    var constraintsToFF37_ = function(c) {\n      if (typeof c !== 'object' || c.require) {\n        return c;\n      }\n      var require = [];\n      Object.keys(c).forEach(function(key) {\n        if (key === 'require' || key === 'advanced' || key === 'mediaSource') {\n          return;\n        }\n        var r = c[key] = (typeof c[key] === 'object') ?\n            c[key] : {ideal: c[key]};\n        if (r.min !== undefined ||\n            r.max !== undefined || r.exact !== undefined) {\n          require.push(key);\n        }\n        if (r.exact !== undefined) {\n          if (typeof r.exact === 'number') {\n            r. min = r.max = r.exact;\n          } else {\n            c[key] = r.exact;\n          }\n          delete r.exact;\n        }\n        if (r.ideal !== undefined) {\n          c.advanced = c.advanced || [];\n          var oc = {};\n          if (typeof r.ideal === 'number') {\n            oc[key] = {min: r.ideal, max: r.ideal};\n          } else {\n            oc[key] = r.ideal;\n          }\n          c.advanced.push(oc);\n          delete r.ideal;\n          if (!Object.keys(r).length) {\n            delete c[key];\n          }\n        }\n      });\n      if (require.length) {\n        c.require = require;\n      }\n      return c;\n    };\n    if (browserDetails.version < 38) {\n      logging('spec: ' + JSON.stringify(constraints));\n      if (constraints.audio) {\n        constraints.audio = constraintsToFF37_(constraints.audio);\n      }\n      if (constraints.video) {\n        constraints.video = constraintsToFF37_(constraints.video);\n      }\n      logging('ff37: ' + JSON.stringify(constraints));\n    }\n    return navigator.mozGetUserMedia(constraints, onSuccess, onError);\n  };\n\n  navigator.getUserMedia = getUserMedia_;\n\n  // Returns the result of getUserMedia as a Promise.\n  var getUserMediaPromise_ = function(constraints) {\n    return new Promise(function(resolve, reject) {\n      navigator.getUserMedia(constraints, resolve, reject);\n    });\n  }\n\n  // Shim for mediaDevices on older versions.\n  if (!navigator.mediaDevices) {\n    navigator.mediaDevices = {getUserMedia: getUserMediaPromise_,\n      addEventListener: function() { },\n      removeEventListener: function() { }\n    };\n  }\n  navigator.mediaDevices.enumerateDevices =\n      navigator.mediaDevices.enumerateDevices || function() {\n    return new Promise(function(resolve) {\n      var infos = [\n        {kind: 'audioinput', deviceId: 'default', label: '', groupId: ''},\n        {kind: 'videoinput', deviceId: 'default', label: '', groupId: ''}\n      ];\n      resolve(infos);\n    });\n  };\n\n  if (browserDetails.version < 41) {\n    // Work around http://bugzil.la/1169665\n    var orgEnumerateDevices =\n        navigator.mediaDevices.enumerateDevices.bind(navigator.mediaDevices);\n    navigator.mediaDevices.enumerateDevices = function() {\n      return orgEnumerateDevices().then(undefined, function(e) {\n        if (e.name === 'NotFoundError') {\n          return [];\n        }\n        throw e;\n      });\n    };\n  }\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/webrtc-adapter/src/js/firefox/getusermedia.js\n ** module id = 152\n ** module chunks = 0\n **/","module.e = __WEBPACK_EXTERNAL_MODULE_153__;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external \"get-pixels\"\n ** module id = 153\n ** module chunks = 0\n **/","module.e = __WEBPACK_EXTERNAL_MODULE_154__;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external \"ndarray\"\n ** module id = 154\n ** module chunks = 0\n **/","module.e = __WEBPACK_EXTERNAL_MODULE_155__;\n\n\n/*****************\n ** WEBPACK FOOTER\n ** external \"ndarray-linear-interpolate\"\n ** module id = 155\n ** module chunks = 0\n **/"],"sourceRoot":""} \ No newline at end of file