You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
12402 lines
1.1 MiB
12402 lines
1.1 MiB
(function webpackUniversalModuleDefinition(root, factory) {
|
|
if(typeof exports === 'object' && typeof module === 'object')
|
|
module.exports = factory(factory.toString()).default;
|
|
else if(typeof exports === 'object')
|
|
exports["Quagga"] = factory(factory.toString()).default;
|
|
else
|
|
root["Quagga"] = factory(factory.toString()).default;
|
|
})(this, function(__factorySource__) {
|
|
return /******/ (function(modules) { // webpackBootstrap
|
|
/******/ // The module cache
|
|
/******/ var installedModules = {};
|
|
/******/
|
|
/******/ // The require function
|
|
/******/ function __webpack_require__(moduleId) {
|
|
/******/
|
|
/******/ // Check if module is in cache
|
|
/******/ if(installedModules[moduleId])
|
|
/******/ return installedModules[moduleId].e;
|
|
/******/
|
|
/******/ // Create a new module (and put it into the cache)
|
|
/******/ var module = installedModules[moduleId] = {
|
|
/******/ e: {},
|
|
/******/ i: moduleId,
|
|
/******/ l: false
|
|
/******/ };
|
|
/******/
|
|
/******/ // Execute the module function
|
|
/******/ modules[moduleId].call(module.e, module, module.e, __webpack_require__);
|
|
/******/
|
|
/******/ // Flag the module as loaded
|
|
/******/ module.l = true;
|
|
/******/
|
|
/******/ // Return the exports of the module
|
|
/******/ return module.e;
|
|
/******/ }
|
|
/******/
|
|
/******/
|
|
/******/ // expose the modules object (__webpack_modules__)
|
|
/******/ __webpack_require__.m = modules;
|
|
/******/
|
|
/******/ // expose the module cache
|
|
/******/ __webpack_require__.c = installedModules;
|
|
/******/
|
|
/******/ // __webpack_public_path__
|
|
/******/ __webpack_require__.p = "/";
|
|
/******/
|
|
/******/ // Load entry module and return exports
|
|
/******/ return __webpack_require__(__webpack_require__.s = 154);
|
|
/******/ })
|
|
/************************************************************************/
|
|
/******/ ([
|
|
/* 0 */
|
|
/***/ 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 logDisabled_ = false;
|
|
|
|
// 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';
|
|
},
|
|
|
|
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;
|
|
}
|
|
|
|
// 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!');
|
|
}
|
|
|
|
return result;
|
|
}
|
|
};
|
|
|
|
// 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);
|
|
|
|
/** 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 free variable `global` from Node.js. */
|
|
var freeGlobal = checkGlobal(freeExports && freeModule && typeof global == 'object' && global);
|
|
|
|
/** Detect free variable `self`. */
|
|
var freeSelf = checkGlobal(objectTypes[typeof self] && self);
|
|
|
|
/** Detect free variable `window`. */
|
|
var freeWindow = checkGlobal(objectTypes[typeof window] && window);
|
|
|
|
/** Detect `this` as the global object. */
|
|
var thisGlobal = checkGlobal(objectTypes[typeof this] && this);
|
|
|
|
/**
|
|
* 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')();
|
|
|
|
module.e = root;
|
|
|
|
/* 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');
|
|
}
|
|
|
|
module.e = isObject;
|
|
|
|
|
|
/***/ },
|
|
/* 3 */
|
|
/***/ 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 Map = getNative(root, 'Map');
|
|
|
|
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;
|
|
|
|
module.e = isArray;
|
|
|
|
|
|
/***/ },
|
|
/* 5 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
function BarcodeReader(config) {
|
|
this._row = [];
|
|
this.config = config || {};
|
|
return this;
|
|
}
|
|
|
|
BarcodeReader.prototype._nextUnset = function (line, start) {
|
|
var i;
|
|
|
|
if (start === undefined) {
|
|
start = 0;
|
|
}
|
|
for (i = start; i < line.length; i++) {
|
|
if (!line[i]) {
|
|
return i;
|
|
}
|
|
}
|
|
return line.length;
|
|
};
|
|
|
|
BarcodeReader.prototype._matchPattern = function (counter, code) {
|
|
var i,
|
|
error = 0,
|
|
singleError = 0,
|
|
modulo = this.MODULO,
|
|
maxSingleError = this.SINGLE_CODE_ERROR || 1;
|
|
|
|
for (i = 0; i < counter.length; i++) {
|
|
singleError = Math.abs(code[i] - counter[i]);
|
|
if (singleError > maxSingleError) {
|
|
return Number.MAX_VALUE;
|
|
}
|
|
error += singleError;
|
|
}
|
|
return error / modulo;
|
|
};
|
|
|
|
BarcodeReader.prototype._nextSet = function (line, offset) {
|
|
var i;
|
|
|
|
offset = offset || 0;
|
|
for (i = offset; i < line.length; i++) {
|
|
if (line[i]) {
|
|
return i;
|
|
}
|
|
}
|
|
return line.length;
|
|
};
|
|
|
|
BarcodeReader.prototype._normalize = function (counter, modulo) {
|
|
var i,
|
|
self = this,
|
|
sum = 0,
|
|
ratio,
|
|
numOnes = 0,
|
|
normalized = [],
|
|
norm = 0;
|
|
|
|
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 {
|
|
ratio = (sum + numOnes) / modulo;
|
|
for (i = 0; i < counter.length; i++) {
|
|
norm = counter[i] / ratio;
|
|
normalized.push(norm);
|
|
}
|
|
}
|
|
return normalized;
|
|
};
|
|
|
|
BarcodeReader.prototype._matchTrace = function (cmpCounter, epsilon) {
|
|
var counter = [],
|
|
i,
|
|
self = this,
|
|
offset = self._nextSet(self._row),
|
|
isWhite = !self._row[offset],
|
|
counterPos = 0,
|
|
bestMatch = {
|
|
error: Number.MAX_VALUE,
|
|
code: -1,
|
|
start: 0
|
|
},
|
|
error;
|
|
|
|
if (cmpCounter) {
|
|
for (i = 0; i < cmpCounter.length; i++) {
|
|
counter.push(0);
|
|
}
|
|
for (i = offset; i < self._row.length; i++) {
|
|
if (self._row[i] ^ isWhite) {
|
|
counter[counterPos]++;
|
|
} else {
|
|
if (counterPos === counter.length - 1) {
|
|
error = self._matchPattern(counter, cmpCounter);
|
|
|
|
if (error < epsilon) {
|
|
bestMatch.start = i - offset;
|
|
bestMatch.end = i;
|
|
bestMatch.counter = counter;
|
|
return bestMatch;
|
|
} else {
|
|
return null;
|
|
}
|
|
} else {
|
|
counterPos++;
|
|
}
|
|
counter[counterPos] = 1;
|
|
isWhite = !isWhite;
|
|
}
|
|
}
|
|
} else {
|
|
counter.push(0);
|
|
for (i = offset; i < self._row.length; i++) {
|
|
if (self._row[i] ^ isWhite) {
|
|
counter[counterPos]++;
|
|
} else {
|
|
counterPos++;
|
|
counter.push(0);
|
|
counter[counterPos] = 1;
|
|
isWhite = !isWhite;
|
|
}
|
|
}
|
|
}
|
|
|
|
// if cmpCounter was not given
|
|
bestMatch.start = offset;
|
|
bestMatch.end = self._row.length - 1;
|
|
bestMatch.counter = counter;
|
|
return bestMatch;
|
|
};
|
|
|
|
BarcodeReader.prototype.decodePattern = function (pattern) {
|
|
var self = this,
|
|
result;
|
|
|
|
self._row = pattern;
|
|
result = self._decode();
|
|
if (result === null) {
|
|
self._row.reverse();
|
|
result = self._decode();
|
|
if (result) {
|
|
result.direction = BarcodeReader.DIRECTION.REVERSE;
|
|
result.start = self._row.length - result.start;
|
|
result.end = self._row.length - result.end;
|
|
}
|
|
} else {
|
|
result.direction = BarcodeReader.DIRECTION.FORWARD;
|
|
}
|
|
if (result) {
|
|
result.format = self.FORMAT;
|
|
}
|
|
return result;
|
|
};
|
|
|
|
BarcodeReader.prototype._matchRange = function (start, end, value) {
|
|
var i;
|
|
|
|
start = start < 0 ? 0 : start;
|
|
for (i = start; i < end; i++) {
|
|
if (this._row[i] !== value) {
|
|
return false;
|
|
}
|
|
}
|
|
return true;
|
|
};
|
|
|
|
BarcodeReader.prototype._fillCounters = function (offset, end, isWhite) {
|
|
var self = this,
|
|
counterPos = 0,
|
|
i,
|
|
counters = [];
|
|
|
|
isWhite = typeof isWhite !== 'undefined' ? isWhite : true;
|
|
offset = typeof offset !== 'undefined' ? offset : self._nextUnset(self._row);
|
|
end = end || self._row.length;
|
|
|
|
counters[counterPos] = 0;
|
|
for (i = offset; i < end; i++) {
|
|
if (self._row[i] ^ isWhite) {
|
|
counters[counterPos]++;
|
|
} else {
|
|
counterPos++;
|
|
counters[counterPos] = 1;
|
|
isWhite = !isWhite;
|
|
}
|
|
}
|
|
return counters;
|
|
};
|
|
|
|
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 = {};
|
|
|
|
/* harmony default export */ exports["a"] = BarcodeReader;
|
|
|
|
/***/ },
|
|
/* 6 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
module.e = clone
|
|
|
|
/**
|
|
* Creates a new vec2 initialized with values from an existing vector
|
|
*
|
|
* @param {vec2} a vector to clone
|
|
* @returns {vec2} a new 2D vector
|
|
*/
|
|
function clone(a) {
|
|
var out = new Float32Array(2)
|
|
out[0] = a[0]
|
|
out[1] = a[1]
|
|
return out
|
|
}
|
|
|
|
/***/ },
|
|
/* 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';
|
|
}
|
|
|
|
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;
|
|
}
|
|
},
|
|
|
|
/**
|
|
* Shuffles the content of an array
|
|
* @return {Array} the array itself shuffled
|
|
*/
|
|
shuffle: function shuffle(arr) {
|
|
var i = arr.length - 1,
|
|
j,
|
|
x;
|
|
for (i; i >= 0; i--) {
|
|
j = Math.floor(Math.random() * i);
|
|
x = arr[i];
|
|
arr[i] = arr[j];
|
|
arr[j] = x;
|
|
}
|
|
return arr;
|
|
},
|
|
|
|
toPointList: function toPointList(arr) {
|
|
var i,
|
|
j,
|
|
row = [],
|
|
rows = [];
|
|
for (i = 0; i < arr.length; i++) {
|
|
row = [];
|
|
for (j = 0; j < arr[i].length; j++) {
|
|
row[j] = arr[i][j];
|
|
}
|
|
rows[i] = "[" + row.join(",") + "]";
|
|
}
|
|
return "[" + rows.join(",\r\n") + "]";
|
|
},
|
|
|
|
/**
|
|
* returns the elements which's score is bigger than the threshold
|
|
* @return {Array} the reduced array
|
|
*/
|
|
threshold: function threshold(arr, _threshold, scoreFunc) {
|
|
var i,
|
|
queue = [];
|
|
for (i = 0; i < arr.length; i++) {
|
|
if (scoreFunc.apply(arr, [arr[i]]) >= _threshold) {
|
|
queue.push(arr[i]);
|
|
}
|
|
}
|
|
return queue;
|
|
},
|
|
|
|
maxIndex: function maxIndex(arr) {
|
|
var i,
|
|
max = 0;
|
|
for (i = 0; i < arr.length; i++) {
|
|
if (arr[i] > arr[max]) {
|
|
max = i;
|
|
}
|
|
}
|
|
return max;
|
|
},
|
|
|
|
max: function max(arr) {
|
|
var i,
|
|
max = 0;
|
|
for (i = 0; i < arr.length; i++) {
|
|
if (arr[i] > max) {
|
|
max = arr[i];
|
|
}
|
|
}
|
|
return max;
|
|
},
|
|
|
|
sum: function sum(arr) {
|
|
var length = arr.length,
|
|
sum = 0;
|
|
|
|
while (length--) {
|
|
sum += arr[length];
|
|
}
|
|
return sum;
|
|
}
|
|
};
|
|
|
|
/***/ },
|
|
/* 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;
|
|
|
|
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 EANReader(opts) {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].call(this, opts);
|
|
}
|
|
|
|
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 }
|
|
};
|
|
|
|
EANReader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].prototype, properties);
|
|
EANReader.prototype.constructor = EANReader;
|
|
|
|
EANReader.prototype._decodeCode = function (start, coderange) {
|
|
var counter = [0, 0, 0, 0],
|
|
i,
|
|
self = this,
|
|
offset = start,
|
|
isWhite = !self._row[offset],
|
|
counterPos = 0,
|
|
bestMatch = {
|
|
error: Number.MAX_VALUE,
|
|
code: -1,
|
|
start: start,
|
|
end: start
|
|
},
|
|
code,
|
|
error,
|
|
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 < 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++;
|
|
}
|
|
counter[counterPos] = 1;
|
|
isWhite = !isWhite;
|
|
}
|
|
}
|
|
return null;
|
|
};
|
|
|
|
EANReader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder, epsilon) {
|
|
var counter = [],
|
|
self = this,
|
|
i,
|
|
counterPos = 0,
|
|
bestMatch = {
|
|
error: Number.MAX_VALUE,
|
|
code: -1,
|
|
start: 0,
|
|
end: 0
|
|
},
|
|
error,
|
|
j,
|
|
sum,
|
|
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]++;
|
|
} 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;
|
|
}
|
|
}
|
|
return null;
|
|
};
|
|
|
|
EANReader.prototype._findStart = function () {
|
|
var self = this,
|
|
leadingWhitespaceStart,
|
|
offset = self._nextSet(self._row),
|
|
startInfo;
|
|
|
|
while (!startInfo) {
|
|
startInfo = self._findPattern(self.START_PATTERN, offset);
|
|
if (!startInfo) {
|
|
return null;
|
|
}
|
|
leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);
|
|
if (leadingWhitespaceStart >= 0) {
|
|
if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
|
|
return startInfo;
|
|
}
|
|
}
|
|
offset = startInfo.end;
|
|
startInfo = null;
|
|
}
|
|
};
|
|
|
|
EANReader.prototype._verifyTrailingWhitespace = function (endInfo) {
|
|
var self = this,
|
|
trailingWhitespaceEnd;
|
|
|
|
trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);
|
|
if (trailingWhitespaceEnd < self._row.length) {
|
|
if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
|
|
return endInfo;
|
|
}
|
|
}
|
|
return null;
|
|
};
|
|
|
|
EANReader.prototype._findEnd = function (offset, isWhite) {
|
|
var self = this,
|
|
endInfo = self._findPattern(self.STOP_PATTERN, offset, isWhite, false);
|
|
|
|
return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;
|
|
};
|
|
|
|
EANReader.prototype._calculateFirstDigit = function (codeFrequency) {
|
|
var i,
|
|
self = this;
|
|
|
|
for (i = 0; i < self.CODE_FREQUENCY.length; i++) {
|
|
if (codeFrequency === self.CODE_FREQUENCY[i]) {
|
|
return i;
|
|
}
|
|
}
|
|
return null;
|
|
};
|
|
|
|
EANReader.prototype._decodePayload = function (code, result, decodedCodes) {
|
|
var i,
|
|
self = this,
|
|
codeFrequency = 0x0,
|
|
firstDigit;
|
|
|
|
for (i = 0; i < 6; i++) {
|
|
code = self._decodeCode(code.end);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
if (code.code >= self.CODE_G_START) {
|
|
code.code = code.code - self.CODE_G_START;
|
|
codeFrequency |= 1 << 5 - i;
|
|
} else {
|
|
codeFrequency |= 0 << 5 - i;
|
|
}
|
|
result.push(code.code);
|
|
decodedCodes.push(code);
|
|
}
|
|
|
|
firstDigit = self._calculateFirstDigit(codeFrequency);
|
|
if (firstDigit === null) {
|
|
return null;
|
|
}
|
|
result.unshift(firstDigit);
|
|
|
|
code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);
|
|
if (code === null) {
|
|
return null;
|
|
}
|
|
decodedCodes.push(code);
|
|
|
|
for (i = 0; i < 6; i++) {
|
|
code = self._decodeCode(code.end, self.CODE_G_START);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
decodedCodes.push(code);
|
|
result.push(code.code);
|
|
}
|
|
|
|
return code;
|
|
};
|
|
|
|
EANReader.prototype._decode = function () {
|
|
var startInfo,
|
|
self = this,
|
|
code,
|
|
result = [],
|
|
decodedCodes = [];
|
|
|
|
startInfo = self._findStart();
|
|
if (!startInfo) {
|
|
return null;
|
|
}
|
|
code = {
|
|
code: startInfo.code,
|
|
start: startInfo.start,
|
|
end: startInfo.end
|
|
};
|
|
decodedCodes.push(code);
|
|
code = self._decodePayload(code, result, decodedCodes);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
code = self._findEnd(code.end, false);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
|
|
decodedCodes.push(code);
|
|
|
|
// Checksum
|
|
if (!self._checksum(result)) {
|
|
return null;
|
|
}
|
|
|
|
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;
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = EANReader;
|
|
|
|
/***/ },
|
|
/* 11 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var eq = __webpack_require__(15);
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
|
|
module.e = assocIndexOf;
|
|
|
|
|
|
/***/ },
|
|
/* 12 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var isNative = __webpack_require__(140);
|
|
|
|
/**
|
|
* Gets the native function at `key` of `object`.
|
|
*
|
|
* @private
|
|
* @param {Object} object The object to query.
|
|
* @param {string} key The key of the method to get.
|
|
* @returns {*} Returns the function if it's native, else `undefined`.
|
|
*/
|
|
function getNative(object, key) {
|
|
var value = object[key];
|
|
return isNative(value) ? value : undefined;
|
|
}
|
|
|
|
module.e = getNative;
|
|
|
|
|
|
/***/ },
|
|
/* 13 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/**
|
|
* Checks if `value` is suitable for use as unique object key.
|
|
*
|
|
* @private
|
|
* @param {*} value The value to check.
|
|
* @returns {boolean} Returns `true` if `value` is suitable, else `false`.
|
|
*/
|
|
function isKeyable(value) {
|
|
var type = typeof value;
|
|
return type == 'number' || type == 'boolean' ||
|
|
(type == 'string' && value != '__proto__') || value == null;
|
|
}
|
|
|
|
module.e = isKeyable;
|
|
|
|
|
|
/***/ },
|
|
/* 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__) {
|
|
|
|
/**
|
|
* 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
|
|
*/
|
|
function eq(value, other) {
|
|
return value === other || (value !== value && other !== other);
|
|
}
|
|
|
|
module.e = eq;
|
|
|
|
|
|
/***/ },
|
|
/* 16 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var isObject = __webpack_require__(2);
|
|
|
|
/** `Object#toString` result references. */
|
|
var funcTag = '[object Function]',
|
|
genTag = '[object GeneratorFunction]';
|
|
|
|
/** 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;
|
|
|
|
/**
|
|
* 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
|
|
*/
|
|
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;
|
|
}
|
|
|
|
module.e = isFunction;
|
|
|
|
|
|
/***/ },
|
|
/* 17 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* 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 vec2 = {
|
|
clone: __webpack_require__(6)
|
|
};
|
|
var vec3 = {
|
|
clone: __webpack_require__(78)
|
|
};
|
|
|
|
/**
|
|
* @param x x-coordinate
|
|
* @param y y-coordinate
|
|
* @return ImageReference {x,y} Coordinate
|
|
*/
|
|
function imageRef(x, y) {
|
|
var that = {
|
|
x: x,
|
|
y: y,
|
|
toVec2: function toVec2() {
|
|
return vec2.clone([this.x, this.y]);
|
|
},
|
|
toVec3: function toVec3() {
|
|
return vec3.clone([this.x, this.y, 1]);
|
|
},
|
|
round: function round() {
|
|
this.x = this.x > 0.0 ? Math.floor(this.x + 0.5) : Math.floor(this.x - 0.5);
|
|
this.y = this.y > 0.0 ? Math.floor(this.y + 0.5) : Math.floor(this.y - 0.5);
|
|
return this;
|
|
}
|
|
};
|
|
return that;
|
|
};
|
|
|
|
/**
|
|
* Computes an integral image of a given grayscale image.
|
|
* @param imageDataContainer {ImageDataContainer} the image to be integrated
|
|
*/
|
|
function computeIntegralImage2(imageWrapper, integralWrapper) {
|
|
var imageData = imageWrapper.data;
|
|
var width = imageWrapper.size.x;
|
|
var height = imageWrapper.size.y;
|
|
var integralImageData = integralWrapper.data;
|
|
var sum = 0,
|
|
posA = 0,
|
|
posB = 0,
|
|
posC = 0,
|
|
posD = 0,
|
|
x,
|
|
y;
|
|
|
|
// sum up first column
|
|
posB = width;
|
|
sum = 0;
|
|
for (y = 1; y < height; y++) {
|
|
sum += imageData[posA];
|
|
integralImageData[posB] += sum;
|
|
posA += width;
|
|
posB += width;
|
|
}
|
|
|
|
posA = 0;
|
|
posB = 1;
|
|
sum = 0;
|
|
for (x = 1; x < width; x++) {
|
|
sum += imageData[posA];
|
|
integralImageData[posB] += sum;
|
|
posA++;
|
|
posB++;
|
|
}
|
|
|
|
for (y = 1; y < height; y++) {
|
|
posA = y * width + 1;
|
|
posB = (y - 1) * width + 1;
|
|
posC = y * width;
|
|
posD = (y - 1) * width;
|
|
for (x = 1; x < width; x++) {
|
|
integralImageData[posA] += imageData[posA] + integralImageData[posB] + integralImageData[posC] - integralImageData[posD];
|
|
posA++;
|
|
posB++;
|
|
posC++;
|
|
posD++;
|
|
}
|
|
}
|
|
};
|
|
|
|
function computeIntegralImage(imageWrapper, integralWrapper) {
|
|
var imageData = imageWrapper.data;
|
|
var width = imageWrapper.size.x;
|
|
var height = imageWrapper.size.y;
|
|
var integralImageData = integralWrapper.data;
|
|
var sum = 0;
|
|
|
|
// sum up first row
|
|
for (var i = 0; i < width; i++) {
|
|
sum += imageData[i];
|
|
integralImageData[i] = sum;
|
|
}
|
|
|
|
for (var v = 1; v < height; v++) {
|
|
sum = 0;
|
|
for (var u = 0; u < width; u++) {
|
|
sum += imageData[v * width + u];
|
|
integralImageData[v * width + u] = sum + integralImageData[(v - 1) * width + u];
|
|
}
|
|
}
|
|
};
|
|
|
|
function thresholdImage(imageWrapper, threshold, targetWrapper) {
|
|
if (!targetWrapper) {
|
|
targetWrapper = imageWrapper;
|
|
}
|
|
var imageData = imageWrapper.data,
|
|
length = imageData.length,
|
|
targetData = targetWrapper.data;
|
|
|
|
while (length--) {
|
|
targetData[length] = imageData[length] < threshold ? 1 : 0;
|
|
}
|
|
};
|
|
|
|
function computeHistogram(imageWrapper, bitsPerPixel) {
|
|
if (!bitsPerPixel) {
|
|
bitsPerPixel = 8;
|
|
}
|
|
var imageData = imageWrapper.data,
|
|
length = imageData.length,
|
|
bitShift = 8 - bitsPerPixel,
|
|
bucketCnt = 1 << bitsPerPixel,
|
|
hist = new Int32Array(bucketCnt);
|
|
|
|
while (length--) {
|
|
hist[imageData[length] >> bitShift]++;
|
|
}
|
|
return hist;
|
|
};
|
|
|
|
function sharpenLine(line) {
|
|
var i,
|
|
length = line.length,
|
|
left = line[0],
|
|
center = line[1],
|
|
right;
|
|
|
|
for (i = 1; i < length - 1; i++) {
|
|
right = line[i + 1];
|
|
// -1 4 -1 kernel
|
|
line[i - 1] = center * 2 - left - right & 255;
|
|
left = center;
|
|
center = right;
|
|
}
|
|
return line;
|
|
};
|
|
|
|
function determineOtsuThreshold(imageWrapper, bitsPerPixel) {
|
|
if (!bitsPerPixel) {
|
|
bitsPerPixel = 8;
|
|
}
|
|
var hist,
|
|
threshold,
|
|
bitShift = 8 - bitsPerPixel;
|
|
|
|
function px(init, end) {
|
|
var sum = 0,
|
|
i;
|
|
for (i = init; i <= end; i++) {
|
|
sum += hist[i];
|
|
}
|
|
return sum;
|
|
}
|
|
|
|
function mx(init, end) {
|
|
var i,
|
|
sum = 0;
|
|
|
|
for (i = init; i <= end; i++) {
|
|
sum += i * hist[i];
|
|
}
|
|
|
|
return sum;
|
|
}
|
|
|
|
function determineThreshold() {
|
|
var vet = [0],
|
|
p1,
|
|
p2,
|
|
p12,
|
|
k,
|
|
m1,
|
|
m2,
|
|
m12,
|
|
max = (1 << bitsPerPixel) - 1;
|
|
|
|
hist = computeHistogram(imageWrapper, bitsPerPixel);
|
|
for (k = 1; k < max; k++) {
|
|
p1 = px(0, k);
|
|
p2 = px(k + 1, max);
|
|
p12 = p1 * p2;
|
|
if (p12 === 0) {
|
|
p12 = 1;
|
|
}
|
|
m1 = mx(0, k) * p2;
|
|
m2 = mx(k + 1, max) * p1;
|
|
m12 = m1 - m2;
|
|
vet[k] = m12 * m12 / p12;
|
|
}
|
|
return /* harmony import */__WEBPACK_IMPORTED_MODULE_1__array_helper__["a"].maxIndex(vet);
|
|
}
|
|
|
|
threshold = determineThreshold();
|
|
return threshold << bitShift;
|
|
};
|
|
|
|
function otsuThreshold(imageWrapper, targetWrapper) {
|
|
var threshold = determineOtsuThreshold(imageWrapper);
|
|
|
|
thresholdImage(imageWrapper, threshold, targetWrapper);
|
|
return threshold;
|
|
};
|
|
|
|
// local thresholding
|
|
function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) {
|
|
computeIntegralImage(imageWrapper, integralWrapper);
|
|
|
|
if (!targetWrapper) {
|
|
targetWrapper = imageWrapper;
|
|
}
|
|
var imageData = imageWrapper.data;
|
|
var targetData = targetWrapper.data;
|
|
var width = imageWrapper.size.x;
|
|
var height = imageWrapper.size.y;
|
|
var integralImageData = integralWrapper.data;
|
|
var sum = 0,
|
|
v,
|
|
u,
|
|
kernel = 3,
|
|
A,
|
|
B,
|
|
C,
|
|
D,
|
|
avg,
|
|
size = (kernel * 2 + 1) * (kernel * 2 + 1);
|
|
|
|
// clear out top & bottom-border
|
|
for (v = 0; v <= kernel; v++) {
|
|
for (u = 0; u < width; u++) {
|
|
targetData[v * width + u] = 0;
|
|
targetData[(height - 1 - v) * width + u] = 0;
|
|
}
|
|
}
|
|
|
|
// clear out left & right border
|
|
for (v = kernel; v < height - kernel; v++) {
|
|
for (u = 0; u <= kernel; u++) {
|
|
targetData[v * width + u] = 0;
|
|
targetData[v * width + (width - 1 - u)] = 0;
|
|
}
|
|
}
|
|
|
|
for (v = kernel + 1; v < height - kernel - 1; v++) {
|
|
for (u = kernel + 1; u < width - kernel; u++) {
|
|
A = integralImageData[(v - kernel - 1) * width + (u - kernel - 1)];
|
|
B = integralImageData[(v - kernel - 1) * width + (u + kernel)];
|
|
C = integralImageData[(v + kernel) * width + (u - kernel - 1)];
|
|
D = integralImageData[(v + kernel) * width + (u + kernel)];
|
|
sum = D - C - B + A;
|
|
avg = sum / size;
|
|
targetData[v * width + u] = imageData[v * width + u] > avg + 5 ? 0 : 1;
|
|
}
|
|
}
|
|
};
|
|
|
|
function cluster(points, threshold, property) {
|
|
var i,
|
|
k,
|
|
cluster,
|
|
point,
|
|
clusters = [];
|
|
|
|
if (!property) {
|
|
property = "rad";
|
|
}
|
|
|
|
function addToCluster(newPoint) {
|
|
var found = false;
|
|
for (k = 0; k < clusters.length; k++) {
|
|
cluster = clusters[k];
|
|
if (cluster.fits(newPoint)) {
|
|
cluster.add(newPoint);
|
|
found = true;
|
|
}
|
|
}
|
|
return found;
|
|
}
|
|
|
|
// iterate over each cloud
|
|
for (i = 0; i < points.length; i++) {
|
|
point = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__cluster__["a"].createPoint(points[i], i, property);
|
|
if (!addToCluster(point)) {
|
|
clusters.push(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__cluster__["a"].create(point, threshold));
|
|
}
|
|
}
|
|
return clusters;
|
|
};
|
|
|
|
var Tracer = {
|
|
trace: function trace(points, vec) {
|
|
var iteration,
|
|
maxIterations = 10,
|
|
top = [],
|
|
result = [],
|
|
centerPos = 0,
|
|
currentPos = 0;
|
|
|
|
function trace(idx, forward) {
|
|
var from,
|
|
to,
|
|
toIdx,
|
|
predictedPos,
|
|
thresholdX = 1,
|
|
thresholdY = Math.abs(vec[1] / 10),
|
|
found = false;
|
|
|
|
function match(pos, predicted) {
|
|
if (pos.x > predicted.x - thresholdX && pos.x < predicted.x + thresholdX && pos.y > predicted.y - thresholdY && pos.y < predicted.y + thresholdY) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
// check if the next index is within the vec specifications
|
|
// if not, check as long as the threshold is met
|
|
|
|
from = points[idx];
|
|
if (forward) {
|
|
predictedPos = {
|
|
x: from.x + vec[0],
|
|
y: from.y + vec[1]
|
|
};
|
|
} else {
|
|
predictedPos = {
|
|
x: from.x - vec[0],
|
|
y: from.y - vec[1]
|
|
};
|
|
}
|
|
|
|
toIdx = forward ? idx + 1 : idx - 1;
|
|
to = points[toIdx];
|
|
while (to && (found = match(to, predictedPos)) !== true && Math.abs(to.y - from.y) < vec[1]) {
|
|
toIdx = forward ? toIdx + 1 : toIdx - 1;
|
|
to = points[toIdx];
|
|
}
|
|
|
|
return found ? toIdx : null;
|
|
}
|
|
|
|
for (iteration = 0; iteration < maxIterations; iteration++) {
|
|
// randomly select point to start with
|
|
centerPos = Math.floor(Math.random() * points.length);
|
|
|
|
// trace forward
|
|
top = [];
|
|
currentPos = centerPos;
|
|
top.push(points[currentPos]);
|
|
while ((currentPos = trace(currentPos, true)) !== null) {
|
|
top.push(points[currentPos]);
|
|
}
|
|
if (centerPos > 0) {
|
|
currentPos = centerPos;
|
|
while ((currentPos = trace(currentPos, false)) !== null) {
|
|
top.push(points[currentPos]);
|
|
}
|
|
}
|
|
|
|
if (top.length > result.length) {
|
|
result = top;
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
};/* unused harmony export Tracer */
|
|
|
|
var DILATE = 1;/* unused harmony export DILATE */
|
|
var ERODE = 2;/* unused harmony export ERODE */
|
|
|
|
function dilate(inImageWrapper, outImageWrapper) {
|
|
var v,
|
|
u,
|
|
inImageData = inImageWrapper.data,
|
|
outImageData = outImageWrapper.data,
|
|
height = inImageWrapper.size.y,
|
|
width = inImageWrapper.size.x,
|
|
sum,
|
|
yStart1,
|
|
yStart2,
|
|
xStart1,
|
|
xStart2;
|
|
|
|
for (v = 1; v < height - 1; v++) {
|
|
for (u = 1; u < width - 1; u++) {
|
|
yStart1 = v - 1;
|
|
yStart2 = v + 1;
|
|
xStart1 = u - 1;
|
|
xStart2 = u + 1;
|
|
sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] + inImageData[v * width + u] + inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];
|
|
outImageData[v * width + u] = sum > 0 ? 1 : 0;
|
|
}
|
|
}
|
|
};
|
|
|
|
function erode(inImageWrapper, outImageWrapper) {
|
|
var v,
|
|
u,
|
|
inImageData = inImageWrapper.data,
|
|
outImageData = outImageWrapper.data,
|
|
height = inImageWrapper.size.y,
|
|
width = inImageWrapper.size.x,
|
|
sum,
|
|
yStart1,
|
|
yStart2,
|
|
xStart1,
|
|
xStart2;
|
|
|
|
for (v = 1; v < height - 1; v++) {
|
|
for (u = 1; u < width - 1; u++) {
|
|
yStart1 = v - 1;
|
|
yStart2 = v + 1;
|
|
xStart1 = u - 1;
|
|
xStart2 = u + 1;
|
|
sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] + inImageData[v * width + u] + inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];
|
|
outImageData[v * width + u] = sum === 5 ? 1 : 0;
|
|
}
|
|
}
|
|
};
|
|
|
|
function subtract(aImageWrapper, bImageWrapper, resultImageWrapper) {
|
|
if (!resultImageWrapper) {
|
|
resultImageWrapper = aImageWrapper;
|
|
}
|
|
var length = aImageWrapper.data.length,
|
|
aImageData = aImageWrapper.data,
|
|
bImageData = bImageWrapper.data,
|
|
cImageData = resultImageWrapper.data;
|
|
|
|
while (length--) {
|
|
cImageData[length] = aImageData[length] - bImageData[length];
|
|
}
|
|
};
|
|
|
|
function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) {
|
|
if (!resultImageWrapper) {
|
|
resultImageWrapper = aImageWrapper;
|
|
}
|
|
var length = aImageWrapper.data.length,
|
|
aImageData = aImageWrapper.data,
|
|
bImageData = bImageWrapper.data,
|
|
cImageData = resultImageWrapper.data;
|
|
|
|
while (length--) {
|
|
cImageData[length] = aImageData[length] || bImageData[length];
|
|
}
|
|
};
|
|
|
|
function countNonZero(imageWrapper) {
|
|
var length = imageWrapper.data.length,
|
|
data = imageWrapper.data,
|
|
sum = 0;
|
|
|
|
while (length--) {
|
|
sum += data[length];
|
|
}
|
|
return sum;
|
|
};
|
|
|
|
function topGeneric(list, top, scoreFunc) {
|
|
var i,
|
|
minIdx = 0,
|
|
min = 0,
|
|
queue = [],
|
|
score,
|
|
hit,
|
|
pos;
|
|
|
|
for (i = 0; i < top; i++) {
|
|
queue[i] = {
|
|
score: 0,
|
|
item: null
|
|
};
|
|
}
|
|
|
|
for (i = 0; i < list.length; i++) {
|
|
score = scoreFunc.apply(this, [list[i]]);
|
|
if (score > min) {
|
|
hit = queue[minIdx];
|
|
hit.score = score;
|
|
hit.item = list[i];
|
|
min = Number.MAX_VALUE;
|
|
for (pos = 0; pos < top; pos++) {
|
|
if (queue[pos].score < min) {
|
|
min = queue[pos].score;
|
|
minIdx = pos;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return queue;
|
|
};
|
|
|
|
function grayArrayFromImage(htmlImage, offsetX, ctx, array) {
|
|
ctx.drawImage(htmlImage, offsetX, 0, htmlImage.width, htmlImage.height);
|
|
var ctxData = ctx.getImageData(offsetX, 0, htmlImage.width, htmlImage.height).data;
|
|
computeGray(ctxData, array);
|
|
};
|
|
|
|
function grayArrayFromContext(ctx, size, offset, array) {
|
|
var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data;
|
|
computeGray(ctxData, array);
|
|
};
|
|
|
|
function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {
|
|
var topRowIdx = 0;
|
|
var bottomRowIdx = size.x;
|
|
var endIdx = Math.floor(canvasData.length / 4);
|
|
var outWidth = size.x / 2;
|
|
var outImgIdx = 0;
|
|
var inWidth = size.x;
|
|
var i;
|
|
|
|
while (bottomRowIdx < endIdx) {
|
|
for (i = 0; i < outWidth; i++) {
|
|
outArray[outImgIdx] = Math.floor((0.299 * canvasData[topRowIdx * 4 + 0] + 0.587 * canvasData[topRowIdx * 4 + 1] + 0.114 * canvasData[topRowIdx * 4 + 2] + (0.299 * canvasData[(topRowIdx + 1) * 4 + 0] + 0.587 * canvasData[(topRowIdx + 1) * 4 + 1] + 0.114 * canvasData[(topRowIdx + 1) * 4 + 2]) + (0.299 * canvasData[bottomRowIdx * 4 + 0] + 0.587 * canvasData[bottomRowIdx * 4 + 1] + 0.114 * canvasData[bottomRowIdx * 4 + 2]) + (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] + 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] + 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4);
|
|
outImgIdx++;
|
|
topRowIdx = topRowIdx + 2;
|
|
bottomRowIdx = bottomRowIdx + 2;
|
|
}
|
|
topRowIdx = topRowIdx + inWidth;
|
|
bottomRowIdx = bottomRowIdx + inWidth;
|
|
}
|
|
};
|
|
|
|
function computeGray(imageData, outArray, config) {
|
|
var l = imageData.length / 4 | 0,
|
|
i,
|
|
singleChannel = config && config.singleChannel === true;
|
|
|
|
if (singleChannel) {
|
|
for (i = 0; i < l; i++) {
|
|
outArray[i] = imageData[i * 4 + 0];
|
|
}
|
|
} else {
|
|
for (i = 0; i < l; i++) {
|
|
outArray[i] = Math.floor(0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2]);
|
|
}
|
|
}
|
|
};
|
|
|
|
function loadImageArray(src, callback, canvas) {
|
|
if (!canvas) {
|
|
canvas = document.createElement('canvas');
|
|
}
|
|
var img = new Image();
|
|
img.callback = callback;
|
|
img.onload = function () {
|
|
canvas.width = this.width;
|
|
canvas.height = this.height;
|
|
var ctx = canvas.getContext('2d');
|
|
ctx.drawImage(this, 0, 0);
|
|
var array = new Uint8Array(this.width * this.height);
|
|
ctx.drawImage(this, 0, 0);
|
|
var data = ctx.getImageData(0, 0, this.width, this.height).data;
|
|
computeGray(data, array);
|
|
this.callback(array, {
|
|
x: this.width,
|
|
y: this.height
|
|
}, this);
|
|
};
|
|
img.src = src;
|
|
};
|
|
|
|
/**
|
|
* @param inImg {ImageWrapper} input image to be sampled
|
|
* @param outImg {ImageWrapper} to be stored in
|
|
*/
|
|
function halfSample(inImgWrapper, outImgWrapper) {
|
|
var inImg = inImgWrapper.data;
|
|
var inWidth = inImgWrapper.size.x;
|
|
var outImg = outImgWrapper.data;
|
|
var topRowIdx = 0;
|
|
var bottomRowIdx = inWidth;
|
|
var endIdx = inImg.length;
|
|
var outWidth = inWidth / 2;
|
|
var outImgIdx = 0;
|
|
while (bottomRowIdx < endIdx) {
|
|
for (var i = 0; i < outWidth; i++) {
|
|
outImg[outImgIdx] = Math.floor((inImg[topRowIdx] + inImg[topRowIdx + 1] + inImg[bottomRowIdx] + inImg[bottomRowIdx + 1]) / 4);
|
|
outImgIdx++;
|
|
topRowIdx = topRowIdx + 2;
|
|
bottomRowIdx = bottomRowIdx + 2;
|
|
}
|
|
topRowIdx = topRowIdx + inWidth;
|
|
bottomRowIdx = bottomRowIdx + inWidth;
|
|
}
|
|
};
|
|
|
|
function hsv2rgb(hsv, rgb) {
|
|
var h = hsv[0],
|
|
s = hsv[1],
|
|
v = hsv[2],
|
|
c = v * s,
|
|
x = c * (1 - Math.abs(h / 60 % 2 - 1)),
|
|
m = v - c,
|
|
r = 0,
|
|
g = 0,
|
|
b = 0;
|
|
|
|
rgb = rgb || [0, 0, 0];
|
|
|
|
if (h < 60) {
|
|
r = c;
|
|
g = x;
|
|
} else if (h < 120) {
|
|
r = x;
|
|
g = c;
|
|
} else if (h < 180) {
|
|
g = c;
|
|
b = x;
|
|
} else if (h < 240) {
|
|
g = x;
|
|
b = c;
|
|
} else if (h < 300) {
|
|
r = x;
|
|
b = c;
|
|
} else if (h < 360) {
|
|
r = c;
|
|
b = x;
|
|
}
|
|
rgb[0] = (r + m) * 255 | 0;
|
|
rgb[1] = (g + m) * 255 | 0;
|
|
rgb[2] = (b + m) * 255 | 0;
|
|
return rgb;
|
|
};
|
|
|
|
function _computeDivisors(n) {
|
|
var largeDivisors = [],
|
|
divisors = [],
|
|
i;
|
|
|
|
for (i = 1; i < Math.sqrt(n) + 1; i++) {
|
|
if (n % i === 0) {
|
|
divisors.push(i);
|
|
if (i !== n / i) {
|
|
largeDivisors.unshift(Math.floor(n / i));
|
|
}
|
|
}
|
|
}
|
|
return divisors.concat(largeDivisors);
|
|
};
|
|
|
|
function _computeIntersection(arr1, arr2) {
|
|
var i = 0,
|
|
j = 0,
|
|
result = [];
|
|
|
|
while (i < arr1.length && j < arr2.length) {
|
|
if (arr1[i] === arr2[j]) {
|
|
result.push(arr1[i]);
|
|
i++;
|
|
j++;
|
|
} else if (arr1[i] > arr2[j]) {
|
|
j++;
|
|
} else {
|
|
i++;
|
|
}
|
|
}
|
|
return result;
|
|
};
|
|
|
|
function calculatePatchSize(patchSize, imgSize) {
|
|
var divisorsX = _computeDivisors(imgSize.x),
|
|
divisorsY = _computeDivisors(imgSize.y),
|
|
wideSide = Math.max(imgSize.x, imgSize.y),
|
|
common = _computeIntersection(divisorsX, divisorsY),
|
|
nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80],
|
|
nrOfPatchesMap = {
|
|
"x-small": 5,
|
|
"small": 4,
|
|
"medium": 3,
|
|
"large": 2,
|
|
"x-large": 1
|
|
},
|
|
nrOfPatchesIdx = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium,
|
|
nrOfPatches = nrOfPatchesList[nrOfPatchesIdx],
|
|
desiredPatchSize = Math.floor(wideSide / nrOfPatches),
|
|
optimalPatchSize;
|
|
|
|
function findPatchSizeForDivisors(divisors) {
|
|
var i = 0,
|
|
found = divisors[Math.floor(divisors.length / 2)];
|
|
|
|
while (i < divisors.length - 1 && divisors[i] < desiredPatchSize) {
|
|
i++;
|
|
}
|
|
if (i > 0) {
|
|
if (Math.abs(divisors[i] - desiredPatchSize) > Math.abs(divisors[i - 1] - desiredPatchSize)) {
|
|
found = divisors[i - 1];
|
|
} else {
|
|
found = divisors[i];
|
|
}
|
|
}
|
|
if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIdx + 1] / nrOfPatchesList[nrOfPatchesIdx] && desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIdx - 1] / nrOfPatchesList[nrOfPatchesIdx]) {
|
|
return { x: found, y: found };
|
|
}
|
|
return null;
|
|
}
|
|
|
|
optimalPatchSize = findPatchSizeForDivisors(common);
|
|
if (!optimalPatchSize) {
|
|
optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide));
|
|
if (!optimalPatchSize) {
|
|
optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(desiredPatchSize * nrOfPatches));
|
|
}
|
|
}
|
|
return optimalPatchSize;
|
|
};
|
|
|
|
function _parseCSSDimensionValues(value) {
|
|
var dimension = {
|
|
value: parseFloat(value),
|
|
unit: value.indexOf("%") === value.length - 1 ? "%" : "px"
|
|
};
|
|
|
|
return dimension;
|
|
};
|
|
|
|
var _dimensionsConverters = {
|
|
top: function top(dimension, context) {
|
|
return Math.floor(dimension.unit === "%" ? context.height * (dimension.value / 100) : dimension.value);
|
|
},
|
|
right: function right(dimension, context) {
|
|
return Math.floor(dimension.unit === "%" ? context.width - context.width * (dimension.value / 100) : context.width - dimension.value);
|
|
},
|
|
bottom: function bottom(dimension, context) {
|
|
return Math.floor(dimension.unit === "%" ? context.height - context.height * (dimension.value / 100) : context.height - dimension.value);
|
|
},
|
|
left: function left(dimension, context) {
|
|
return Math.floor(dimension.unit === "%" ? context.width * (dimension.value / 100) : dimension.value);
|
|
}
|
|
};/* unused harmony export _dimensionsConverters */
|
|
|
|
function computeImageArea(inputWidth, inputHeight, area) {
|
|
var context = { width: inputWidth, height: inputHeight };
|
|
|
|
var parsedArea = Object.keys(area).reduce(function (result, key) {
|
|
var value = area[key],
|
|
parsed = _parseCSSDimensionValues(value),
|
|
calculated = _dimensionsConverters[key](parsed, context);
|
|
|
|
result[key] = calculated;
|
|
return result;
|
|
}, {});
|
|
|
|
return {
|
|
sx: parsedArea.left,
|
|
sy: parsedArea.top,
|
|
sw: parsedArea.right - parsedArea.left,
|
|
sh: parsedArea.bottom - parsedArea.top
|
|
};
|
|
};
|
|
|
|
/***/ },
|
|
/* 18 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* 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);
|
|
|
|
|
|
|
|
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) {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_2__common_array_helper__["a"].init(this.data, 0);
|
|
}
|
|
} 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);
|
|
}
|
|
}
|
|
} else {
|
|
this.data = data;
|
|
}
|
|
this.size = size;
|
|
}
|
|
|
|
/**
|
|
* tests if a position is within the image with a given offset
|
|
* @param imgRef {x, y} The location to test
|
|
* @param border Number the padding value in pixel
|
|
* @returns {Boolean} true if location inside the image's border, false otherwise
|
|
* @see cvd/image.h
|
|
*/
|
|
ImageWrapper.prototype.inImageWithBorder = function (imgRef, border) {
|
|
return imgRef.x >= border && imgRef.y >= border && imgRef.x < this.size.x - border && imgRef.y < this.size.y - border;
|
|
};
|
|
|
|
/**
|
|
* Performs bilinear sampling
|
|
* @param inImg Image to extract sample from
|
|
* @param x the x-coordinate
|
|
* @param y the y-coordinate
|
|
* @returns the sampled value
|
|
* @see cvd/vision.h
|
|
*/
|
|
ImageWrapper.sample = function (inImg, x, y) {
|
|
var lx = Math.floor(x);
|
|
var ly = Math.floor(y);
|
|
var w = inImg.size.x;
|
|
var base = ly * inImg.size.x + lx;
|
|
var a = inImg.data[base + 0];
|
|
var b = inImg.data[base + 1];
|
|
var c = inImg.data[base + w];
|
|
var d = inImg.data[base + w + 1];
|
|
var e = a - b;
|
|
x -= lx;
|
|
y -= ly;
|
|
|
|
var result = Math.floor(x * (y * (e - c + d) - e) + y * (c - a) + a);
|
|
return result;
|
|
};
|
|
|
|
/**
|
|
* Initializes a given array. Sets each element to zero.
|
|
* @param array {Array} The array to initialize
|
|
*/
|
|
ImageWrapper.clearArray = function (array) {
|
|
var l = array.length;
|
|
while (l--) {
|
|
array[l] = 0;
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Creates a {SubImage} from the current image ({this}).
|
|
* @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner)
|
|
* @param size {ImageRef} The size of the resulting image
|
|
* @returns {SubImage} A shared part of the original image
|
|
*/
|
|
ImageWrapper.prototype.subImage = function (from, size) {
|
|
return new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__subImage__["a"](from, size, this);
|
|
};
|
|
|
|
/**
|
|
* Creates an {ImageWrapper) and copies the needed underlying image-data area
|
|
* @param imageWrapper {ImageWrapper} The target {ImageWrapper} where the data should be copied
|
|
* @param from {ImageRef} The location where to copy from (top-left location)
|
|
*/
|
|
ImageWrapper.prototype.subImageAsCopy = function (imageWrapper, from) {
|
|
var sizeY = imageWrapper.size.y,
|
|
sizeX = imageWrapper.size.x;
|
|
var x, y;
|
|
for (x = 0; x < sizeX; x++) {
|
|
for (y = 0; y < sizeY; y++) {
|
|
imageWrapper.data[y * sizeX + x] = this.data[(from.y + y) * this.size.x + from.x + x];
|
|
}
|
|
}
|
|
};
|
|
|
|
ImageWrapper.prototype.copyTo = function (imageWrapper) {
|
|
var length = this.data.length,
|
|
srcData = this.data,
|
|
dstData = imageWrapper.data;
|
|
|
|
while (length--) {
|
|
dstData[length] = srcData[length];
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Retrieves a given pixel position from the image
|
|
* @param x {Number} The x-position
|
|
* @param y {Number} The y-position
|
|
* @returns {Number} The grayscale value at the pixel-position
|
|
*/
|
|
ImageWrapper.prototype.get = function (x, y) {
|
|
return this.data[y * this.size.x + x];
|
|
};
|
|
|
|
/**
|
|
* Retrieves a given pixel position from the image
|
|
* @param x {Number} The x-position
|
|
* @param y {Number} The y-position
|
|
* @returns {Number} The grayscale value at the pixel-position
|
|
*/
|
|
ImageWrapper.prototype.getSafe = function (x, y) {
|
|
var i;
|
|
|
|
if (!this.indexMapping) {
|
|
this.indexMapping = {
|
|
x: [],
|
|
y: []
|
|
};
|
|
for (i = 0; i < this.size.x; i++) {
|
|
this.indexMapping.x[i] = i;
|
|
this.indexMapping.x[i + this.size.x] = i;
|
|
}
|
|
for (i = 0; i < this.size.y; i++) {
|
|
this.indexMapping.y[i] = i;
|
|
this.indexMapping.y[i + this.size.y] = i;
|
|
}
|
|
}
|
|
return this.data[this.indexMapping.y[y + this.size.y] * this.size.x + this.indexMapping.x[x + this.size.x]];
|
|
};
|
|
|
|
/**
|
|
* Sets a given pixel position in the image
|
|
* @param x {Number} The x-position
|
|
* @param y {Number} The y-position
|
|
* @param value {Number} The grayscale value to set
|
|
* @returns {ImageWrapper} The Image itself (for possible chaining)
|
|
*/
|
|
ImageWrapper.prototype.set = function (x, y, value) {
|
|
this.data[y * this.size.x + x] = value;
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* Sets the border of the image (1 pixel) to zero
|
|
*/
|
|
ImageWrapper.prototype.zeroBorder = function () {
|
|
var i,
|
|
width = this.size.x,
|
|
height = this.size.y,
|
|
data = this.data;
|
|
for (i = 0; i < width; i++) {
|
|
data[i] = data[(height - 1) * width + i] = 0;
|
|
}
|
|
for (i = 1; i < height - 1; i++) {
|
|
data[i * width] = data[i * width + (width - 1)] = 0;
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Inverts a binary image in place
|
|
*/
|
|
ImageWrapper.prototype.invert = function () {
|
|
var data = this.data,
|
|
length = data.length;
|
|
|
|
while (length--) {
|
|
data[length] = data[length] ? 0 : 1;
|
|
}
|
|
};
|
|
|
|
ImageWrapper.prototype.convolve = function (kernel) {
|
|
var x,
|
|
y,
|
|
kx,
|
|
ky,
|
|
kSize = kernel.length / 2 | 0,
|
|
accu = 0;
|
|
for (y = 0; y < this.size.y; y++) {
|
|
for (x = 0; x < this.size.x; x++) {
|
|
accu = 0;
|
|
for (ky = -kSize; ky <= kSize; ky++) {
|
|
for (kx = -kSize; kx <= kSize; kx++) {
|
|
accu += kernel[ky + kSize][kx + kSize] * this.getSafe(x + kx, y + ky);
|
|
}
|
|
}
|
|
this.data[y * this.size.x + x] = accu;
|
|
}
|
|
}
|
|
};
|
|
|
|
ImageWrapper.prototype.moments = function (labelcount) {
|
|
var data = this.data,
|
|
x,
|
|
y,
|
|
height = this.size.y,
|
|
width = this.size.x,
|
|
val,
|
|
ysq,
|
|
labelsum = [],
|
|
i,
|
|
label,
|
|
mu11,
|
|
mu02,
|
|
mu20,
|
|
x_,
|
|
y_,
|
|
tmp,
|
|
result = [],
|
|
PI = Math.PI,
|
|
PI_4 = PI / 4;
|
|
|
|
if (labelcount <= 0) {
|
|
return result;
|
|
}
|
|
|
|
for (i = 0; i < labelcount; i++) {
|
|
labelsum[i] = {
|
|
m00: 0,
|
|
m01: 0,
|
|
m10: 0,
|
|
m11: 0,
|
|
m02: 0,
|
|
m20: 0,
|
|
theta: 0,
|
|
rad: 0
|
|
};
|
|
}
|
|
|
|
for (y = 0; y < height; y++) {
|
|
ysq = y * y;
|
|
for (x = 0; x < width; x++) {
|
|
val = data[y * width + x];
|
|
if (val > 0) {
|
|
label = labelsum[val - 1];
|
|
label.m00 += 1;
|
|
label.m01 += y;
|
|
label.m10 += x;
|
|
label.m11 += x * y;
|
|
label.m02 += ysq;
|
|
label.m20 += x * x;
|
|
}
|
|
}
|
|
}
|
|
|
|
for (i = 0; i < labelcount; i++) {
|
|
label = labelsum[i];
|
|
if (!isNaN(label.m00) && label.m00 !== 0) {
|
|
x_ = label.m10 / label.m00;
|
|
y_ = label.m01 / label.m00;
|
|
mu11 = label.m11 / label.m00 - x_ * y_;
|
|
mu02 = label.m02 / label.m00 - y_ * y_;
|
|
mu20 = label.m20 / label.m00 - x_ * x_;
|
|
tmp = (mu02 - mu20) / (2 * mu11);
|
|
tmp = 0.5 * Math.atan(tmp) + (mu11 >= 0 ? PI_4 : -PI_4) + PI;
|
|
label.theta = (tmp * 180 / PI + 90) % 180 - 90;
|
|
if (label.theta < 0) {
|
|
label.theta += 180;
|
|
}
|
|
label.rad = tmp > PI ? tmp - PI : tmp;
|
|
label.vec = vec2.clone([Math.cos(tmp), Math.sin(tmp)]);
|
|
result.push(label);
|
|
}
|
|
}
|
|
|
|
return result;
|
|
};
|
|
|
|
/**
|
|
* Displays the {ImageWrapper} in a given canvas
|
|
* @param canvas {Canvas} The canvas element to write to
|
|
* @param scale {Number} Scale which is applied to each pixel-value
|
|
*/
|
|
ImageWrapper.prototype.show = function (canvas, scale) {
|
|
var ctx, frame, data, current, pixel, x, y;
|
|
|
|
if (!scale) {
|
|
scale = 1.0;
|
|
}
|
|
ctx = canvas.getContext('2d');
|
|
canvas.width = this.size.x;
|
|
canvas.height = this.size.y;
|
|
frame = ctx.getImageData(0, 0, canvas.width, canvas.height);
|
|
data = frame.data;
|
|
current = 0;
|
|
for (y = 0; y < this.size.y; y++) {
|
|
for (x = 0; x < this.size.x; x++) {
|
|
pixel = y * this.size.x + x;
|
|
current = this.get(x, y) * scale;
|
|
data[pixel * 4 + 0] = current;
|
|
data[pixel * 4 + 1] = current;
|
|
data[pixel * 4 + 2] = current;
|
|
data[pixel * 4 + 3] = 255;
|
|
}
|
|
}
|
|
//frame.data = data;
|
|
ctx.putImageData(frame, 0, 0);
|
|
};
|
|
|
|
/**
|
|
* Displays the {SubImage} in a given canvas
|
|
* @param canvas {Canvas} The canvas element to write to
|
|
* @param scale {Number} Scale which is applied to each pixel-value
|
|
*/
|
|
ImageWrapper.prototype.overlay = function (canvas, scale, from) {
|
|
if (!scale || scale < 0 || scale > 360) {
|
|
scale = 360;
|
|
}
|
|
var hsv = [0, 1, 1];
|
|
var rgb = [0, 0, 0];
|
|
var whiteRgb = [255, 255, 255];
|
|
var blackRgb = [0, 0, 0];
|
|
var result = [];
|
|
var ctx = canvas.getContext('2d');
|
|
var frame = ctx.getImageData(from.x, from.y, this.size.x, this.size.y);
|
|
var data = frame.data;
|
|
var length = this.data.length;
|
|
while (length--) {
|
|
hsv[0] = this.data[length] * scale;
|
|
result = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : /* 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__) {
|
|
|
|
/**
|
|
* 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;
|
|
|
|
if (initAccum && length) {
|
|
accumulator = array[++index];
|
|
}
|
|
while (++index < length) {
|
|
accumulator = iteratee(accumulator, array[index], index, array);
|
|
}
|
|
return accumulator;
|
|
}
|
|
|
|
module.e = arrayReduce;
|
|
|
|
|
|
/***/ },
|
|
/* 20 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var copyObjectWith = __webpack_require__(111);
|
|
|
|
/**
|
|
* 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 copyObject(source, props, object) {
|
|
return copyObjectWith(source, props, object);
|
|
}
|
|
|
|
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;
|
|
}
|
|
|
|
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*)$/;
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
|
|
module.e = isIndex;
|
|
|
|
|
|
/***/ },
|
|
/* 23 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/** Used for built-in method references. */
|
|
var objectProto = Object.prototype;
|
|
|
|
/**
|
|
* Checks if `value` is likely a prototype object.
|
|
*
|
|
* @private
|
|
* @param {*} value The value to check.
|
|
* @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
|
|
*/
|
|
function isPrototype(value) {
|
|
var Ctor = value && value.constructor,
|
|
proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;
|
|
|
|
return value === proto;
|
|
}
|
|
|
|
module.e = isPrototype;
|
|
|
|
|
|
/***/ },
|
|
/* 24 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var isArrayLikeObject = __webpack_require__(26);
|
|
|
|
/** `Object#toString` result references. */
|
|
var argsTag = '[object Arguments]';
|
|
|
|
/** 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;
|
|
|
|
/** Built-in value references. */
|
|
var propertyIsEnumerable = objectProto.propertyIsEnumerable;
|
|
|
|
/**
|
|
* 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);
|
|
}
|
|
|
|
module.e = isArguments;
|
|
|
|
|
|
/***/ },
|
|
/* 25 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var getLength = __webpack_require__(115),
|
|
isFunction = __webpack_require__(16),
|
|
isLength = __webpack_require__(27);
|
|
|
|
/**
|
|
* 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);
|
|
|
|
/**
|
|
* 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 isArrayLikeObject(value) {
|
|
return isObjectLike(value) && isArrayLike(value);
|
|
}
|
|
|
|
module.e = isArrayLikeObject;
|
|
|
|
|
|
/***/ },
|
|
/* 27 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/** Used as references for various `Number` constants. */
|
|
var MAX_SAFE_INTEGER = 9007199254740991;
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
|
|
module.e = isLength;
|
|
|
|
|
|
/***/ },
|
|
/* 28 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var baseMerge = __webpack_require__(99),
|
|
createAssigner = __webpack_require__(113);
|
|
|
|
/**
|
|
* 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);
|
|
});
|
|
|
|
module.e = merge;
|
|
|
|
|
|
/***/ },
|
|
/* 29 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/**
|
|
* http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization
|
|
*/
|
|
var Tracer = {
|
|
searchDirections: [[0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [-1, -1], [-1, 0], [-1, 1]],
|
|
create: function create(imageWrapper, labelWrapper) {
|
|
var imageData = imageWrapper.data,
|
|
labelData = labelWrapper.data,
|
|
searchDirections = this.searchDirections,
|
|
width = imageWrapper.size.x,
|
|
pos;
|
|
|
|
function _trace(current, color, label, edgelabel) {
|
|
var i, y, x;
|
|
|
|
for (i = 0; i < 7; i++) {
|
|
y = current.cy + searchDirections[current.dir][0];
|
|
x = current.cx + searchDirections[current.dir][1];
|
|
pos = y * width + x;
|
|
if (imageData[pos] === color && (labelData[pos] === 0 || labelData[pos] === label)) {
|
|
labelData[pos] = label;
|
|
current.cy = y;
|
|
current.cx = x;
|
|
return true;
|
|
} else {
|
|
if (labelData[pos] === 0) {
|
|
labelData[pos] = edgelabel;
|
|
}
|
|
current.dir = (current.dir + 1) % 8;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function vertex2D(x, y, dir) {
|
|
return {
|
|
dir: dir,
|
|
x: x,
|
|
y: y,
|
|
next: null,
|
|
prev: null
|
|
};
|
|
}
|
|
|
|
function _contourTracing(sy, sx, label, color, edgelabel) {
|
|
var Fv = null,
|
|
Cv,
|
|
P,
|
|
ldir,
|
|
current = {
|
|
cx: sx,
|
|
cy: sy,
|
|
dir: 0
|
|
};
|
|
|
|
if (_trace(current, color, label, edgelabel)) {
|
|
Fv = vertex2D(sx, sy, current.dir);
|
|
Cv = Fv;
|
|
ldir = current.dir;
|
|
P = vertex2D(current.cx, current.cy, 0);
|
|
P.prev = Cv;
|
|
Cv.next = P;
|
|
P.next = null;
|
|
Cv = P;
|
|
do {
|
|
current.dir = (current.dir + 6) % 8;
|
|
_trace(current, color, label, edgelabel);
|
|
if (ldir !== current.dir) {
|
|
Cv.dir = current.dir;
|
|
P = vertex2D(current.cx, current.cy, 0);
|
|
P.prev = Cv;
|
|
Cv.next = P;
|
|
P.next = null;
|
|
Cv = P;
|
|
} else {
|
|
Cv.dir = ldir;
|
|
Cv.x = current.cx;
|
|
Cv.y = current.cy;
|
|
}
|
|
ldir = current.dir;
|
|
} while (current.cx !== sx || current.cy !== sy);
|
|
Fv.prev = Cv.prev;
|
|
Cv.prev.next = Fv;
|
|
}
|
|
return Fv;
|
|
}
|
|
|
|
return {
|
|
trace: function trace(current, color, label, edgelabel) {
|
|
return _trace(current, color, label, edgelabel);
|
|
},
|
|
contourTracing: function contourTracing(sy, sx, label, color, edgelabel) {
|
|
return _contourTracing(sy, sx, label, color, edgelabel);
|
|
}
|
|
};
|
|
}
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = Tracer;
|
|
|
|
/***/ },
|
|
/* 30 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* 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);
|
|
|
|
|
|
|
|
function Code39Reader() {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].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(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].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;
|
|
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_array_helper__["a"].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) {
|
|
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 += /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_array_helper__["a"].sum(counters);
|
|
nextStart = self._nextSet(self._row, nextStart);
|
|
} while (decodedChar !== '*');
|
|
result.pop();
|
|
|
|
if (!result.length) {
|
|
return null;
|
|
}
|
|
|
|
if (!self._verifyTrailingWhitespace(lastStart, nextStart, counters)) {
|
|
return null;
|
|
}
|
|
|
|
return {
|
|
code: result.join(""),
|
|
start: start.start,
|
|
end: nextStart,
|
|
startInfo: start,
|
|
decodedCodes: result
|
|
};
|
|
};
|
|
|
|
Code39Reader.prototype._verifyTrailingWhitespace = function (lastStart, nextStart, counters) {
|
|
var trailingWhitespaceEnd,
|
|
patternSize = /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_array_helper__["a"].sum(counters);
|
|
|
|
trailingWhitespaceEnd = nextStart - lastStart - patternSize;
|
|
if (trailingWhitespaceEnd * 3 >= patternSize) {
|
|
return true;
|
|
}
|
|
return false;
|
|
};
|
|
|
|
Code39Reader.prototype._patternToChar = function (pattern) {
|
|
var i,
|
|
self = this;
|
|
|
|
for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {
|
|
if (self.CHARACTER_ENCODINGS[i] === pattern) {
|
|
return String.fromCharCode(self.ALPHABET[i]);
|
|
}
|
|
}
|
|
return -1;
|
|
};
|
|
|
|
Code39Reader.prototype._findNextWidth = function (counters, current) {
|
|
var i,
|
|
minWidth = Number.MAX_VALUE;
|
|
|
|
for (i = 0; i < counters.length; i++) {
|
|
if (counters[i] < minWidth && counters[i] > current) {
|
|
minWidth = counters[i];
|
|
}
|
|
}
|
|
|
|
return minWidth;
|
|
};
|
|
|
|
Code39Reader.prototype._toPattern = function (counters) {
|
|
var numCounters = counters.length,
|
|
maxNarrowWidth = 0,
|
|
numWideBars = numCounters,
|
|
wideBarWidth = 0,
|
|
self = this,
|
|
pattern,
|
|
i;
|
|
|
|
while (numWideBars > 3) {
|
|
maxNarrowWidth = self._findNextWidth(counters, maxNarrowWidth);
|
|
numWideBars = 0;
|
|
pattern = 0;
|
|
for (i = 0; i < numCounters; i++) {
|
|
if (counters[i] > maxNarrowWidth) {
|
|
pattern |= 1 << numCounters - 1 - i;
|
|
numWideBars++;
|
|
wideBarWidth += counters[i];
|
|
}
|
|
}
|
|
|
|
if (numWideBars === 3) {
|
|
for (i = 0; i < numCounters && numWideBars > 0; i++) {
|
|
if (counters[i] > maxNarrowWidth) {
|
|
numWideBars--;
|
|
if (counters[i] * 2 >= wideBarWidth) {
|
|
return -1;
|
|
}
|
|
}
|
|
}
|
|
return pattern;
|
|
}
|
|
}
|
|
return -1;
|
|
};
|
|
|
|
Code39Reader.prototype._findStart = function () {
|
|
var self = this,
|
|
offset = self._nextSet(self._row),
|
|
patternStart = offset,
|
|
counter = [0, 0, 0, 0, 0, 0, 0, 0, 0],
|
|
counterPos = 0,
|
|
isWhite = false,
|
|
i,
|
|
j,
|
|
whiteSpaceMustStart;
|
|
|
|
for (i = offset; i < self._row.length; i++) {
|
|
if (self._row[i] ^ isWhite) {
|
|
counter[counterPos]++;
|
|
} else {
|
|
if (counterPos === counter.length - 1) {
|
|
// find start pattern
|
|
if (self._toPattern(counter) === self.ASTERISK) {
|
|
whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - (i - patternStart) / 4));
|
|
if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) {
|
|
return {
|
|
start: patternStart,
|
|
end: i
|
|
};
|
|
}
|
|
}
|
|
|
|
patternStart += counter[0] + counter[1];
|
|
for (j = 0; j < 7; j++) {
|
|
counter[j] = counter[j + 2];
|
|
}
|
|
counter[7] = 0;
|
|
counter[8] = 0;
|
|
counterPos--;
|
|
} else {
|
|
counterPos++;
|
|
}
|
|
counter[counterPos] = 1;
|
|
isWhite = !isWhite;
|
|
}
|
|
}
|
|
return null;
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = Code39Reader;
|
|
|
|
/***/ },
|
|
/* 31 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
module.e = dot
|
|
|
|
/**
|
|
* Calculates the dot product of two vec2's
|
|
*
|
|
* @param {vec2} a the first operand
|
|
* @param {vec2} b the second operand
|
|
* @returns {Number} dot product of a and b
|
|
*/
|
|
function dot(a, b) {
|
|
return a[0] * b[0] + a[1] * b[1]
|
|
}
|
|
|
|
/***/ },
|
|
/* 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);
|
|
|
|
/**
|
|
* 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;
|
|
|
|
this.clear();
|
|
while (++index < length) {
|
|
var entry = values[index];
|
|
this.set(entry[0], entry[1]);
|
|
}
|
|
}
|
|
|
|
// 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__) {
|
|
|
|
/**
|
|
* 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`.
|
|
*/
|
|
function arrayEach(array, iteratee) {
|
|
var index = -1,
|
|
length = array.length;
|
|
|
|
while (++index < length) {
|
|
if (iteratee(array[index], index, array) === false) {
|
|
break;
|
|
}
|
|
}
|
|
return array;
|
|
}
|
|
|
|
module.e = arrayEach;
|
|
|
|
|
|
/***/ },
|
|
/* 34 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var eq = __webpack_require__(15);
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
}
|
|
|
|
module.e = assignMergeValue;
|
|
|
|
|
|
/***/ },
|
|
/* 35 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var eq = __webpack_require__(15);
|
|
|
|
/** Used for built-in method references. */
|
|
var objectProto = Object.prototype;
|
|
|
|
/** Used to check objects for own properties. */
|
|
var hasOwnProperty = objectProto.hasOwnProperty;
|
|
|
|
/**
|
|
* Assigns `value` to `key` of `object` if the existing value is not equivalent
|
|
* using [`SameValueZero`](http://ecma-international.org/ecma-262/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;
|
|
}
|
|
}
|
|
|
|
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;
|
|
}
|
|
|
|
module.e = assocDelete;
|
|
|
|
|
|
/***/ },
|
|
/* 37 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var assocIndexOf = __webpack_require__(11);
|
|
|
|
/**
|
|
* 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.
|
|
*/
|
|
function assocGet(array, key) {
|
|
var index = assocIndexOf(array, key);
|
|
return index < 0 ? undefined : array[index][1];
|
|
}
|
|
|
|
module.e = assocGet;
|
|
|
|
|
|
/***/ },
|
|
/* 38 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var assocIndexOf = __webpack_require__(11);
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
|
|
module.e = assocHas;
|
|
|
|
|
|
/***/ },
|
|
/* 39 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var assocIndexOf = __webpack_require__(11);
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
}
|
|
|
|
module.e = assocSet;
|
|
|
|
|
|
/***/ },
|
|
/* 40 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var Uint8Array = __webpack_require__(84);
|
|
|
|
/**
|
|
* Creates a clone of `arrayBuffer`.
|
|
*
|
|
* @private
|
|
* @param {ArrayBuffer} arrayBuffer The array buffer to clone.
|
|
* @returns {ArrayBuffer} Returns the cloned array buffer.
|
|
*/
|
|
function cloneArrayBuffer(arrayBuffer) {
|
|
var result = new arrayBuffer.constructor(arrayBuffer.byteLength);
|
|
new Uint8Array(result).set(new Uint8Array(arrayBuffer));
|
|
return result;
|
|
}
|
|
|
|
module.e = cloneArrayBuffer;
|
|
|
|
|
|
/***/ },
|
|
/* 41 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/**
|
|
* Copies the values of `source` to `array`.
|
|
*
|
|
* @private
|
|
* @param {Array} source The array to copy values from.
|
|
* @param {Array} [array=[]] The array to copy values to.
|
|
* @returns {Array} Returns `array`.
|
|
*/
|
|
function copyArray(source, array) {
|
|
var index = -1,
|
|
length = source.length;
|
|
|
|
array || (array = Array(length));
|
|
while (++index < length) {
|
|
array[index] = source[index];
|
|
}
|
|
return array;
|
|
}
|
|
|
|
module.e = copyArray;
|
|
|
|
|
|
/***/ },
|
|
/* 42 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var nativeCreate = __webpack_require__(14);
|
|
|
|
/** Used for built-in method references. */
|
|
var objectProto = Object.prototype;
|
|
|
|
/** Used to check objects for own properties. */
|
|
var hasOwnProperty = objectProto.hasOwnProperty;
|
|
|
|
/**
|
|
* Checks if a hash value for `key` exists.
|
|
*
|
|
* @private
|
|
* @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);
|
|
}
|
|
|
|
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);
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
|
|
module.e = indexKeys;
|
|
|
|
|
|
/***/ },
|
|
/* 44 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var isLength = __webpack_require__(27),
|
|
isObjectLike = __webpack_require__(7);
|
|
|
|
/** `Object#toString` result references. */
|
|
var argsTag = '[object Arguments]',
|
|
arrayTag = '[object Array]',
|
|
boolTag = '[object Boolean]',
|
|
dateTag = '[object Date]',
|
|
errorTag = '[object Error]',
|
|
funcTag = '[object Function]',
|
|
mapTag = '[object Map]',
|
|
numberTag = '[object Number]',
|
|
objectTag = '[object Object]',
|
|
regexpTag = '[object RegExp]',
|
|
setTag = '[object Set]',
|
|
stringTag = '[object String]',
|
|
weakMapTag = '[object WeakMap]';
|
|
|
|
var arrayBufferTag = '[object ArrayBuffer]',
|
|
float32Tag = '[object Float32Array]',
|
|
float64Tag = '[object Float64Array]',
|
|
int8Tag = '[object Int8Array]',
|
|
int16Tag = '[object Int16Array]',
|
|
int32Tag = '[object Int32Array]',
|
|
uint8Tag = '[object Uint8Array]',
|
|
uint8ClampedTag = '[object Uint8ClampedArray]',
|
|
uint16Tag = '[object Uint16Array]',
|
|
uint32Tag = '[object Uint32Array]';
|
|
|
|
/** Used to identify `toStringTag` values of typed arrays. */
|
|
var typedArrayTags = {};
|
|
typedArrayTags[float32Tag] = typedArrayTags[float64Tag] =
|
|
typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =
|
|
typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =
|
|
typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =
|
|
typedArrayTags[uint32Tag] = true;
|
|
typedArrayTags[argsTag] = typedArrayTags[arrayTag] =
|
|
typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =
|
|
typedArrayTags[dateTag] = typedArrayTags[errorTag] =
|
|
typedArrayTags[funcTag] = typedArrayTags[mapTag] =
|
|
typedArrayTags[numberTag] = typedArrayTags[objectTag] =
|
|
typedArrayTags[regexpTag] = typedArrayTags[setTag] =
|
|
typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;
|
|
|
|
/** 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;
|
|
|
|
/**
|
|
* 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)];
|
|
}
|
|
|
|
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);
|
|
|
|
/**
|
|
* 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;
|
|
|
|
for (var key in object) {
|
|
if (baseHas(object, key) &&
|
|
!(skipIndexes && (key == 'length' || isIndex(key, length))) &&
|
|
!(isProto && key == 'constructor')) {
|
|
result.push(key);
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
|
|
module.e = keys;
|
|
|
|
|
|
/***/ },
|
|
/* 46 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var baseKeysIn = __webpack_require__(98),
|
|
indexKeys = __webpack_require__(43),
|
|
isIndex = __webpack_require__(22),
|
|
isPrototype = __webpack_require__(23);
|
|
|
|
/** Used for built-in method references. */
|
|
var objectProto = Object.prototype;
|
|
|
|
/** Used to check objects for own properties. */
|
|
var hasOwnProperty = objectProto.hasOwnProperty;
|
|
|
|
/**
|
|
* Creates an array of the 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;
|
|
}
|
|
|
|
module.e = keysIn;
|
|
|
|
|
|
/***/ },
|
|
/* 47 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var apply = __webpack_require__(88),
|
|
toInteger = __webpack_require__(144);
|
|
|
|
/** Used as the `TypeError` message for "Functions" methods. */
|
|
var FUNC_ERROR_TEXT = 'Expected a function';
|
|
|
|
/* 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);
|
|
};
|
|
}
|
|
|
|
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);
|
|
|
|
|
|
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
|
|
|
|
// eslint-disable-line no-unused-vars
|
|
// eslint-disable-line no-unused-vars
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var vec2 = {
|
|
clone: __webpack_require__(6)
|
|
};
|
|
|
|
var _inputStream,
|
|
_framegrabber,
|
|
_stopped,
|
|
_canvasContainer = {
|
|
ctx: {
|
|
image: null,
|
|
overlay: null
|
|
},
|
|
dom: {
|
|
image: null,
|
|
overlay: null
|
|
}
|
|
},
|
|
_inputImageWrapper,
|
|
_boxSize,
|
|
_decoder,
|
|
_workerPool = [],
|
|
_onUIThread = true,
|
|
_resultCollector,
|
|
_config = {};
|
|
|
|
function initializeData(imageWrapper) {
|
|
initBuffers(imageWrapper);
|
|
_decoder = /* harmony import */__WEBPACK_IMPORTED_MODULE_5__decoder_barcode_decoder__["a"].create(_config.decoder, _inputImageWrapper);
|
|
}
|
|
|
|
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);
|
|
});
|
|
}
|
|
|
|
_inputStream.setAttribute("preload", "auto");
|
|
_inputStream.setAttribute("autoplay", true);
|
|
_inputStream.setInputStream(_config.inputStream);
|
|
_inputStream.addEventListener("canrecord", canRecord.bind(undefined, cb));
|
|
}
|
|
|
|
function getViewPort() {
|
|
var target = _config.inputStream.target;
|
|
// Check if target is already a DOM element
|
|
if (target && target.nodeName && target.nodeType === 1) {
|
|
return target;
|
|
} else {
|
|
// Use '#interactive.viewport' as a fallback selector (backwards compatibility)
|
|
var selector = typeof target === 'string' ? target : '#interactive.viewport';
|
|
return document.querySelector(selector);
|
|
}
|
|
}
|
|
|
|
function canRecord(cb) {
|
|
/* 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);
|
|
|
|
adjustWorkerPool(_config.numOfWorkers, function () {
|
|
if (_config.numOfWorkers === 0) {
|
|
initializeData();
|
|
}
|
|
ready(cb);
|
|
});
|
|
}
|
|
|
|
function ready(cb) {
|
|
_inputStream.play();
|
|
cb();
|
|
}
|
|
|
|
function initCanvas() {
|
|
if (typeof document !== "undefined") {
|
|
var $viewport = getViewPort();
|
|
_canvasContainer.dom.image = document.querySelector("canvas.imgBuffer");
|
|
if (!_canvasContainer.dom.image) {
|
|
_canvasContainer.dom.image = document.createElement("canvas");
|
|
_canvasContainer.dom.image.className = "imgBuffer";
|
|
if ($viewport && _config.inputStream.type === "ImageStream") {
|
|
$viewport.appendChild(_canvasContainer.dom.image);
|
|
}
|
|
}
|
|
_canvasContainer.ctx.image = _canvasContainer.dom.image.getContext("2d");
|
|
_canvasContainer.dom.image.width = _inputStream.getCanvasSize().x;
|
|
_canvasContainer.dom.image.height = _inputStream.getCanvasSize().y;
|
|
|
|
_canvasContainer.dom.overlay = document.querySelector("canvas.drawingBuffer");
|
|
if (!_canvasContainer.dom.overlay) {
|
|
_canvasContainer.dom.overlay = document.createElement("canvas");
|
|
_canvasContainer.dom.overlay.className = "drawingBuffer";
|
|
if ($viewport) {
|
|
$viewport.appendChild(_canvasContainer.dom.overlay);
|
|
}
|
|
var clearFix = document.createElement("br");
|
|
clearFix.setAttribute("clear", "all");
|
|
if ($viewport) {
|
|
$viewport.appendChild(clearFix);
|
|
}
|
|
}
|
|
_canvasContainer.ctx.overlay = _canvasContainer.dom.overlay.getContext("2d");
|
|
_canvasContainer.dom.overlay.width = _inputStream.getCanvasSize().x;
|
|
_canvasContainer.dom.overlay.height = _inputStream.getCanvasSize().y;
|
|
}
|
|
}
|
|
|
|
function initBuffers(imageWrapper) {
|
|
if (imageWrapper) {
|
|
_inputImageWrapper = imageWrapper;
|
|
} else {
|
|
_inputImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_wrapper__["a"]({
|
|
x: _inputStream.getWidth(),
|
|
y: _inputStream.getHeight()
|
|
});
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
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])]];
|
|
}
|
|
}
|
|
|
|
function transformResult(result) {
|
|
var topRight = _inputStream.getTopRight(),
|
|
xOffset = topRight.x,
|
|
yOffset = topRight.y,
|
|
i;
|
|
|
|
if (xOffset === 0 && yOffset === 0) {
|
|
return;
|
|
}
|
|
|
|
if (result.barcodes) {
|
|
for (i = 0; i < result.barcodes.length; i++) {
|
|
transformResult(result.barcodes[i]);
|
|
}
|
|
}
|
|
|
|
if (result.line && result.line.length === 2) {
|
|
moveLine(result.line);
|
|
}
|
|
|
|
if (result.box) {
|
|
moveBox(result.box);
|
|
}
|
|
|
|
if (result.boxes && result.boxes.length > 0) {
|
|
for (i = 0; i < result.boxes.length; i++) {
|
|
moveBox(result.boxes[i]);
|
|
}
|
|
}
|
|
|
|
function moveBox(box) {
|
|
var corner = box.length;
|
|
|
|
while (corner--) {
|
|
box[corner][0] += xOffset;
|
|
box[corner][1] += yOffset;
|
|
}
|
|
}
|
|
|
|
function moveLine(line) {
|
|
line[0].x += xOffset;
|
|
line[0].y += yOffset;
|
|
line[1].x += xOffset;
|
|
line[1].y += yOffset;
|
|
}
|
|
}
|
|
|
|
function addResult(result, imageData) {
|
|
if (!imageData || !_resultCollector) {
|
|
return;
|
|
}
|
|
|
|
if (result.barcodes) {
|
|
result.barcodes.filter(function (barcode) {
|
|
return barcode.codeResult;
|
|
}).forEach(function (barcode) {
|
|
return addResult(barcode, imageData);
|
|
});
|
|
} else if (result.codeResult) {
|
|
_resultCollector.addResult(imageData, _inputStream.getCanvasSize(), result.codeResult);
|
|
}
|
|
}
|
|
|
|
function hasCodeResult(result) {
|
|
return result && (result.barcodes ? result.barcodes.some(function (barcode) {
|
|
return barcode.codeResult;
|
|
}) : result.codeResult);
|
|
}
|
|
|
|
function publishResult(result, imageData) {
|
|
var resultToPublish = result;
|
|
|
|
if (result && _onUIThread) {
|
|
transformResult(result);
|
|
addResult(result, imageData);
|
|
resultToPublish = result.barcodes || result;
|
|
}
|
|
|
|
/* 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);
|
|
}
|
|
}
|
|
|
|
function locateAndDecode() {
|
|
var result, boxes;
|
|
|
|
boxes = getBoundingBoxes();
|
|
if (boxes) {
|
|
result = _decoder.decodeFromBoundingBoxes(boxes);
|
|
result = result || {};
|
|
result.boxes = boxes;
|
|
publishResult(result, _inputImageWrapper.data);
|
|
} else {
|
|
publishResult();
|
|
}
|
|
}
|
|
|
|
function update() {
|
|
var availableWorker;
|
|
|
|
if (_onUIThread) {
|
|
if (_workerPool.length > 0) {
|
|
availableWorker = _workerPool.filter(function (workerThread) {
|
|
return !workerThread.busy;
|
|
})[0];
|
|
if (availableWorker) {
|
|
_framegrabber.attachData(availableWorker.imageData);
|
|
} else {
|
|
return; // all workers are busy
|
|
}
|
|
} else {
|
|
_framegrabber.attachData(_inputImageWrapper.data);
|
|
}
|
|
if (_framegrabber.grab()) {
|
|
if (availableWorker) {
|
|
availableWorker.busy = true;
|
|
availableWorker.worker.postMessage({
|
|
cmd: 'process',
|
|
imageData: availableWorker.imageData
|
|
}, [availableWorker.imageData.buffer]);
|
|
} else {
|
|
locateAndDecode();
|
|
}
|
|
}
|
|
} else {
|
|
locateAndDecode();
|
|
}
|
|
}
|
|
|
|
function startContinuousUpdate() {
|
|
var next = null,
|
|
delay = 1000 / (_config.frequency || 60);
|
|
|
|
_stopped = false;
|
|
(function frame(timestamp) {
|
|
next = next || timestamp;
|
|
if (!_stopped) {
|
|
if (timestamp >= next) {
|
|
next += delay;
|
|
update();
|
|
}
|
|
window.requestAnimFrame(frame);
|
|
}
|
|
})(performance.now());
|
|
}
|
|
|
|
function _start() {
|
|
if (_onUIThread && _config.inputStream.type === "LiveStream") {
|
|
startContinuousUpdate();
|
|
} else {
|
|
update();
|
|
}
|
|
}
|
|
|
|
function initWorker(cb) {
|
|
var blobURL,
|
|
workerThread = {
|
|
worker: undefined,
|
|
imageData: new Uint8Array(_inputStream.getWidth() * _inputStream.getHeight()),
|
|
busy: true
|
|
};
|
|
|
|
blobURL = generateWorkerBlob();
|
|
workerThread.worker = new Worker(blobURL);
|
|
|
|
workerThread.worker.onmessage = function (e) {
|
|
if (e.data.event === 'initialized') {
|
|
URL.revokeObjectURL(blobURL);
|
|
workerThread.busy = false;
|
|
workerThread.imageData = new Uint8Array(e.data.imageData);
|
|
if (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);
|
|
}
|
|
}
|
|
};
|
|
|
|
workerThread.worker.postMessage({
|
|
cmd: 'init',
|
|
size: { x: _inputStream.getWidth(), y: _inputStream.getHeight() },
|
|
imageData: workerThread.imageData,
|
|
config: configForWorker(_config)
|
|
}, [workerThread.imageData.buffer]);
|
|
}
|
|
|
|
function configForWorker(config) {
|
|
return _extends({}, config, {
|
|
inputStream: _extends({}, config.inputStream, {
|
|
target: null
|
|
})
|
|
});
|
|
}
|
|
|
|
function workerInterface(factory) {
|
|
/* eslint-disable no-undef*/
|
|
if (factory) {
|
|
var Quagga = factory().default;
|
|
if (!Quagga) {
|
|
self.postMessage({ 'event': 'error', message: 'Quagga could not be created' });
|
|
return;
|
|
}
|
|
}
|
|
var imageWrapper;
|
|
|
|
self.onmessage = function (e) {
|
|
if (e.data.cmd === 'init') {
|
|
var config = e.data.config;
|
|
config.numOfWorkers = 0;
|
|
imageWrapper = new Quagga.ImageWrapper({
|
|
x: e.data.size.x,
|
|
y: e.data.size.y
|
|
}, new Uint8Array(e.data.imageData));
|
|
Quagga.init(config, ready, imageWrapper);
|
|
Quagga.onProcessed(onProcessed);
|
|
} else if (e.data.cmd === 'process') {
|
|
imageWrapper.data = new Uint8Array(e.data.imageData);
|
|
Quagga.start();
|
|
} else if (e.data.cmd === 'setReaders') {
|
|
Quagga.setReaders(e.data.readers);
|
|
}
|
|
};
|
|
|
|
function onProcessed(result) {
|
|
self.postMessage({
|
|
'event': 'processed',
|
|
imageData: imageWrapper.data,
|
|
result: result
|
|
}, [imageWrapper.data.buffer]);
|
|
}
|
|
|
|
function ready() {
|
|
// eslint-disable-line
|
|
self.postMessage({ 'event': 'initialized', imageData: imageWrapper.data }, [imageWrapper.data.buffer]);
|
|
}
|
|
|
|
/* eslint-enable */
|
|
}
|
|
|
|
function generateWorkerBlob() {
|
|
var blob, factorySource;
|
|
|
|
/* jshint ignore:start */
|
|
if (typeof __factorySource__ !== 'undefined') {
|
|
factorySource = __factorySource__; // eslint-disable-line no-undef
|
|
}
|
|
/* jshint ignore:end */
|
|
|
|
blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'], { type: 'text/javascript' });
|
|
|
|
return window.URL.createObjectURL(blob);
|
|
}
|
|
|
|
function _setReaders(readers) {
|
|
if (_decoder) {
|
|
_decoder.setReaders(readers);
|
|
} else if (_onUIThread && _workerPool.length > 0) {
|
|
_workerPool.forEach(function (workerThread) {
|
|
workerThread.worker.postMessage({ cmd: 'setReaders', readers: readers });
|
|
});
|
|
}
|
|
}
|
|
|
|
function adjustWorkerPool(capacity, cb) {
|
|
var increaseBy = capacity - _workerPool.length;
|
|
if (increaseBy === 0) {
|
|
return cb && cb();
|
|
}
|
|
if (increaseBy < 0) {
|
|
var workersToTerminate = _workerPool.slice(increaseBy);
|
|
workersToTerminate.forEach(function (workerThread) {
|
|
workerThread.worker.terminate();
|
|
if (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 (var i = 0; i < increaseBy; i++) {
|
|
initWorker(workerInitialized);
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 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 {
|
|
initInputStream(cb);
|
|
}
|
|
},
|
|
start: function start() {
|
|
_start();
|
|
},
|
|
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();
|
|
}
|
|
},
|
|
pause: function pause() {
|
|
_stopped = true;
|
|
},
|
|
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;
|
|
}
|
|
},
|
|
canvas: _canvasContainer,
|
|
decodeSingle: function decodeSingle(config, resultCallback) {
|
|
var _this = this;
|
|
|
|
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
|
|
}
|
|
}, 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();
|
|
});
|
|
},
|
|
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"]
|
|
};
|
|
|
|
/***/ },
|
|
/* 50 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__common_image_debug__ = __webpack_require__(9);
|
|
|
|
|
|
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;
|
|
}
|
|
|
|
/* 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;
|
|
|
|
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;
|
|
/* 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;
|
|
}
|
|
};
|
|
}
|
|
};
|
|
|
|
/***/ },
|
|
/* 51 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var vec2 = {
|
|
clone: __webpack_require__(6),
|
|
dot: __webpack_require__(31)
|
|
};
|
|
/**
|
|
* Creates a cluster for grouping similar orientations of datapoints
|
|
*/
|
|
/* harmony default export */ exports["a"] = {
|
|
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
|
|
};
|
|
}
|
|
};
|
|
|
|
/***/ },
|
|
/* 52 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* harmony default export */ exports["a"] = 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();
|
|
}
|
|
}
|
|
};
|
|
}();
|
|
|
|
/***/ },
|
|
/* 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;
|
|
|
|
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;
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = SubImage;
|
|
|
|
/***/ },
|
|
/* 54 */
|
|
/***/ function(module, exports) {
|
|
|
|
/*
|
|
* 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;
|
|
};
|
|
|
|
/***/ },
|
|
/* 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
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
/***/ },
|
|
/* 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');
|
|
}
|
|
|
|
/* 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; };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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();
|
|
|
|
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");
|
|
|
|
_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 (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(', '));
|
|
}
|
|
}
|
|
|
|
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";
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 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 = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__bresenham__["a"].getBarcodeLine(inputImageWrapper, line[0], line[1]);
|
|
|
|
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);
|
|
}
|
|
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_0__bresenham__["a"].toBinaryLine(barcodeLine);
|
|
|
|
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
|
|
};
|
|
}
|
|
|
|
/**
|
|
* 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 (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 });
|
|
}
|
|
}
|
|
|
|
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 (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 {
|
|
decodeFromBoundingBox: function decodeFromBoundingBox(box) {
|
|
return _decodeFromBoundingBox(box);
|
|
},
|
|
decodeFromBoundingBoxes: function decodeFromBoundingBoxes(boxes) {
|
|
var i,
|
|
result,
|
|
barcodes = [],
|
|
multiple = config.multiple;
|
|
|
|
for (i = 0; i < boxes.length; i++) {
|
|
var box = boxes[i];
|
|
result = _decodeFromBoundingBox(box) || {};
|
|
result.box = box;
|
|
|
|
if (multiple) {
|
|
barcodes.push(result);
|
|
} else if (result.codeResult) {
|
|
return result;
|
|
}
|
|
}
|
|
|
|
if (multiple) {
|
|
return {
|
|
barcodes: barcodes
|
|
};
|
|
}
|
|
},
|
|
setReaders: function setReaders(readers) {
|
|
config.readers = readers;
|
|
_barcodeReaders.length = 0;
|
|
initReaders();
|
|
}
|
|
};
|
|
}
|
|
};
|
|
|
|
/***/ },
|
|
/* 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
|
|
}
|
|
};
|
|
/**
|
|
* 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);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = Bresenham;
|
|
|
|
/***/ },
|
|
/* 59 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* 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 });
|
|
|
|
|
|
|
|
|
|
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 (true) {
|
|
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 = /* harmony import */__WEBPACK_IMPORTED_MODULE_0_lodash_pick___default.a.bind()(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(/* 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 pickConstraints(videoConstraints) {
|
|
var constraints = {
|
|
audio: false,
|
|
video: deprecatedConstraints(videoConstraints)
|
|
};
|
|
return applyCameraFacing(constraints.video.facingMode, constraints);
|
|
}
|
|
|
|
/* 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();
|
|
}
|
|
streamRef = null;
|
|
}
|
|
};
|
|
|
|
/***/ },
|
|
/* 60 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__common_cv_utils__ = __webpack_require__(17);
|
|
|
|
|
|
var FrameGrabber = {};
|
|
|
|
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;
|
|
|
|
_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
|
|
}));
|
|
}
|
|
|
|
/**
|
|
* Uses the given array as frame-buffer
|
|
*/
|
|
_that.attachData = function (data) {
|
|
_data = data;
|
|
};
|
|
|
|
/**
|
|
* Returns the used frame-buffer
|
|
*/
|
|
_that.getData = function () {
|
|
return _data;
|
|
};
|
|
|
|
/**
|
|
* Fetches a frame from the input-stream and puts into the frame-buffer.
|
|
* The image-data is converted to gray-scale and then half-sampled if configured.
|
|
*/
|
|
_that.grab = function () {
|
|
var doHalfSample = _streamConfig.halfSample,
|
|
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;
|
|
}
|
|
};
|
|
|
|
_that.getSize = function () {
|
|
return _size;
|
|
};
|
|
|
|
return _that;
|
|
};
|
|
|
|
/* 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;
|
|
|
|
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";
|
|
}
|
|
}
|
|
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;
|
|
}
|
|
}
|
|
if (notloadedImgs.length === 0) {
|
|
if (true) {
|
|
console.log("Images loaded");
|
|
}
|
|
callback.apply(null, [htmlImagesArray]);
|
|
}
|
|
};
|
|
|
|
for (i = 0; i < htmlImagesSrcArray.length; i++) {
|
|
img = new Image();
|
|
htmlImagesArray.addImage(img);
|
|
addOnloadHandler(img, htmlImagesArray);
|
|
img.src = htmlImagesSrcArray[i];
|
|
}
|
|
};
|
|
|
|
function addOnloadHandler(img, htmlImagesArray) {
|
|
img.onload = function () {
|
|
htmlImagesArray.loaded(this);
|
|
};
|
|
}
|
|
|
|
/* harmony default export */ exports["a"] = ImageLoader;
|
|
|
|
/***/ },
|
|
/* 62 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__image_loader__ = __webpack_require__(61);
|
|
|
|
|
|
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 };
|
|
|
|
function initSize() {
|
|
var width = video.videoWidth,
|
|
height = video.videoHeight;
|
|
|
|
_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;
|
|
}
|
|
|
|
that.getRealWidth = function () {
|
|
return video.videoWidth;
|
|
};
|
|
|
|
that.getRealHeight = function () {
|
|
return video.videoHeight;
|
|
};
|
|
|
|
that.getWidth = function () {
|
|
return _calculatedWidth;
|
|
};
|
|
|
|
that.getHeight = function () {
|
|
return _calculatedHeight;
|
|
};
|
|
|
|
that.setWidth = function (width) {
|
|
_calculatedWidth = width;
|
|
};
|
|
|
|
that.setHeight = function (height) {
|
|
_calculatedHeight = height;
|
|
};
|
|
|
|
that.setInputStream = function (config) {
|
|
_config = config;
|
|
video.src = typeof config.src !== 'undefined' ? config.src : '';
|
|
};
|
|
|
|
that.ended = function () {
|
|
return video.ended;
|
|
};
|
|
|
|
that.getConfig = function () {
|
|
return _config;
|
|
};
|
|
|
|
that.setAttribute = function (name, value) {
|
|
video.setAttribute(name, value);
|
|
};
|
|
|
|
that.pause = function () {
|
|
video.pause();
|
|
};
|
|
|
|
that.play = function () {
|
|
video.play();
|
|
};
|
|
|
|
that.setCurrentTime = function (time) {
|
|
if (_config.type !== "LiveStream") {
|
|
video.currentTime = time;
|
|
}
|
|
};
|
|
|
|
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);
|
|
}
|
|
};
|
|
|
|
that.clearEventHandlers = function () {
|
|
_eventNames.forEach(function (eventName) {
|
|
var handlers = _eventHandlers[eventName];
|
|
if (handlers && handlers.length > 0) {
|
|
handlers.forEach(function (handler) {
|
|
video.removeEventListener(eventName, handler);
|
|
});
|
|
}
|
|
});
|
|
};
|
|
|
|
that.trigger = function (eventName, args) {
|
|
var j,
|
|
handlers = _eventHandlers[eventName];
|
|
|
|
if (eventName === 'canrecord') {
|
|
initSize();
|
|
}
|
|
if (handlers && handlers.length > 0) {
|
|
for (j = 0; j < handlers.length; j++) {
|
|
handlers[j].apply(that, args);
|
|
}
|
|
}
|
|
};
|
|
|
|
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 () {
|
|
return video;
|
|
};
|
|
|
|
return that;
|
|
};
|
|
|
|
InputStream.createLiveStream = function (video) {
|
|
video.setAttribute("autoplay", true);
|
|
var that = InputStream.createVideoStream(video);
|
|
|
|
that.ended = function () {
|
|
return false;
|
|
};
|
|
|
|
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;
|
|
/* 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);
|
|
}
|
|
}
|
|
}
|
|
|
|
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();
|
|
};
|
|
|
|
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 (canvasSize) {
|
|
_canvasSize.x = canvasSize.x;
|
|
_canvasSize.y = canvasSize.y;
|
|
};
|
|
|
|
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;
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = InputStream;
|
|
|
|
/***/ },
|
|
/* 63 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* 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);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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 _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 /* 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;
|
|
}
|
|
|
|
_patchSize = /* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["b"].bind()(_config.patchSize, _currentImageWrapper.size);
|
|
|
|
_numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0;
|
|
_numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0;
|
|
|
|
_binaryImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"](_currentImageWrapper.size, undefined, Uint8Array, false);
|
|
|
|
_labelImageWrapper = new /* harmony import */__WEBPACK_IMPORTED_MODULE_0__common_image_wrapper__["a"](_patchSize, undefined, Array, true);
|
|
|
|
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);
|
|
|
|
_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);
|
|
}
|
|
|
|
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;
|
|
}
|
|
|
|
/**
|
|
* 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 (true && _config.debug.showPatches) {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].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 (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 });
|
|
}
|
|
}
|
|
|
|
// find bounding box
|
|
for (i = 0; i < patches.length; i++) {
|
|
patch = patches[i];
|
|
for (j = 0; j < 4; j++) {
|
|
if (patch.box[j][0] < minx) {
|
|
minx = patch.box[j][0];
|
|
}
|
|
if (patch.box[j][0] > maxx) {
|
|
maxx = patch.box[j][0];
|
|
}
|
|
if (patch.box[j][1] < miny) {
|
|
miny = patch.box[j][1];
|
|
}
|
|
if (patch.box[j][1] > maxy) {
|
|
maxy = patch.box[j][1];
|
|
}
|
|
}
|
|
}
|
|
|
|
box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]];
|
|
|
|
if (true && _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 });
|
|
}
|
|
|
|
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 (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 });
|
|
}
|
|
|
|
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() {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_1__common_cv_utils__["c"].bind()(_currentImageWrapper, _binaryImageWrapper);
|
|
_binaryImageWrapper.zeroBorder();
|
|
if (_config.debug.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();
|
|
/* 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 });
|
|
}
|
|
|
|
// 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];
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_3__common_image_debug__["a"].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 (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];
|
|
}
|
|
}
|
|
}
|
|
sc = cc;
|
|
while (sc !== null) {
|
|
sc.index = depthlabel;
|
|
sc = sc.nextpeer;
|
|
}
|
|
return {
|
|
cc: cc,
|
|
count: connectedCount
|
|
};
|
|
},
|
|
debug: {
|
|
drawContour: function drawContour(canvas, firstContour) {
|
|
var ctx = canvas.getContext("2d"),
|
|
pq = firstContour,
|
|
iq,
|
|
q,
|
|
p;
|
|
|
|
ctx.strokeStyle = "red";
|
|
ctx.fillStyle = "red";
|
|
ctx.lineWidth = 1;
|
|
|
|
if (pq !== null) {
|
|
iq = pq.insideContours;
|
|
} else {
|
|
iq = null;
|
|
}
|
|
|
|
while (pq !== null) {
|
|
if (iq !== null) {
|
|
q = iq;
|
|
iq = iq.nextpeer;
|
|
} else {
|
|
q = pq;
|
|
pq = pq.nextpeer;
|
|
if (pq !== null) {
|
|
iq = pq.insideContours;
|
|
} else {
|
|
iq = null;
|
|
}
|
|
}
|
|
|
|
switch (q.dir) {
|
|
case Rasterizer.CONTOUR_DIR.CW_DIR:
|
|
ctx.strokeStyle = "red";
|
|
break;
|
|
case Rasterizer.CONTOUR_DIR.CCW_DIR:
|
|
ctx.strokeStyle = "blue";
|
|
break;
|
|
case Rasterizer.CONTOUR_DIR.UNKNOWN_DIR:
|
|
ctx.strokeStyle = "green";
|
|
break;
|
|
}
|
|
|
|
p = q.firstVertex;
|
|
ctx.beginPath();
|
|
ctx.moveTo(p.x, p.y);
|
|
do {
|
|
p = p.next;
|
|
ctx.lineTo(p.x, p.y);
|
|
} while (p !== q.firstVertex);
|
|
ctx.stroke();
|
|
}
|
|
}
|
|
}
|
|
};
|
|
}
|
|
};
|
|
|
|
/* 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;
|
|
}
|
|
for (x = 0; (x | 0) < (size | 0); x = x + 1 | 0) {
|
|
images[imagePtr + y | 0] = 0;
|
|
y = y + 1 | 0;
|
|
}
|
|
}
|
|
|
|
function skeletonize() {
|
|
var subImagePtr = 0,
|
|
erodedImagePtr = 0,
|
|
tempImagePtr = 0,
|
|
skelImagePtr = 0,
|
|
sum = 0,
|
|
done = 0;
|
|
|
|
erodedImagePtr = imul(size, size) | 0;
|
|
tempImagePtr = erodedImagePtr + erodedImagePtr | 0;
|
|
skelImagePtr = tempImagePtr + erodedImagePtr | 0;
|
|
|
|
// init skel-image
|
|
init(skelImagePtr, 0);
|
|
zeroBorder(subImagePtr);
|
|
|
|
do {
|
|
erode(subImagePtr, erodedImagePtr);
|
|
dilate(erodedImagePtr, tempImagePtr);
|
|
subtract(subImagePtr, tempImagePtr, tempImagePtr);
|
|
bitwiseOr(skelImagePtr, tempImagePtr, skelImagePtr);
|
|
memcpy(erodedImagePtr, subImagePtr);
|
|
sum = countNonZero(subImagePtr) | 0;
|
|
done = (sum | 0) == 0 | 0;
|
|
} while (!done);
|
|
}
|
|
return {
|
|
skeletonize: skeletonize
|
|
};
|
|
}
|
|
/* @preserve ASM END */
|
|
/* 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);
|
|
|
|
|
|
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;
|
|
|
|
do {
|
|
pattern = self._toPattern(nextStart);
|
|
if (pattern < 0) {
|
|
return null;
|
|
}
|
|
decodedChar = self._patternToChar(pattern);
|
|
if (decodedChar < 0) {
|
|
return null;
|
|
}
|
|
result.push(decodedChar);
|
|
nextStart += 8;
|
|
if (result.length > 1 && self._isStartEnd(pattern)) {
|
|
break;
|
|
}
|
|
} while (nextStart < self._counters.length);
|
|
|
|
// verify end
|
|
if (result.length - 2 < self.MIN_ENCODED_CHARS || !self._isStartEnd(pattern)) {
|
|
return null;
|
|
}
|
|
|
|
// verify end white space
|
|
if (!self._verifyWhitespace(start.startCounter, nextStart - 8)) {
|
|
return null;
|
|
}
|
|
|
|
if (!self._validateResult(result, start.startCounter)) {
|
|
return null;
|
|
}
|
|
|
|
nextStart = nextStart > self._counters.length ? self._counters.length : nextStart;
|
|
end = start.start + self._sumCounters(start.startCounter, nextStart - 8);
|
|
|
|
return {
|
|
code: result.join(""),
|
|
start: start.start,
|
|
end: end,
|
|
startInfo: start,
|
|
decodedCodes: result
|
|
};
|
|
};
|
|
|
|
CodabarReader.prototype._verifyWhitespace = function (startCounter, endCounter) {
|
|
if (startCounter - 1 <= 0 || this._counters[startCounter - 1] >= this._calculatePatternLength(startCounter) / 2.0) {
|
|
if (endCounter + 8 >= this._counters.length || this._counters[endCounter + 7] >= this._calculatePatternLength(endCounter) / 2.0) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
};
|
|
|
|
CodabarReader.prototype._calculatePatternLength = function (offset) {
|
|
var i,
|
|
sum = 0;
|
|
|
|
for (i = offset; i < offset + 7; i++) {
|
|
sum += this._counters[i];
|
|
}
|
|
|
|
return sum;
|
|
};
|
|
|
|
CodabarReader.prototype._thresholdResultPattern = function (result, startCounter) {
|
|
var self = this,
|
|
categorization = {
|
|
space: {
|
|
narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE },
|
|
wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE }
|
|
},
|
|
bar: {
|
|
narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE },
|
|
wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE }
|
|
}
|
|
},
|
|
kind,
|
|
cat,
|
|
i,
|
|
j,
|
|
pos = startCounter,
|
|
pattern;
|
|
|
|
for (i = 0; i < result.length; i++) {
|
|
pattern = self._charToPattern(result[i]);
|
|
for (j = 6; j >= 0; j--) {
|
|
kind = (j & 1) === 2 ? categorization.bar : categorization.space;
|
|
cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;
|
|
cat.size += self._counters[pos + j];
|
|
cat.counts++;
|
|
pattern >>= 1;
|
|
}
|
|
pos += 8;
|
|
}
|
|
|
|
["space", "bar"].forEach(function (key) {
|
|
var newkind = categorization[key];
|
|
newkind.wide.min = Math.floor((newkind.narrow.size / newkind.narrow.counts + newkind.wide.size / newkind.wide.counts) / 2);
|
|
newkind.narrow.max = Math.ceil(newkind.wide.min);
|
|
newkind.wide.max = Math.ceil((newkind.wide.size * self.MAX_ACCEPTABLE + self.PADDING) / newkind.wide.counts);
|
|
});
|
|
|
|
return categorization;
|
|
};
|
|
|
|
CodabarReader.prototype._charToPattern = function (char) {
|
|
var self = this,
|
|
charCode = char.charCodeAt(0),
|
|
i;
|
|
|
|
for (i = 0; i < self.ALPHABET.length; i++) {
|
|
if (self.ALPHABET[i] === charCode) {
|
|
return self.CHARACTER_ENCODINGS[i];
|
|
}
|
|
}
|
|
return 0x0;
|
|
};
|
|
|
|
CodabarReader.prototype._validateResult = function (result, startCounter) {
|
|
var self = this,
|
|
thresholds = self._thresholdResultPattern(result, startCounter),
|
|
i,
|
|
j,
|
|
kind,
|
|
cat,
|
|
size,
|
|
pos = startCounter,
|
|
pattern;
|
|
|
|
for (i = 0; i < result.length; i++) {
|
|
pattern = self._charToPattern(result[i]);
|
|
for (j = 6; j >= 0; j--) {
|
|
kind = (j & 1) === 0 ? thresholds.bar : thresholds.space;
|
|
cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;
|
|
size = self._counters[pos + j];
|
|
if (size < cat.min || size > cat.max) {
|
|
return false;
|
|
}
|
|
pattern >>= 1;
|
|
}
|
|
pos += 8;
|
|
}
|
|
return true;
|
|
};
|
|
|
|
CodabarReader.prototype._patternToChar = function (pattern) {
|
|
var i,
|
|
self = this;
|
|
|
|
for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {
|
|
if (self.CHARACTER_ENCODINGS[i] === pattern) {
|
|
return String.fromCharCode(self.ALPHABET[i]);
|
|
}
|
|
}
|
|
return -1;
|
|
};
|
|
|
|
CodabarReader.prototype._computeAlternatingThreshold = function (offset, end) {
|
|
var i,
|
|
min = Number.MAX_VALUE,
|
|
max = 0,
|
|
counter;
|
|
|
|
for (i = offset; i < end; i += 2) {
|
|
counter = this._counters[i];
|
|
if (counter > max) {
|
|
max = counter;
|
|
}
|
|
if (counter < min) {
|
|
min = counter;
|
|
}
|
|
}
|
|
|
|
return (min + max) / 2.0 | 0;
|
|
};
|
|
|
|
CodabarReader.prototype._toPattern = function (offset) {
|
|
var numCounters = 7,
|
|
end = offset + numCounters,
|
|
barThreshold,
|
|
spaceThreshold,
|
|
bitmask = 1 << numCounters - 1,
|
|
pattern = 0,
|
|
i,
|
|
threshold;
|
|
|
|
if (end > this._counters.length) {
|
|
return -1;
|
|
}
|
|
|
|
barThreshold = this._computeAlternatingThreshold(offset, end);
|
|
spaceThreshold = this._computeAlternatingThreshold(offset + 1, end);
|
|
|
|
for (i = 0; i < numCounters; i++) {
|
|
threshold = (i & 1) === 0 ? barThreshold : spaceThreshold;
|
|
if (this._counters[offset + i] > threshold) {
|
|
pattern |= bitmask;
|
|
}
|
|
bitmask >>= 1;
|
|
}
|
|
|
|
return pattern;
|
|
};
|
|
|
|
CodabarReader.prototype._isStartEnd = function (pattern) {
|
|
var i;
|
|
|
|
for (i = 0; i < this.START_END.length; i++) {
|
|
if (this.START_END[i] === pattern) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
};
|
|
|
|
CodabarReader.prototype._sumCounters = function (start, end) {
|
|
var i,
|
|
sum = 0;
|
|
|
|
for (i = start; i < end; i++) {
|
|
sum += this._counters[i];
|
|
}
|
|
return sum;
|
|
};
|
|
|
|
CodabarReader.prototype._findStart = function () {
|
|
var self = this,
|
|
i,
|
|
pattern,
|
|
start = self._nextUnset(self._row),
|
|
end;
|
|
|
|
for (i = 1; i < this._counters.length; i++) {
|
|
pattern = self._toPattern(i);
|
|
if (pattern !== -1 && self._isStartEnd(pattern)) {
|
|
// TODO: Look for whitespace ahead
|
|
start += self._sumCounters(0, i);
|
|
end = start + self._sumCounters(i, i + 8);
|
|
return {
|
|
start: start,
|
|
end: end,
|
|
startCounter: i,
|
|
endCounter: i + 8
|
|
};
|
|
}
|
|
}
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = CodabarReader;
|
|
|
|
/***/ },
|
|
/* 67 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__barcode_reader__ = __webpack_require__(5);
|
|
|
|
|
|
function Code128Reader() {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].call(this);
|
|
}
|
|
|
|
var properties = {
|
|
CODE_SHIFT: { value: 98 },
|
|
CODE_C: { value: 99 },
|
|
CODE_B: { value: 100 },
|
|
CODE_A: { value: 101 },
|
|
START_CODE_A: { value: 103 },
|
|
START_CODE_B: { value: 104 },
|
|
START_CODE_C: { value: 105 },
|
|
STOP_CODE: { value: 106 },
|
|
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 }
|
|
};
|
|
|
|
Code128Reader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__barcode_reader__["a"].prototype, properties);
|
|
Code128Reader.prototype.constructor = Code128Reader;
|
|
|
|
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;
|
|
|
|
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 = 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;
|
|
}
|
|
}
|
|
|
|
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;
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
} else {
|
|
done = true;
|
|
}
|
|
if (unshift) {
|
|
codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A;
|
|
}
|
|
}
|
|
|
|
if (code === null) {
|
|
return null;
|
|
}
|
|
|
|
code.end = self._nextUnset(self._row, code.end);
|
|
if (!self._verifyTrailingWhitespace(code)) {
|
|
return null;
|
|
}
|
|
|
|
checksum -= multiplier * rawResult[rawResult.length - 1];
|
|
if (checksum % 103 !== rawResult[rawResult.length - 1]) {
|
|
return null;
|
|
}
|
|
|
|
if (!result.length) {
|
|
return null;
|
|
}
|
|
|
|
// remove last code from result (checksum)
|
|
if (removeLastCharacter) {
|
|
result.splice(result.length - 1, 1);
|
|
}
|
|
|
|
return {
|
|
code: result.join(""),
|
|
start: startInfo.start,
|
|
end: code.end,
|
|
codeset: codeset,
|
|
startInfo: startInfo,
|
|
decodedCodes: decodedCodes,
|
|
endInfo: code
|
|
};
|
|
};
|
|
|
|
/* 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;
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = Code128Reader;
|
|
|
|
/***/ },
|
|
/* 68 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__code_39_reader__ = __webpack_require__(30);
|
|
|
|
|
|
function Code39VINReader() {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_0__code_39_reader__["a"].call(this);
|
|
}
|
|
|
|
var patterns = {
|
|
IOQ: /[IOQ]/g,
|
|
AZ09: /[A-Z0-9]{17}/
|
|
};
|
|
|
|
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 = /* harmony import */__WEBPACK_IMPORTED_MODULE_0__code_39_reader__["a"].prototype._decode.apply(this);
|
|
if (!result) {
|
|
return null;
|
|
}
|
|
|
|
var code = result.code;
|
|
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
|
|
code = code.replace(patterns.IOQ, '');
|
|
|
|
if (!code.match(patterns.AZ09)) {
|
|
if (true) {
|
|
console.log('Failed AZ09 pattern code:', code);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
if (!this._checkChecksum(code)) {
|
|
return null;
|
|
}
|
|
|
|
result.code = code;
|
|
return result;
|
|
};
|
|
|
|
Code39VINReader.prototype._checkChecksum = function (code) {
|
|
// TODO
|
|
return !!code;
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = Code39VINReader;
|
|
|
|
/***/ },
|
|
/* 69 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__ean_reader__ = __webpack_require__(10);
|
|
|
|
|
|
function EAN8Reader() {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].call(this);
|
|
}
|
|
|
|
var properties = {
|
|
FORMAT: { value: "ean_8", writeable: false }
|
|
};
|
|
|
|
EAN8Reader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].prototype, properties);
|
|
EAN8Reader.prototype.constructor = EAN8Reader;
|
|
|
|
EAN8Reader.prototype._decodePayload = function (code, result, decodedCodes) {
|
|
var i,
|
|
self = this;
|
|
|
|
for (i = 0; i < 4; i++) {
|
|
code = self._decodeCode(code.end, self.CODE_G_START);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
result.push(code.code);
|
|
decodedCodes.push(code);
|
|
}
|
|
|
|
code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);
|
|
if (code === null) {
|
|
return null;
|
|
}
|
|
decodedCodes.push(code);
|
|
|
|
for (i = 0; i < 4; i++) {
|
|
code = self._decodeCode(code.end, self.CODE_G_START);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
decodedCodes.push(code);
|
|
result.push(code.code);
|
|
}
|
|
|
|
return code;
|
|
};
|
|
|
|
/* 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);
|
|
|
|
|
|
|
|
|
|
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;
|
|
}
|
|
}
|
|
|
|
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" }
|
|
};
|
|
|
|
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 = 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 /* harmony import */__WEBPACK_IMPORTED_MODULE_1__barcode_reader__["a"].prototype._matchPattern.call(this, counter, code);
|
|
};
|
|
|
|
I2of5Reader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder) {
|
|
var counter = [],
|
|
self = this,
|
|
i,
|
|
counterPos = 0,
|
|
bestMatch = {
|
|
error: Number.MAX_VALUE,
|
|
code: -1,
|
|
start: 0,
|
|
end: 0
|
|
},
|
|
error,
|
|
j,
|
|
sum,
|
|
normalized,
|
|
epsilon = self.AVG_CODE_ERROR;
|
|
|
|
isWhite = isWhite || false;
|
|
tryHarder = tryHarder || false;
|
|
|
|
if (!offset) {
|
|
offset = self._nextSet(self._row);
|
|
}
|
|
|
|
for (i = 0; i < pattern.length; i++) {
|
|
counter[i] = 0;
|
|
}
|
|
|
|
for (i = offset; i < self._row.length; i++) {
|
|
if (self._row[i] ^ isWhite) {
|
|
counter[counterPos]++;
|
|
} else {
|
|
if (counterPos === counter.length - 1) {
|
|
sum = 0;
|
|
for (j = 0; j < counter.length; j++) {
|
|
sum += counter[j];
|
|
}
|
|
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;
|
|
}
|
|
}
|
|
return null;
|
|
};
|
|
|
|
I2of5Reader.prototype._findStart = function () {
|
|
var self = this,
|
|
leadingWhitespaceStart,
|
|
offset = self._nextSet(self._row),
|
|
startInfo,
|
|
narrowBarWidth = 1;
|
|
|
|
while (!startInfo) {
|
|
startInfo = self._findPattern(self.START_PATTERN, offset, false, true);
|
|
if (!startInfo) {
|
|
return null;
|
|
}
|
|
narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / 4);
|
|
leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10;
|
|
if (leadingWhitespaceStart >= 0) {
|
|
if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
|
|
return startInfo;
|
|
}
|
|
}
|
|
offset = startInfo.end;
|
|
startInfo = null;
|
|
}
|
|
};
|
|
|
|
I2of5Reader.prototype._verifyTrailingWhitespace = function (endInfo) {
|
|
var self = this,
|
|
trailingWhitespaceEnd;
|
|
|
|
trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;
|
|
if (trailingWhitespaceEnd < self._row.length) {
|
|
if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
|
|
return endInfo;
|
|
}
|
|
}
|
|
return null;
|
|
};
|
|
|
|
I2of5Reader.prototype._findEnd = function () {
|
|
var self = this,
|
|
endInfo,
|
|
tmp;
|
|
|
|
self._row.reverse();
|
|
endInfo = self._findPattern(self.STOP_PATTERN);
|
|
self._row.reverse();
|
|
|
|
if (endInfo === null) {
|
|
return null;
|
|
}
|
|
|
|
// reverse numbers
|
|
tmp = endInfo.start;
|
|
endInfo.start = self._row.length - endInfo.end;
|
|
endInfo.end = self._row.length - tmp;
|
|
|
|
return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;
|
|
};
|
|
|
|
I2of5Reader.prototype._decodePair = function (counterPair) {
|
|
var i,
|
|
code,
|
|
codes = [],
|
|
self = this;
|
|
|
|
for (i = 0; i < counterPair.length; i++) {
|
|
code = self._decodeCode(counterPair[i]);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
codes.push(code);
|
|
}
|
|
return codes;
|
|
};
|
|
|
|
I2of5Reader.prototype._decodeCode = function (counter) {
|
|
var j,
|
|
self = this,
|
|
sum = 0,
|
|
normalized,
|
|
error,
|
|
epsilon = self.AVG_CODE_ERROR,
|
|
code,
|
|
bestMatch = {
|
|
error: Number.MAX_VALUE,
|
|
code: -1,
|
|
start: 0,
|
|
end: 0
|
|
};
|
|
|
|
for (j = 0; j < counter.length; j++) {
|
|
sum += counter[j];
|
|
}
|
|
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;
|
|
};
|
|
|
|
I2of5Reader.prototype._decodePayload = function (counters, result, decodedCodes) {
|
|
var i,
|
|
self = this,
|
|
pos = 0,
|
|
counterLength = counters.length,
|
|
counterPair = [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0]],
|
|
codes;
|
|
|
|
while (pos < counterLength) {
|
|
for (i = 0; i < 5; i++) {
|
|
counterPair[0][i] = counters[pos] * this.barSpaceRatio[0];
|
|
counterPair[1][i] = counters[pos + 1] * this.barSpaceRatio[1];
|
|
pos += 2;
|
|
}
|
|
codes = self._decodePair(counterPair);
|
|
if (!codes) {
|
|
return null;
|
|
}
|
|
for (i = 0; i < codes.length; i++) {
|
|
result.push(codes[i].code + "");
|
|
decodedCodes.push(codes[i]);
|
|
}
|
|
}
|
|
return codes;
|
|
};
|
|
|
|
I2of5Reader.prototype._verifyCounterLength = function (counters) {
|
|
return counters.length % 10 === 0;
|
|
};
|
|
|
|
I2of5Reader.prototype._decode = function () {
|
|
var startInfo,
|
|
endInfo,
|
|
self = this,
|
|
code,
|
|
result = [],
|
|
decodedCodes = [],
|
|
counters;
|
|
|
|
startInfo = self._findStart();
|
|
if (!startInfo) {
|
|
return null;
|
|
}
|
|
decodedCodes.push(startInfo);
|
|
|
|
endInfo = self._findEnd();
|
|
if (!endInfo) {
|
|
return null;
|
|
}
|
|
|
|
counters = self._fillCounters(startInfo.end, endInfo.start, false);
|
|
if (!self._verifyCounterLength(counters)) {
|
|
return null;
|
|
}
|
|
code = self._decodePayload(counters, result, decodedCodes);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
if (result.length % 2 !== 0 || result.length < 6) {
|
|
return null;
|
|
}
|
|
|
|
decodedCodes.push(endInfo);
|
|
return {
|
|
code: result.join(""),
|
|
start: startInfo.start,
|
|
end: endInfo.end,
|
|
startInfo: startInfo,
|
|
decodedCodes: decodedCodes
|
|
};
|
|
};
|
|
|
|
I2of5Reader.CONFIG_KEYS = {
|
|
normalizeBarSpaceWidth: {
|
|
'type': 'boolean',
|
|
'default': false,
|
|
'description': 'If true, the reader tries to normalize the' + 'width-difference between bars and spaces'
|
|
}
|
|
};
|
|
|
|
/* harmony default export */ exports["a"] = I2of5Reader;
|
|
|
|
/***/ },
|
|
/* 71 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__ean_reader__ = __webpack_require__(10);
|
|
|
|
|
|
function UPCEReader() {
|
|
/* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].call(this);
|
|
}
|
|
|
|
var properties = {
|
|
CODE_FREQUENCY: { value: [[56, 52, 50, 49, 44, 38, 35, 42, 41, 37], [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]] },
|
|
STOP_PATTERN: { value: [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7] },
|
|
FORMAT: { value: "upc_e", writeable: false }
|
|
};
|
|
|
|
UPCEReader.prototype = Object.create(/* harmony import */__WEBPACK_IMPORTED_MODULE_0__ean_reader__["a"].prototype, properties);
|
|
UPCEReader.prototype.constructor = UPCEReader;
|
|
|
|
UPCEReader.prototype._decodePayload = function (code, result, decodedCodes) {
|
|
var i,
|
|
self = this,
|
|
codeFrequency = 0x0;
|
|
|
|
for (i = 0; i < 6; i++) {
|
|
code = self._decodeCode(code.end);
|
|
if (!code) {
|
|
return null;
|
|
}
|
|
if (code.code >= self.CODE_G_START) {
|
|
code.code = code.code - self.CODE_G_START;
|
|
codeFrequency |= 1 << 5 - i;
|
|
}
|
|
result.push(code.code);
|
|
decodedCodes.push(code);
|
|
}
|
|
if (!self._determineParity(codeFrequency, result)) {
|
|
return null;
|
|
}
|
|
|
|
return code;
|
|
};
|
|
|
|
UPCEReader.prototype._determineParity = function (codeFrequency, result) {
|
|
var i, nrSystem;
|
|
|
|
for (nrSystem = 0; nrSystem < this.CODE_FREQUENCY.length; nrSystem++) {
|
|
for (i = 0; i < this.CODE_FREQUENCY[nrSystem].length; i++) {
|
|
if (codeFrequency === this.CODE_FREQUENCY[nrSystem][i]) {
|
|
result.unshift(nrSystem);
|
|
result.push(i);
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
};
|
|
|
|
UPCEReader.prototype._convertToUPCA = function (result) {
|
|
var upca = [result[0]],
|
|
lastDigit = result[result.length - 2];
|
|
|
|
if (lastDigit <= 2) {
|
|
upca = upca.concat(result.slice(1, 3)).concat([lastDigit, 0, 0, 0, 0]).concat(result.slice(3, 6));
|
|
} else if (lastDigit === 3) {
|
|
upca = upca.concat(result.slice(1, 4)).concat([0, 0, 0, 0, 0]).concat(result.slice(4, 6));
|
|
} else if (lastDigit === 4) {
|
|
upca = upca.concat(result.slice(1, 5)).concat([0, 0, 0, 0, 0, result[5]]);
|
|
} else {
|
|
upca = upca.concat(result.slice(1, 6)).concat([0, 0, 0, 0, lastDigit]);
|
|
}
|
|
|
|
upca.push(result[result.length - 1]);
|
|
return upca;
|
|
};
|
|
|
|
UPCEReader.prototype._checksum = function (result) {
|
|
return /* 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;
|
|
|
|
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;
|
|
|
|
|
|
/***/ },
|
|
/* 81 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var root = __webpack_require__(1);
|
|
|
|
/** Built-in value references. */
|
|
var Reflect = root.Reflect;
|
|
|
|
module.e = Reflect;
|
|
|
|
|
|
/***/ },
|
|
/* 82 */
|
|
/***/ 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;
|
|
|
|
|
|
/***/ },
|
|
/* 83 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var root = __webpack_require__(1);
|
|
|
|
/** Built-in value references. */
|
|
var Symbol = root.Symbol;
|
|
|
|
module.e = Symbol;
|
|
|
|
|
|
/***/ },
|
|
/* 84 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var root = __webpack_require__(1);
|
|
|
|
/** Built-in value references. */
|
|
var Uint8Array = root.Uint8Array;
|
|
|
|
module.e = Uint8Array;
|
|
|
|
|
|
/***/ },
|
|
/* 85 */
|
|
/***/ 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;
|
|
|
|
|
|
/***/ },
|
|
/* 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;
|
|
}
|
|
|
|
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;
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
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;
|
|
|
|
while (++index < length) {
|
|
array[offset + index] = values[index];
|
|
}
|
|
return array;
|
|
}
|
|
|
|
module.e = arrayPush;
|
|
|
|
|
|
/***/ },
|
|
/* 90 */
|
|
/***/ 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;
|
|
|
|
|
|
/***/ },
|
|
/* 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);
|
|
|
|
/** `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);
|
|
|
|
// 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;
|
|
|
|
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;
|
|
}
|
|
|
|
module.e = baseFlatten;
|
|
|
|
|
|
/***/ },
|
|
/* 94 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var createBaseFor = __webpack_require__(114);
|
|
|
|
/**
|
|
* 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();
|
|
|
|
module.e = baseFor;
|
|
|
|
|
|
/***/ },
|
|
/* 95 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var baseFor = __webpack_require__(94),
|
|
keys = __webpack_require__(45);
|
|
|
|
/**
|
|
* 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);
|
|
}
|
|
|
|
module.e = baseForOwn;
|
|
|
|
|
|
/***/ },
|
|
/* 96 */
|
|
/***/ 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;
|
|
|
|
/** Built-in value references. */
|
|
var getPrototypeOf = Object.getPrototypeOf;
|
|
|
|
/**
|
|
* 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);
|
|
}
|
|
|
|
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;
|
|
|
|
/**
|
|
* 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));
|
|
}
|
|
|
|
module.e = baseKeys;
|
|
|
|
|
|
/***/ },
|
|
/* 98 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var Reflect = __webpack_require__(81),
|
|
iteratorToArray = __webpack_require__(125);
|
|
|
|
/** Used for built-in method references. */
|
|
var objectProto = Object.prototype;
|
|
|
|
/** Built-in value references. */
|
|
var enumerate = Reflect ? Reflect.enumerate : undefined,
|
|
propertyIsEnumerable = objectProto.propertyIsEnumerable;
|
|
|
|
/**
|
|
* 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);
|
|
|
|
var result = [];
|
|
for (var key in object) {
|
|
result.push(key);
|
|
}
|
|
return result;
|
|
}
|
|
|
|
// Fallback for IE < 9 with es6-shim.
|
|
if (enumerate && !propertyIsEnumerable.call({ 'valueOf': 1 }, 'valueOf')) {
|
|
baseKeysIn = function(object) {
|
|
return iteratorToArray(enumerate(object));
|
|
};
|
|
}
|
|
|
|
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);
|
|
}
|
|
else {
|
|
var newValue = customizer
|
|
? customizer(object[key], srcValue, (key + ''), object, source, stack)
|
|
: undefined;
|
|
|
|
if (newValue === undefined) {
|
|
newValue = srcValue;
|
|
}
|
|
assignMergeValue(object, key, newValue);
|
|
}
|
|
});
|
|
}
|
|
|
|
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);
|
|
|
|
/**
|
|
* 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;
|
|
|
|
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);
|
|
}
|
|
}
|
|
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);
|
|
|
|
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);
|
|
}
|
|
|
|
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;
|
|
}, {});
|
|
}
|
|
|
|
module.e = basePick;
|
|
|
|
|
|
/***/ },
|
|
/* 102 */
|
|
/***/ 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];
|
|
};
|
|
}
|
|
|
|
module.e = baseProperty;
|
|
|
|
|
|
/***/ },
|
|
/* 103 */
|
|
/***/ 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);
|
|
|
|
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.
|
|
*
|
|
* @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`.
|
|
*
|
|
* @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`.
|
|
*
|
|
* @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`.
|
|
*
|
|
* @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`.
|
|
*
|
|
* @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`.
|
|
*
|
|
* @private
|
|
* @param {Object} source The object to copy symbols from.
|
|
* @param {Object} [object={}] The object to copy symbols to.
|
|
* @returns {Object} Returns `object`.
|
|
*/
|
|
function copySymbols(source, object) {
|
|
return copyObject(source, getSymbols(source), object);
|
|
}
|
|
|
|
module.e = copySymbols;
|
|
|
|
|
|
/***/ },
|
|
/* 113 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var isIterateeCall = __webpack_require__(124),
|
|
rest = __webpack_require__(47);
|
|
|
|
/**
|
|
* Creates a function like `_.assign`.
|
|
*
|
|
* @private
|
|
* @param {Function} assigner The function to assign values.
|
|
* @returns {Function} Returns the new assigner function.
|
|
*/
|
|
function createAssigner(assigner) {
|
|
return rest(function(object, sources) {
|
|
var index = -1,
|
|
length = sources.length,
|
|
customizer = length > 1 ? sources[length - 1] : undefined,
|
|
guard = length > 2 ? sources[2] : undefined;
|
|
|
|
customizer = typeof customizer == 'function'
|
|
? (length--, customizer)
|
|
: undefined;
|
|
|
|
if (guard && isIterateeCall(sources[0], sources[1], guard)) {
|
|
customizer = length < 3 ? undefined : customizer;
|
|
length = 1;
|
|
}
|
|
object = Object(object);
|
|
while (++index < length) {
|
|
var source = sources[index];
|
|
if (source) {
|
|
assigner(object, source, index, customizer);
|
|
}
|
|
}
|
|
return object;
|
|
});
|
|
}
|
|
|
|
module.e = createAssigner;
|
|
|
|
|
|
/***/ },
|
|
/* 114 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/**
|
|
* Creates a base function for methods like `_.forIn`.
|
|
*
|
|
* @private
|
|
* @param {boolean} [fromRight] Specify iterating from right to left.
|
|
* @returns {Function} Returns the new base function.
|
|
*/
|
|
function createBaseFor(fromRight) {
|
|
return function(object, iteratee, keysFunc) {
|
|
var index = -1,
|
|
iterable = Object(object),
|
|
props = keysFunc(object),
|
|
length = props.length;
|
|
|
|
while (length--) {
|
|
var key = props[fromRight ? length : ++index];
|
|
if (iteratee(iterable[key], key, iterable) === false) {
|
|
break;
|
|
}
|
|
}
|
|
return object;
|
|
};
|
|
}
|
|
|
|
module.e = createBaseFor;
|
|
|
|
|
|
/***/ },
|
|
/* 115 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var baseProperty = __webpack_require__(102);
|
|
|
|
/**
|
|
* 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;
|
|
|
|
|
|
/***/ },
|
|
/* 116 */
|
|
/***/ 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;
|
|
|
|
|
|
/***/ },
|
|
/* 117 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var Map = __webpack_require__(3),
|
|
Set = __webpack_require__(82),
|
|
WeakMap = __webpack_require__(85);
|
|
|
|
/** `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;
|
|
|
|
/**
|
|
* 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 {*} value The value to query.
|
|
* @returns {string} Returns the `toStringTag`.
|
|
*/
|
|
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.e = getTag;
|
|
|
|
|
|
/***/ },
|
|
/* 118 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var hashHas = __webpack_require__(42);
|
|
|
|
/**
|
|
* Removes `key` and its value from the hash.
|
|
*
|
|
* @private
|
|
* @param {Object} hash The hash to modify.
|
|
* @param {string} key The key of the value to remove.
|
|
* @returns {boolean} Returns `true` if the entry was removed, else `false`.
|
|
*/
|
|
function hashDelete(hash, key) {
|
|
return hashHas(hash, key) && delete hash[key];
|
|
}
|
|
|
|
module.e = hashDelete;
|
|
|
|
|
|
/***/ },
|
|
/* 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;
|
|
|
|
/**
|
|
* Gets the hash value for `key`.
|
|
*
|
|
* @private
|
|
* @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.e = hashGet;
|
|
|
|
|
|
/***/ },
|
|
/* 120 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var nativeCreate = __webpack_require__(14);
|
|
|
|
/** Used to stand-in for `undefined` hash values. */
|
|
var HASH_UNDEFINED = '__lodash_hash_undefined__';
|
|
|
|
/**
|
|
* Sets the hash `key` to `value`.
|
|
*
|
|
* @private
|
|
* @param {Object} hash The hash to modify.
|
|
* @param {string} key The key of the value to set.
|
|
* @param {*} value The value to set.
|
|
*/
|
|
function hashSet(hash, key, value) {
|
|
hash[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;
|
|
}
|
|
|
|
module.e = hashSet;
|
|
|
|
|
|
/***/ },
|
|
/* 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;
|
|
|
|
/**
|
|
* Initializes an array clone.
|
|
*
|
|
* @private
|
|
* @param {Array} array The array to clone.
|
|
* @returns {Array} Returns the initialized clone.
|
|
*/
|
|
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.e = initCloneArray;
|
|
|
|
|
|
/***/ },
|
|
/* 122 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
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 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]';
|
|
|
|
/**
|
|
* Initializes an object clone based on its `toStringTag`.
|
|
*
|
|
* **Note:** This function only supports cloning values with tags of
|
|
* `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.
|
|
*
|
|
* @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.
|
|
*/
|
|
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.e = initCloneByTag;
|
|
|
|
|
|
/***/ },
|
|
/* 123 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var baseCreate = __webpack_require__(92),
|
|
isPrototype = __webpack_require__(23);
|
|
|
|
/** Built-in value references. */
|
|
var getPrototypeOf = Object.getPrototypeOf;
|
|
|
|
/**
|
|
* Initializes an object clone.
|
|
*
|
|
* @private
|
|
* @param {Object} object The object to clone.
|
|
* @returns {Object} Returns the initialized clone.
|
|
*/
|
|
function initCloneObject(object) {
|
|
return (typeof object.constructor == 'function' && !isPrototype(object))
|
|
? baseCreate(getPrototypeOf(object))
|
|
: {};
|
|
}
|
|
|
|
module.e = initCloneObject;
|
|
|
|
|
|
/***/ },
|
|
/* 124 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var eq = __webpack_require__(15),
|
|
isArrayLike = __webpack_require__(25),
|
|
isIndex = __webpack_require__(22),
|
|
isObject = __webpack_require__(2);
|
|
|
|
/**
|
|
* Checks if the given arguments are from an iteratee call.
|
|
*
|
|
* @private
|
|
* @param {*} value The potential iteratee value argument.
|
|
* @param {*} index The potential iteratee index or key argument.
|
|
* @param {*} object The potential iteratee object argument.
|
|
* @returns {boolean} Returns `true` if the arguments are from an iteratee call, else `false`.
|
|
*/
|
|
function isIterateeCall(value, index, object) {
|
|
if (!isObject(object)) {
|
|
return false;
|
|
}
|
|
var type = typeof index;
|
|
if (type == 'number'
|
|
? (isArrayLike(object) && isIndex(index, object.length))
|
|
: (type == 'string' && index in object)) {
|
|
return eq(object[index], value);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
module.e = isIterateeCall;
|
|
|
|
|
|
/***/ },
|
|
/* 125 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/**
|
|
* Converts `iterator` to an array.
|
|
*
|
|
* @private
|
|
* @param {Object} iterator The iterator to convert.
|
|
* @returns {Array} Returns the converted array.
|
|
*/
|
|
function iteratorToArray(iterator) {
|
|
var data,
|
|
result = [];
|
|
|
|
while (!(data = iterator.next()).done) {
|
|
result.push(data.value);
|
|
}
|
|
return result;
|
|
}
|
|
|
|
module.e = iteratorToArray;
|
|
|
|
|
|
/***/ },
|
|
/* 126 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var Hash = __webpack_require__(79),
|
|
Map = __webpack_require__(3);
|
|
|
|
/**
|
|
* 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.e = mapClear;
|
|
|
|
|
|
/***/ },
|
|
/* 127 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var Map = __webpack_require__(3),
|
|
assocDelete = __webpack_require__(36),
|
|
hashDelete = __webpack_require__(118),
|
|
isKeyable = __webpack_require__(13);
|
|
|
|
/**
|
|
* 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);
|
|
|
|
/**
|
|
* Gets the map value for `key`.
|
|
*
|
|
* @private
|
|
* @name get
|
|
* @memberOf MapCache
|
|
* @param {string} key The key of the value to get.
|
|
* @returns {*} Returns the entry value.
|
|
*/
|
|
function 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.e = mapGet;
|
|
|
|
|
|
/***/ },
|
|
/* 129 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var Map = __webpack_require__(3),
|
|
assocHas = __webpack_require__(38),
|
|
hashHas = __webpack_require__(42),
|
|
isKeyable = __webpack_require__(13);
|
|
|
|
/**
|
|
* Checks if a map value for `key` exists.
|
|
*
|
|
* @private
|
|
* @name has
|
|
* @memberOf MapCache
|
|
* @param {string} key The key of the entry to check.
|
|
* @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
|
|
*/
|
|
function 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.e = mapHas;
|
|
|
|
|
|
/***/ },
|
|
/* 130 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var Map = __webpack_require__(3),
|
|
assocSet = __webpack_require__(39),
|
|
hashSet = __webpack_require__(120),
|
|
isKeyable = __webpack_require__(13);
|
|
|
|
/**
|
|
* Sets the map `key` to `value`.
|
|
*
|
|
* @private
|
|
* @name set
|
|
* @memberOf MapCache
|
|
* @param {string} key The key of the value to set.
|
|
* @param {*} value The value to set.
|
|
* @returns {Object} Returns the map cache 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.e = mapSet;
|
|
|
|
|
|
/***/ },
|
|
/* 131 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/**
|
|
* Converts `map` to an array.
|
|
*
|
|
* @private
|
|
* @param {Object} map The map to convert.
|
|
* @returns {Array} Returns the converted array.
|
|
*/
|
|
function mapToArray(map) {
|
|
var index = -1,
|
|
result = Array(map.size);
|
|
|
|
map.forEach(function(value, key) {
|
|
result[++index] = [key, value];
|
|
});
|
|
return result;
|
|
}
|
|
|
|
module.e = mapToArray;
|
|
|
|
|
|
/***/ },
|
|
/* 132 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/**
|
|
* Converts `set` to an array.
|
|
*
|
|
* @private
|
|
* @param {Object} set The set to convert.
|
|
* @returns {Array} Returns the converted array.
|
|
*/
|
|
function setToArray(set) {
|
|
var index = -1,
|
|
result = Array(set.size);
|
|
|
|
set.forEach(function(value) {
|
|
result[++index] = value;
|
|
});
|
|
return result;
|
|
}
|
|
|
|
module.e = setToArray;
|
|
|
|
|
|
/***/ },
|
|
/* 133 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/**
|
|
* Removes all key-value entries from the stack.
|
|
*
|
|
* @private
|
|
* @name clear
|
|
* @memberOf Stack
|
|
*/
|
|
function stackClear() {
|
|
this.__data__ = { 'array': [], 'map': null };
|
|
}
|
|
|
|
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.e = stackDelete;
|
|
|
|
|
|
/***/ },
|
|
/* 135 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var assocGet = __webpack_require__(37);
|
|
|
|
/**
|
|
* Gets the stack value for `key`.
|
|
*
|
|
* @private
|
|
* @name get
|
|
* @memberOf Stack
|
|
* @param {string} key The key of the value to get.
|
|
* @returns {*} Returns the entry value.
|
|
*/
|
|
function stackGet(key) {
|
|
var data = this.__data__,
|
|
array = data.array;
|
|
|
|
return array ? assocGet(array, key) : data.map.get(key);
|
|
}
|
|
|
|
module.e = stackGet;
|
|
|
|
|
|
/***/ },
|
|
/* 136 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var assocHas = __webpack_require__(38);
|
|
|
|
/**
|
|
* 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;
|
|
|
|
return array ? assocHas(array, key) : data.map.has(key);
|
|
}
|
|
|
|
module.e = stackHas;
|
|
|
|
|
|
/***/ },
|
|
/* 137 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var MapCache = __webpack_require__(80),
|
|
assocSet = __webpack_require__(39);
|
|
|
|
/** Used as the size to enable large array optimizations. */
|
|
var LARGE_ARRAY_SIZE = 200;
|
|
|
|
/**
|
|
* Sets the stack `key` to `value`.
|
|
*
|
|
* @private
|
|
* @name set
|
|
* @memberOf Stack
|
|
* @param {string} key The key of the value to set.
|
|
* @param {*} value The value to set.
|
|
* @returns {Object} Returns the stack cache 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__) {
|
|
|
|
/**
|
|
* Creates a function that returns `value`.
|
|
*
|
|
* @static
|
|
* @memberOf _
|
|
* @category Util
|
|
* @param {*} value The value to return from the new function.
|
|
* @returns {Function} Returns the new function.
|
|
* @example
|
|
*
|
|
* var object = { 'user': 'fred' };
|
|
* var getter = _.constant(object);
|
|
*
|
|
* getter() === object;
|
|
* // => true
|
|
*/
|
|
function constant(value) {
|
|
return function() {
|
|
return value;
|
|
};
|
|
}
|
|
|
|
module.e = constant;
|
|
|
|
|
|
/***/ },
|
|
/* 139 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
/* 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;
|
|
|
|
/**
|
|
* Checks if `value` is a buffer.
|
|
*
|
|
* @static
|
|
* @memberOf _
|
|
* @category Lang
|
|
* @param {*} value The value to check.
|
|
* @returns {boolean} Returns `true` if `value` is a buffer, else `false`.
|
|
* @example
|
|
*
|
|
* _.isBuffer(new Buffer(2));
|
|
* // => true
|
|
*
|
|
* _.isBuffer(new Uint8Array(2));
|
|
* // => false
|
|
*/
|
|
var isBuffer = !Buffer ? constant(false) : function(value) {
|
|
return value instanceof Buffer;
|
|
};
|
|
|
|
module.e = isBuffer;
|
|
|
|
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(48)(module)))
|
|
|
|
/***/ },
|
|
/* 140 */
|
|
/***/ 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.*?') + '$'
|
|
);
|
|
|
|
/**
|
|
* 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(funcToString.call(value));
|
|
}
|
|
return isObjectLike(value) &&
|
|
(isHostObject(value) ? reIsNative : reIsHostCtor).test(value);
|
|
}
|
|
|
|
module.e = isNative;
|
|
|
|
|
|
/***/ },
|
|
/* 141 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var isHostObject = __webpack_require__(21),
|
|
isObjectLike = __webpack_require__(7);
|
|
|
|
/** `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);
|
|
|
|
/**
|
|
* 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 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;
|
|
}
|
|
var Ctor = proto.constructor;
|
|
return (typeof Ctor == 'function' &&
|
|
Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString);
|
|
}
|
|
|
|
module.e = isPlainObject;
|
|
|
|
|
|
/***/ },
|
|
/* 142 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
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;
|
|
|
|
/**
|
|
* Checks if `value` is classified as a `String` primitive or object.
|
|
*
|
|
* @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 isString(value) {
|
|
return typeof value == 'string' ||
|
|
(!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag);
|
|
}
|
|
|
|
module.e = isString;
|
|
|
|
|
|
/***/ },
|
|
/* 143 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var baseFlatten = __webpack_require__(93),
|
|
basePick = __webpack_require__(101),
|
|
rest = __webpack_require__(47);
|
|
|
|
/**
|
|
* Creates an object composed of the picked `object` properties.
|
|
*
|
|
* @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 }
|
|
*/
|
|
var pick = rest(function(object, props) {
|
|
return object == null ? {} : basePick(object, baseFlatten(props, 1));
|
|
});
|
|
|
|
module.e = pick;
|
|
|
|
|
|
/***/ },
|
|
/* 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;
|
|
|
|
/**
|
|
* 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 Lang
|
|
* @param {*} value The value to convert.
|
|
* @returns {number} Returns the converted integer.
|
|
* @example
|
|
*
|
|
* _.toInteger(3);
|
|
* // => 3
|
|
*
|
|
* _.toInteger(Number.MIN_VALUE);
|
|
* // => 0
|
|
*
|
|
* _.toInteger(Infinity);
|
|
* // => 1.7976931348623157e+308
|
|
*
|
|
* _.toInteger('3');
|
|
* // => 3
|
|
*/
|
|
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.e = toInteger;
|
|
|
|
|
|
/***/ },
|
|
/* 145 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
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;
|
|
|
|
/**
|
|
* Converts `value` to a number.
|
|
*
|
|
* @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 toNumber(value) {
|
|
if (isObject(value)) {
|
|
var other = isFunction(value.valueOf) ? value.valueOf() : value;
|
|
value = isObject(other) ? (other + '') : other;
|
|
}
|
|
if (typeof value != 'string') {
|
|
return value === 0 ? value : +value;
|
|
}
|
|
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.e = toNumber;
|
|
|
|
|
|
/***/ },
|
|
/* 146 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
var copyObject = __webpack_require__(20),
|
|
keysIn = __webpack_require__(46);
|
|
|
|
/**
|
|
* Converts `value` to a plain object flattening inherited enumerable
|
|
* properties of `value` to own properties of the plain object.
|
|
*
|
|
* @static
|
|
* @memberOf _
|
|
* @category Lang
|
|
* @param {*} value The value to convert.
|
|
* @returns {Object} Returns the converted plain object.
|
|
* @example
|
|
*
|
|
* function Foo() {
|
|
* this.b = 2;
|
|
* }
|
|
*
|
|
* Foo.prototype.c = 3;
|
|
*
|
|
* _.assign({ 'a': 1 }, new Foo);
|
|
* // => { 'a': 1, 'b': 2 }
|
|
*
|
|
* _.assign({ 'a': 1 }, _.toPlainObject(new Foo));
|
|
* // => { 'a': 1, 'b': 2, 'c': 3 }
|
|
*/
|
|
function toPlainObject(value) {
|
|
return copyObject(value, keysIn(value));
|
|
}
|
|
|
|
module.e = toPlainObject;
|
|
|
|
|
|
/***/ },
|
|
/* 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';
|
|
|
|
// 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;
|
|
|
|
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!');
|
|
}
|
|
})();
|
|
|
|
|
|
/***/ },
|
|
/* 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);
|
|
}
|
|
|
|
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);
|
|
});
|
|
}
|
|
});
|
|
}
|
|
}
|
|
},
|
|
|
|
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;
|
|
}
|
|
|
|
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]]);
|
|
}
|
|
|
|
// 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);
|
|
}
|
|
};
|
|
});
|
|
|
|
['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.');
|
|
}
|
|
},
|
|
|
|
reattachMediaStream: function(to, from) {
|
|
logging('DEPRECATED, reattachMediaStream will soon be removed.');
|
|
if (browserDetails.version >= 43) {
|
|
to.srcObject = from.srcObject;
|
|
} else {
|
|
to.src = from.src;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// Expose public methods.
|
|
module.e = {
|
|
shimOnTrack: chromeShim.shimOnTrack,
|
|
shimSourceObject: chromeShim.shimSourceObject,
|
|
shimPeerConnection: chromeShim.shimPeerConnection,
|
|
shimGetUserMedia: __webpack_require__(149),
|
|
attachMediaStream: chromeShim.attachMediaStream,
|
|
reattachMediaStream: chromeShim.reattachMediaStream
|
|
};
|
|
|
|
|
|
/***/ },
|
|
/* 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;
|
|
|
|
// 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 cc;
|
|
};
|
|
|
|
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_;
|
|
|
|
// Returns the result of getUserMedia as a Promise.
|
|
var getUserMediaPromise_ = function(constraints) {
|
|
return new Promise(function(resolve, reject) {
|
|
navigator.getUserMedia(constraints, resolve, reject);
|
|
});
|
|
}
|
|
|
|
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: ''};
|
|
}));
|
|
});
|
|
});
|
|
}};
|
|
}
|
|
|
|
// 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);
|
|
}
|
|
|
|
// 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.');
|
|
};
|
|
}
|
|
};
|
|
|
|
|
|
/***/ },
|
|
/* 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';
|
|
|
|
// SDP helpers.
|
|
var SDPUtils = {};
|
|
|
|
// 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);
|
|
};
|
|
|
|
// The RTCP CNAME used by all peerconnections from the same JS.
|
|
SDPUtils.localCName = SDPUtils.generateIdentifier();
|
|
|
|
|
|
// 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(' ');
|
|
};
|
|
|
|
// 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;
|
|
};
|
|
|
|
// 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:<pt> 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;
|
|
};
|
|
|
|
// Generates parts of the SDP media section describing the capabilities / parameters.
|
|
SDPUtils.writeRtpDescription = function(kind, caps) {
|
|
var sdp = '';
|
|
|
|
// 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';
|
|
|
|
sdp += 'c=IN IP4 0.0.0.0\r\n';
|
|
sdp += 'a=rtcp:9 IN IP4 0.0.0.0\r\n';
|
|
|
|
// 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;
|
|
|
|
|
|
/***/ },
|
|
/* 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';
|
|
|
|
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;
|
|
};
|
|
}
|
|
}
|
|
|
|
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;
|
|
});
|
|
}
|
|
|
|
// per-track iceGathers, iceTransports, dtlsTransports, rtpSenders, ...
|
|
// everything that is needed to describe a SDP m-line.
|
|
this.transceivers = [];
|
|
|
|
// 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 = [];
|
|
};
|
|
|
|
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('');
|
|
};
|
|
|
|
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();
|
|
};
|
|
|
|
window.RTCPeerConnection.prototype.removeStream = function(stream) {
|
|
var idx = this.localStreams.indexOf(stream);
|
|
if (idx > -1) {
|
|
this.localStreams.splice(idx, 1);
|
|
this._maybeFireNegotiationNeeded();
|
|
}
|
|
};
|
|
|
|
// 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;
|
|
}
|
|
}
|
|
});
|
|
|
|
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;
|
|
}
|
|
}
|
|
});
|
|
|
|
// FIXME: fecMechanisms
|
|
return commonCapabilities;
|
|
};
|
|
|
|
// 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
|
|
};
|
|
};
|
|
|
|
// 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);
|
|
}
|
|
};
|
|
|
|
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);
|
|
}
|
|
});
|
|
}
|
|
|
|
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 + '"');
|
|
}
|
|
|
|
// 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;
|
|
};
|
|
|
|
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();
|
|
};
|
|
|
|
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');
|
|
};
|
|
|
|
// 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);
|
|
}
|
|
};
|
|
|
|
// 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);
|
|
}
|
|
};
|
|
|
|
// 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';
|
|
}
|
|
|
|
if (newState !== self.iceConnectionState) {
|
|
self.iceConnectionState = newState;
|
|
var event = new Event('iceconnectionstatechange');
|
|
this.dispatchEvent(event);
|
|
if (this.oniceconnectionstatechange !== null) {
|
|
this.oniceconnectionstatechange(event);
|
|
}
|
|
}
|
|
};
|
|
|
|
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--;
|
|
}
|
|
}
|
|
|
|
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);
|
|
};
|
|
|
|
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);
|
|
};
|
|
|
|
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();
|
|
};
|
|
|
|
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);
|
|
});
|
|
});
|
|
};
|
|
},
|
|
|
|
// 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
|
|
}
|
|
|
|
|
|
|
|
/***/ },
|
|
/* 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';
|
|
|
|
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;
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
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;
|
|
}
|
|
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);
|
|
};
|
|
|
|
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;
|
|
});
|
|
};
|
|
}
|
|
},
|
|
|
|
// 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 = {
|
|
shimOnTrack: firefoxShim.shimOnTrack,
|
|
shimSourceObject: firefoxShim.shimSourceObject,
|
|
shimPeerConnection: firefoxShim.shimPeerConnection,
|
|
shimGetUserMedia: __webpack_require__(153),
|
|
attachMediaStream: firefoxShim.attachMediaStream,
|
|
reattachMediaStream: firefoxShim.reattachMediaStream
|
|
}
|
|
|
|
|
|
/***/ },
|
|
/* 153 */
|
|
/***/ 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;
|
|
|
|
// 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);
|
|
};
|
|
|
|
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;
|
|
});
|
|
};
|
|
}
|
|
}
|
|
|
|
|
|
/***/ },
|
|
/* 154 */
|
|
/***/ function(module, exports, __webpack_require__) {
|
|
|
|
module.e = __webpack_require__(49);
|
|
|
|
|
|
/***/ }
|
|
/******/ ])
|
|
});
|
|
;
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/myModuleDefinition","webpack:///webpack/bootstrap 7bff77b9904c4daa2956","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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AI,YAAJ,CAAiB,KAAjB,EAAwB,KAAK,CAAL,EAAQ,KAAK,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;;A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;cAnBP;AAsBA,qBAAQ,UAAR,IAAsB,CAAtB,CAvBG;AAwBH,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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AACrF,gBAAO,IAAP,GAAc,OAAO,IAAP,CAAY,SAAZ,CAAsB,CAAtB,CAAd,CADqF;AAErF,gBAAO,MAAP,CAFqF;MAAzF;AAIA,YAAO,IAAP,CAPqC;EAAX;;AAU9B,6CAAe,SAAf,C;;;;;;ACvBA;;AAEA;AACA;AACA;AACA;AACA,YAAW,KAAK;AAChB,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 7bff77b9904c4daa2956\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';\nimport ArrayHelper from './array_helper';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n};\nconst vec3 = {\n    clone: require('gl-vec3/clone'),\n};\n\n/**\n * @param x x-coordinate\n * @param y y-coordinate\n * @return ImageReference {x,y} Coordinate\n */\nexport function imageRef(x, y) {\n    var that = {\n        x: x,\n        y: y,\n        toVec2: function() {\n            return vec2.clone([this.x, this.y]);\n        },\n        toVec3: function() {\n            return vec3.clone([this.x, this.y, 1]);\n        },\n        round: function() {\n            this.x = this.x > 0.0 ? Math.floor(this.x + 0.5) : Math.floor(this.x - 0.5);\n            this.y = this.y > 0.0 ? Math.floor(this.y + 0.5) : Math.floor(this.y - 0.5);\n            return this;\n        }\n    };\n    return that;\n};\n\n/**\n * Computes an integral image of a given grayscale image.\n * @param imageDataContainer {ImageDataContainer} the image to be integrated\n */\nexport function computeIntegralImage2(imageWrapper, integralWrapper) {\n    var imageData = imageWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0, posA = 0, posB = 0, posC = 0, posD = 0, x, y;\n\n    // sum up first column\n    posB = width;\n    sum = 0;\n    for ( y = 1; y < height; y++) {\n        sum += imageData[posA];\n        integralImageData[posB] += sum;\n        posA += width;\n        posB += width;\n    }\n\n    posA = 0;\n    posB = 1;\n    sum = 0;\n    for ( x = 1; x < width; x++) {\n        sum += imageData[posA];\n        integralImageData[posB] += sum;\n        posA++;\n        posB++;\n    }\n\n    for ( y = 1; y < height; y++) {\n        posA = y * width + 1;\n        posB = (y - 1) * width + 1;\n        posC = y * width;\n        posD = (y - 1) * width;\n        for ( x = 1; x < width; x++) {\n            integralImageData[posA] +=\n                imageData[posA] + integralImageData[posB] + integralImageData[posC] - integralImageData[posD];\n            posA++;\n            posB++;\n            posC++;\n            posD++;\n        }\n    }\n};\n\nexport function computeIntegralImage(imageWrapper, integralWrapper) {\n    var imageData = imageWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0;\n\n    // sum up first row\n    for (var i = 0; i < width; i++) {\n        sum += imageData[i];\n        integralImageData[i] = sum;\n    }\n\n    for (var v = 1; v < height; v++) {\n        sum = 0;\n        for (var u = 0; u < width; u++) {\n            sum += imageData[v * width + u];\n            integralImageData[((v) * width) + u] = sum + integralImageData[(v - 1) * width + u];\n        }\n    }\n};\n\nexport function thresholdImage(imageWrapper, threshold, targetWrapper) {\n    if (!targetWrapper) {\n        targetWrapper = imageWrapper;\n    }\n    var imageData = imageWrapper.data, length = imageData.length, targetData = targetWrapper.data;\n\n    while (length--) {\n        targetData[length] = imageData[length] < threshold ? 1 : 0;\n    }\n};\n\nexport function computeHistogram(imageWrapper, bitsPerPixel) {\n    if (!bitsPerPixel) {\n        bitsPerPixel = 8;\n    }\n    var imageData = imageWrapper.data,\n        length = imageData.length,\n        bitShift = 8 - bitsPerPixel,\n        bucketCnt = 1 << bitsPerPixel,\n        hist = new Int32Array(bucketCnt);\n\n    while (length--) {\n        hist[imageData[length] >> bitShift]++;\n    }\n    return hist;\n};\n\nexport function sharpenLine(line) {\n    var i,\n        length = line.length,\n        left = line[0],\n        center = line[1],\n        right;\n\n    for (i = 1; i < length - 1; i++) {\n        right = line[i + 1];\n        //  -1 4 -1 kernel\n        line[i - 1] = (((center * 2) - left - right)) & 255;\n        left = center;\n        center = right;\n    }\n    return line;\n};\n\nexport function determineOtsuThreshold(imageWrapper, bitsPerPixel) {\n    if (!bitsPerPixel) {\n        bitsPerPixel = 8;\n    }\n    var hist,\n        threshold,\n        bitShift = 8 - bitsPerPixel;\n\n    function px(init, end) {\n        var sum = 0, i;\n        for ( i = init; i <= end; i++) {\n            sum += hist[i];\n        }\n        return sum;\n    }\n\n    function mx(init, end) {\n        var i, sum = 0;\n\n        for ( i = init; i <= end; i++) {\n            sum += i * hist[i];\n        }\n\n        return sum;\n    }\n\n    function determineThreshold() {\n        var vet = [0], p1, p2, p12, k, m1, m2, m12,\n            max = (1 << bitsPerPixel) - 1;\n\n        hist = computeHistogram(imageWrapper, bitsPerPixel);\n        for ( k = 1; k < max; k++) {\n            p1 = px(0, k);\n            p2 = px(k + 1, max);\n            p12 = p1 * p2;\n            if (p12 === 0) {\n                p12 = 1;\n            }\n            m1 = mx(0, k) * p2;\n            m2 = mx(k + 1, max) * p1;\n            m12 = m1 - m2;\n            vet[k] = m12 * m12 / p12;\n        }\n        return ArrayHelper.maxIndex(vet);\n    }\n\n    threshold = determineThreshold();\n    return threshold << bitShift;\n};\n\nexport function otsuThreshold(imageWrapper, targetWrapper) {\n    var threshold = determineOtsuThreshold(imageWrapper);\n\n    thresholdImage(imageWrapper, threshold, targetWrapper);\n    return threshold;\n};\n\n// local thresholding\nexport function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) {\n    computeIntegralImage(imageWrapper, integralWrapper);\n\n    if (!targetWrapper) {\n        targetWrapper = imageWrapper;\n    }\n    var imageData = imageWrapper.data;\n    var targetData = targetWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0, v, u, kernel = 3, A, B, C, D, avg, size = (kernel * 2 + 1) * (kernel * 2 + 1);\n\n    // clear out top & bottom-border\n    for ( v = 0; v <= kernel; v++) {\n        for ( u = 0; u < width; u++) {\n            targetData[((v) * width) + u] = 0;\n            targetData[(((height - 1) - v) * width) + u] = 0;\n        }\n    }\n\n    // clear out left & right border\n    for ( v = kernel; v < height - kernel; v++) {\n        for ( u = 0; u <= kernel; u++) {\n            targetData[((v) * width) + u] = 0;\n            targetData[((v) * width) + (width - 1 - u)] = 0;\n        }\n    }\n\n    for ( v = kernel + 1; v < height - kernel - 1; v++) {\n        for ( u = kernel + 1; u < width - kernel; u++) {\n            A = integralImageData[(v - kernel - 1) * width + (u - kernel - 1)];\n            B = integralImageData[(v - kernel - 1) * width + (u + kernel)];\n            C = integralImageData[(v + kernel) * width + (u - kernel - 1)];\n            D = integralImageData[(v + kernel) * width + (u + kernel)];\n            sum = D - C - B + A;\n            avg = sum / (size);\n            targetData[v * width + u] = imageData[v * width + u] > (avg + 5) ? 0 : 1;\n        }\n    }\n};\n\nexport function cluster(points, threshold, property) {\n    var i, k, cluster, point, clusters = [];\n\n    if (!property) {\n        property = \"rad\";\n    }\n\n    function addToCluster(newPoint) {\n        var found = false;\n        for ( k = 0; k < clusters.length; k++) {\n            cluster = clusters[k];\n            if (cluster.fits(newPoint)) {\n                cluster.add(newPoint);\n                found = true;\n            }\n        }\n        return found;\n    }\n\n    // iterate over each cloud\n    for ( i = 0; i < points.length; i++) {\n        point = Cluster2.createPoint(points[i], i, property);\n        if (!addToCluster(point)) {\n            clusters.push(Cluster2.create(point, threshold));\n        }\n    }\n    return clusters;\n};\n\nexport const Tracer = {\n    trace: function(points, vec) {\n        var iteration, maxIterations = 10, top = [], result = [], centerPos = 0, currentPos = 0;\n\n        function trace(idx, forward) {\n            var from, to, toIdx, predictedPos, thresholdX = 1, thresholdY = Math.abs(vec[1] / 10), found = false;\n\n            function match(pos, predicted) {\n                if (pos.x > (predicted.x - thresholdX)\n                        && pos.x < (predicted.x + thresholdX)\n                        && pos.y > (predicted.y - thresholdY)\n                        && pos.y < (predicted.y + thresholdY)) {\n                    return true;\n                } else {\n                    return false;\n                }\n            }\n\n            // check if the next index is within the vec specifications\n            // if not, check as long as the threshold is met\n\n            from = points[idx];\n            if (forward) {\n                predictedPos = {\n                    x: from.x + vec[0],\n                    y: from.y + vec[1]\n                };\n            } else {\n                predictedPos = {\n                    x: from.x - vec[0],\n                    y: from.y - vec[1]\n                };\n            }\n\n            toIdx = forward ? idx + 1 : idx - 1;\n            to = points[toIdx];\n            while (to && ( found = match(to, predictedPos)) !== true && (Math.abs(to.y - from.y) < vec[1])) {\n                toIdx = forward ? toIdx + 1 : toIdx - 1;\n                to = points[toIdx];\n            }\n\n            return found ? toIdx : null;\n        }\n\n        for ( iteration = 0; iteration < maxIterations; iteration++) {\n            // randomly select point to start with\n            centerPos = Math.floor(Math.random() * points.length);\n\n            // trace forward\n            top = [];\n            currentPos = centerPos;\n            top.push(points[currentPos]);\n            while (( currentPos = trace(currentPos, true)) !== null) {\n                top.push(points[currentPos]);\n            }\n            if (centerPos > 0) {\n                currentPos = centerPos;\n                while (( currentPos = trace(currentPos, false)) !== null) {\n                    top.push(points[currentPos]);\n                }\n            }\n\n            if (top.length > result.length) {\n                result = top;\n            }\n        }\n        return result;\n    }\n};\n\nexport const DILATE = 1;\nexport const ERODE = 2;\n\nexport function dilate(inImageWrapper, outImageWrapper) {\n    var v,\n        u,\n        inImageData = inImageWrapper.data,\n        outImageData = outImageWrapper.data,\n        height = inImageWrapper.size.y,\n        width = inImageWrapper.size.x,\n        sum,\n        yStart1,\n        yStart2,\n        xStart1,\n        xStart2;\n\n    for ( v = 1; v < height - 1; v++) {\n        for ( u = 1; u < width - 1; u++) {\n            yStart1 = v - 1;\n            yStart2 = v + 1;\n            xStart1 = u - 1;\n            xStart2 = u + 1;\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] +\n            inImageData[v * width + u] +\n            inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\n            outImageData[v * width + u] = sum > 0 ? 1 : 0;\n        }\n    }\n};\n\nexport function erode(inImageWrapper, outImageWrapper) {\n    var v,\n        u,\n        inImageData = inImageWrapper.data,\n        outImageData = outImageWrapper.data,\n        height = inImageWrapper.size.y,\n        width = inImageWrapper.size.x,\n        sum,\n        yStart1,\n        yStart2,\n        xStart1,\n        xStart2;\n\n    for ( v = 1; v < height - 1; v++) {\n        for ( u = 1; u < width - 1; u++) {\n            yStart1 = v - 1;\n            yStart2 = v + 1;\n            xStart1 = u - 1;\n            xStart2 = u + 1;\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] +\n            inImageData[v * width + u] +\n            inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\n            outImageData[v * width + u] = sum === 5 ? 1 : 0;\n        }\n    }\n};\n\nexport function subtract(aImageWrapper, bImageWrapper, resultImageWrapper) {\n    if (!resultImageWrapper) {\n        resultImageWrapper = aImageWrapper;\n    }\n    var length = aImageWrapper.data.length,\n        aImageData = aImageWrapper.data,\n        bImageData = bImageWrapper.data,\n        cImageData = resultImageWrapper.data;\n\n    while (length--) {\n        cImageData[length] = aImageData[length] - bImageData[length];\n    }\n};\n\nexport function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) {\n    if (!resultImageWrapper) {\n        resultImageWrapper = aImageWrapper;\n    }\n    var length = aImageWrapper.data.length,\n        aImageData = aImageWrapper.data,\n        bImageData = bImageWrapper.data,\n        cImageData = resultImageWrapper.data;\n\n    while (length--) {\n        cImageData[length] = aImageData[length] || bImageData[length];\n    }\n};\n\nexport function countNonZero(imageWrapper) {\n    var length = imageWrapper.data.length, data = imageWrapper.data, sum = 0;\n\n    while (length--) {\n        sum += data[length];\n    }\n    return sum;\n};\n\nexport function topGeneric(list, top, scoreFunc) {\n    var i, minIdx = 0, min = 0, queue = [], score, hit, pos;\n\n    for ( i = 0; i < top; i++) {\n        queue[i] = {\n            score: 0,\n            item: null\n        };\n    }\n\n    for ( i = 0; i < list.length; i++) {\n        score = scoreFunc.apply(this, [list[i]]);\n        if (score > min) {\n            hit = queue[minIdx];\n            hit.score = score;\n            hit.item = list[i];\n            min = Number.MAX_VALUE;\n            for ( pos = 0; pos < top; pos++) {\n                if (queue[pos].score < min) {\n                    min = queue[pos].score;\n                    minIdx = pos;\n                }\n            }\n        }\n    }\n\n    return queue;\n};\n\nexport function grayArrayFromImage(htmlImage, offsetX, ctx, array) {\n    ctx.drawImage(htmlImage, offsetX, 0, htmlImage.width, htmlImage.height);\n    var ctxData = ctx.getImageData(offsetX, 0, htmlImage.width, htmlImage.height).data;\n    computeGray(ctxData, array);\n};\n\nexport function grayArrayFromContext(ctx, size, offset, array) {\n    var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data;\n    computeGray(ctxData, array);\n};\n\nexport function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {\n    var topRowIdx = 0;\n    var bottomRowIdx = size.x;\n    var endIdx = Math.floor(canvasData.length / 4);\n    var outWidth = size.x / 2;\n    var outImgIdx = 0;\n    var inWidth = size.x;\n    var i;\n\n    while (bottomRowIdx < endIdx) {\n        for ( i = 0; i < outWidth; i++) {\n            outArray[outImgIdx] = Math.floor((\n                (0.299 * canvasData[topRowIdx * 4 + 0] +\n                 0.587 * canvasData[topRowIdx * 4 + 1] +\n                 0.114 * canvasData[topRowIdx * 4 + 2]) +\n                (0.299 * canvasData[(topRowIdx + 1) * 4 + 0] +\n                 0.587 * canvasData[(topRowIdx + 1) * 4 + 1] +\n                 0.114 * canvasData[(topRowIdx + 1) * 4 + 2]) +\n                (0.299 * canvasData[(bottomRowIdx) * 4 + 0] +\n                 0.587 * canvasData[(bottomRowIdx) * 4 + 1] +\n                 0.114 * canvasData[(bottomRowIdx) * 4 + 2]) +\n                (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] +\n                 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] +\n                 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4);\n            outImgIdx++;\n            topRowIdx = topRowIdx + 2;\n            bottomRowIdx = bottomRowIdx + 2;\n        }\n        topRowIdx = topRowIdx + inWidth;\n        bottomRowIdx = bottomRowIdx + inWidth;\n    }\n};\n\nexport function computeGray(imageData, outArray, config) {\n    var l = (imageData.length / 4) | 0,\n        i,\n        singleChannel = config && config.singleChannel === true;\n\n    if (singleChannel) {\n        for (i = 0; i < l; i++) {\n            outArray[i] = imageData[i * 4 + 0];\n        }\n    } else {\n        for (i = 0; i < l; i++) {\n            outArray[i] = Math.floor(\n                0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2]);\n        }\n    }\n};\n\nexport function loadImageArray(src, callback, canvas) {\n    if (!canvas) {\n        canvas = document.createElement('canvas');\n    }\n    var img = new Image();\n    img.callback = callback;\n    img.onload = function() {\n        canvas.width = this.width;\n        canvas.height = this.height;\n        var ctx = canvas.getContext('2d');\n        ctx.drawImage(this, 0, 0);\n        var array = new Uint8Array(this.width * this.height);\n        ctx.drawImage(this, 0, 0);\n        var data = ctx.getImageData(0, 0, this.width, this.height).data;\n        computeGray(data, array);\n        this.callback(array, {\n            x: this.width,\n            y: this.height\n        }, this);\n    };\n    img.src = src;\n};\n\n/**\n * @param inImg {ImageWrapper} input image to be sampled\n * @param outImg {ImageWrapper} to be stored in\n */\nexport function halfSample(inImgWrapper, outImgWrapper) {\n    var inImg = inImgWrapper.data;\n    var inWidth = inImgWrapper.size.x;\n    var outImg = outImgWrapper.data;\n    var topRowIdx = 0;\n    var bottomRowIdx = inWidth;\n    var endIdx = inImg.length;\n    var outWidth = inWidth / 2;\n    var outImgIdx = 0;\n    while (bottomRowIdx < endIdx) {\n        for (var i = 0; i < outWidth; i++) {\n            outImg[outImgIdx] = Math.floor(\n                (inImg[topRowIdx] + inImg[topRowIdx + 1] + inImg[bottomRowIdx] + inImg[bottomRowIdx + 1]) / 4);\n            outImgIdx++;\n            topRowIdx = topRowIdx + 2;\n            bottomRowIdx = bottomRowIdx + 2;\n        }\n        topRowIdx = topRowIdx + inWidth;\n        bottomRowIdx = bottomRowIdx + inWidth;\n    }\n};\n\nexport function hsv2rgb(hsv, rgb) {\n    var h = hsv[0],\n        s = hsv[1],\n        v = hsv[2],\n        c = v * s,\n        x = c * (1 - Math.abs((h / 60) % 2 - 1)),\n        m = v - c,\n        r = 0,\n        g = 0,\n        b = 0;\n\n    rgb = rgb || [0, 0, 0];\n\n    if (h < 60) {\n        r = c;\n        g = x;\n    } else if (h < 120) {\n        r = x;\n        g = c;\n    } else if (h < 180) {\n        g = c;\n        b = x;\n    } else if (h < 240) {\n        g = x;\n        b = c;\n    } else if (h < 300) {\n        r = x;\n        b = c;\n    } else if (h < 360) {\n        r = c;\n        b = x;\n    }\n    rgb[0] = ((r + m) * 255) | 0;\n    rgb[1] = ((g + m) * 255) | 0;\n    rgb[2] = ((b + m) * 255) | 0;\n    return rgb;\n};\n\nexport function _computeDivisors(n) {\n    var largeDivisors = [],\n        divisors = [],\n        i;\n\n    for (i = 1; i < Math.sqrt(n) + 1; i++) {\n        if (n % i === 0) {\n            divisors.push(i);\n            if (i !== n / i) {\n                largeDivisors.unshift(Math.floor(n / i));\n            }\n        }\n    }\n    return divisors.concat(largeDivisors);\n};\n\nfunction _computeIntersection(arr1, arr2) {\n    var i = 0,\n        j = 0,\n        result = [];\n\n    while (i < arr1.length && j < arr2.length) {\n        if (arr1[i] === arr2[j]) {\n            result.push(arr1[i]);\n            i++;\n            j++;\n        } else if (arr1[i] > arr2[j]) {\n            j++;\n        } else {\n            i++;\n        }\n    }\n    return result;\n};\n\nexport function calculatePatchSize(patchSize, imgSize) {\n    var divisorsX = _computeDivisors(imgSize.x),\n        divisorsY = _computeDivisors(imgSize.y),\n        wideSide = Math.max(imgSize.x, imgSize.y),\n        common = _computeIntersection(divisorsX, divisorsY),\n        nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80],\n        nrOfPatchesMap = {\n            \"x-small\": 5,\n            \"small\": 4,\n            \"medium\": 3,\n            \"large\": 2,\n            \"x-large\": 1\n        },\n        nrOfPatchesIdx = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium,\n        nrOfPatches = nrOfPatchesList[nrOfPatchesIdx],\n        desiredPatchSize = Math.floor(wideSide / nrOfPatches),\n        optimalPatchSize;\n\n    function findPatchSizeForDivisors(divisors) {\n        var i = 0,\n            found = divisors[Math.floor(divisors.length / 2)];\n\n        while (i < (divisors.length - 1) && divisors[i] < desiredPatchSize) {\n            i++;\n        }\n        if (i > 0) {\n            if (Math.abs(divisors[i] - desiredPatchSize) > Math.abs(divisors[i - 1] - desiredPatchSize)) {\n                found = divisors[i - 1];\n            } else {\n                found = divisors[i];\n            }\n        }\n        if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIdx + 1] / nrOfPatchesList[nrOfPatchesIdx] &&\n            desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIdx - 1] / nrOfPatchesList[nrOfPatchesIdx] ) {\n            return {x: found, y: found};\n        }\n        return null;\n    }\n\n    optimalPatchSize = findPatchSizeForDivisors(common);\n    if (!optimalPatchSize) {\n        optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide));\n        if (!optimalPatchSize) {\n            optimalPatchSize = findPatchSizeForDivisors((_computeDivisors(desiredPatchSize * nrOfPatches)));\n        }\n    }\n    return optimalPatchSize;\n};\n\nexport function _parseCSSDimensionValues(value) {\n    var dimension = {\n        value: parseFloat(value),\n        unit: value.indexOf(\"%\") === value.length - 1 ? \"%\" : \"px\"\n    };\n\n    return dimension;\n};\n\nexport const _dimensionsConverters = {\n    top: function (dimension, context) {\n        return Math.floor((dimension.unit === \"%\") \n            ? (context.height * (dimension.value / 100))\n            : dimension.value);\n    },\n    right: function (dimension, context) {\n        return Math.floor((dimension.unit === \"%\")\n            ? (context.width - context.width * (dimension.value / 100))\n            : (context.width - dimension.value));\n    },\n    bottom: function (dimension, context) {\n        return Math.floor((dimension.unit === \"%\") \n            ? (context.height - context.height * (dimension.value / 100))\n            : (context.height - dimension.value));\n    },\n    left: function (dimension, context) {\n        return Math.floor((dimension.unit === \"%\") \n            ? (context.width * (dimension.value / 100))\n            : dimension.value);\n    }\n};\n\nexport function computeImageArea(inputWidth, inputHeight, area) {\n    var context = {width: inputWidth, height: inputHeight};\n\n    var parsedArea = Object.keys(area).reduce(function(result, key) {\n        var value = area[key],\n            parsed = _parseCSSDimensionValues(value),\n            calculated = _dimensionsConverters[key](parsed, context);\n\n        result[key] = calculated;\n        return result;\n    }, {});\n\n    return {\n        sx: parsedArea.left,\n        sy: parsedArea.top,\n        sw: parsedArea.right - parsedArea.left,\n        sh: parsedArea.bottom - parsedArea.top\n    };\n};\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/common/cv_utils.js\n **/","import SubImage from './subImage';\nimport {hsv2rgb} from '../common/cv_utils';\nimport ArrayHelper from '../common/array_helper';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n};\n\n/**\n * Represents a basic image combining the data and size.\n * In addition, some methods for manipulation are contained.\n * @param size {x,y} The size of the image in pixel\n * @param data {Array} If given, a flat array containing the pixel data\n * @param ArrayType {Type} If given, the desired DataType of the Array (may be typed/non-typed)\n * @param initialize {Boolean} Indicating if the array should be initialized on creation.\n * @returns {ImageWrapper}\n */\nfunction ImageWrapper(size, data, ArrayType, initialize) {\n    if (!data) {\n        if (ArrayType) {\n            this.data = new ArrayType(size.x * size.y);\n            if (ArrayType === Array && initialize) {\n                ArrayHelper.init(this.data, 0);\n            }\n        } else {\n            this.data = new Uint8Array(size.x * size.y);\n            if (Uint8Array === Array && initialize) {\n                ArrayHelper.init(this.data, 0);\n            }\n        }\n    } else {\n        this.data = data;\n    }\n    this.size = size;\n}\n\n/**\n * tests if a position is within the image with a given offset\n * @param imgRef {x, y} The location to test\n * @param border Number the padding value in pixel\n * @returns {Boolean} true if location inside the image's border, false otherwise\n * @see cvd/image.h\n */\nImageWrapper.prototype.inImageWithBorder = function(imgRef, border) {\n    return (imgRef.x >= border)\n        && (imgRef.y >= border)\n        && (imgRef.x < (this.size.x - border))\n        && (imgRef.y < (this.size.y - border));\n};\n\n/**\n * Performs bilinear sampling\n * @param inImg Image to extract sample from\n * @param x the x-coordinate\n * @param y the y-coordinate\n * @returns the sampled value\n * @see cvd/vision.h\n */\nImageWrapper.sample = function(inImg, x, y) {\n    var lx = Math.floor(x);\n    var ly = Math.floor(y);\n    var w = inImg.size.x;\n    var base = ly * inImg.size.x + lx;\n    var a = inImg.data[base + 0];\n    var b = inImg.data[base + 1];\n    var c = inImg.data[base + w];\n    var d = inImg.data[base + w + 1];\n    var e = a - b;\n    x -= lx;\n    y -= ly;\n\n    var result = Math.floor(x * (y * (e - c + d) - e) + y * (c - a) + a);\n    return result;\n};\n\n/**\n * Initializes a given array. Sets each element to zero.\n * @param array {Array} The array to initialize\n */\nImageWrapper.clearArray = function(array) {\n    var l = array.length;\n    while (l--) {\n        array[l] = 0;\n    }\n};\n\n/**\n * Creates a {SubImage} from the current image ({this}).\n * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner)\n * @param size {ImageRef} The size of the resulting image\n * @returns {SubImage} A shared part of the original image\n */\nImageWrapper.prototype.subImage = function(from, size) {\n    return new SubImage(from, size, this);\n};\n\n/**\n * Creates an {ImageWrapper) and copies the needed underlying image-data area\n * @param imageWrapper {ImageWrapper} The target {ImageWrapper} where the data should be copied\n * @param from {ImageRef} The location where to copy from (top-left location)\n */\nImageWrapper.prototype.subImageAsCopy = function(imageWrapper, from) {\n    var sizeY = imageWrapper.size.y, sizeX = imageWrapper.size.x;\n    var x, y;\n    for ( x = 0; x < sizeX; x++) {\n        for ( y = 0; y < sizeY; y++) {\n            imageWrapper.data[y * sizeX + x] = this.data[(from.y + y) * this.size.x + from.x + x];\n        }\n    }\n};\n\nImageWrapper.prototype.copyTo = function(imageWrapper) {\n    var length = this.data.length, srcData = this.data, dstData = imageWrapper.data;\n\n    while (length--) {\n        dstData[length] = srcData[length];\n    }\n};\n\n/**\n * Retrieves a given pixel position from the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @returns {Number} The grayscale value at the pixel-position\n */\nImageWrapper.prototype.get = function(x, y) {\n    return this.data[y * this.size.x + x];\n};\n\n/**\n * Retrieves a given pixel position from the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @returns {Number} The grayscale value at the pixel-position\n */\nImageWrapper.prototype.getSafe = function(x, y) {\n    var i;\n\n    if (!this.indexMapping) {\n        this.indexMapping = {\n            x: [],\n            y: []\n        };\n        for (i = 0; i < this.size.x; i++) {\n            this.indexMapping.x[i] = i;\n            this.indexMapping.x[i + this.size.x] = i;\n        }\n        for (i = 0; i < this.size.y; i++) {\n            this.indexMapping.y[i] = i;\n            this.indexMapping.y[i + this.size.y] = i;\n        }\n    }\n    return this.data[(this.indexMapping.y[y + this.size.y]) * this.size.x + this.indexMapping.x[x + this.size.x]];\n};\n\n/**\n * Sets a given pixel position in the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @param value {Number} The grayscale value to set\n * @returns {ImageWrapper} The Image itself (for possible chaining)\n */\nImageWrapper.prototype.set = function(x, y, value) {\n    this.data[y * this.size.x + x] = value;\n    return this;\n};\n\n/**\n * Sets the border of the image (1 pixel) to zero\n */\nImageWrapper.prototype.zeroBorder = function() {\n    var i, width = this.size.x, height = this.size.y, data = this.data;\n    for ( i = 0; i < width; i++) {\n        data[i] = data[(height - 1) * width + i] = 0;\n    }\n    for ( i = 1; i < height - 1; i++) {\n        data[i * width] = data[i * width + (width - 1)] = 0;\n    }\n};\n\n/**\n * Inverts a binary image in place\n */\nImageWrapper.prototype.invert = function() {\n    var data = this.data, length = data.length;\n\n    while (length--) {\n        data[length] = data[length] ? 0 : 1;\n    }\n};\n\nImageWrapper.prototype.convolve = function(kernel) {\n    var x, y, kx, ky, kSize = (kernel.length / 2) | 0, accu = 0;\n    for ( y = 0; y < this.size.y; y++) {\n        for ( x = 0; x < this.size.x; x++) {\n            accu = 0;\n            for ( ky = -kSize; ky <= kSize; ky++) {\n                for ( kx = -kSize; kx <= kSize; kx++) {\n                    accu += kernel[ky + kSize][kx + kSize] * this.getSafe(x + kx, y + ky);\n                }\n            }\n            this.data[y * this.size.x + x] = accu;\n        }\n    }\n};\n\nImageWrapper.prototype.moments = function(labelcount) {\n    var data = this.data,\n        x,\n        y,\n        height = this.size.y,\n        width = this.size.x,\n        val,\n        ysq,\n        labelsum = [],\n        i,\n        label,\n        mu11,\n        mu02,\n        mu20,\n        x_,\n        y_,\n        tmp,\n        result = [],\n        PI = Math.PI,\n        PI_4 = PI / 4;\n\n    if (labelcount <= 0) {\n        return result;\n    }\n\n    for ( i = 0; i < labelcount; i++) {\n        labelsum[i] = {\n            m00: 0,\n            m01: 0,\n            m10: 0,\n            m11: 0,\n            m02: 0,\n            m20: 0,\n            theta: 0,\n            rad: 0\n        };\n    }\n\n    for ( y = 0; y < height; y++) {\n        ysq = y * y;\n        for ( x = 0; x < width; x++) {\n            val = data[y * width + x];\n            if (val > 0) {\n                label = labelsum[val - 1];\n                label.m00 += 1;\n                label.m01 += y;\n                label.m10 += x;\n                label.m11 += x * y;\n                label.m02 += ysq;\n                label.m20 += x * x;\n            }\n        }\n    }\n\n    for ( i = 0; i < labelcount; i++) {\n        label = labelsum[i];\n        if (!isNaN(label.m00) && label.m00 !== 0) {\n            x_ = label.m10 / label.m00;\n            y_ = label.m01 / label.m00;\n            mu11 = label.m11 / label.m00 - x_ * y_;\n            mu02 = label.m02 / label.m00 - y_ * y_;\n            mu20 = label.m20 / label.m00 - x_ * x_;\n            tmp = (mu02 - mu20) / (2 * mu11);\n            tmp = 0.5 * Math.atan(tmp) + (mu11 >= 0 ? PI_4 : -PI_4 ) + PI;\n            label.theta = (tmp * 180 / PI + 90) % 180 - 90;\n            if (label.theta < 0) {\n                label.theta += 180;\n            }\n            label.rad = tmp > PI ? tmp - PI : tmp;\n            label.vec = vec2.clone([Math.cos(tmp), Math.sin(tmp)]);\n            result.push(label);\n        }\n    }\n\n    return result;\n};\n\n/**\n * Displays the {ImageWrapper} in a given canvas\n * @param canvas {Canvas} The canvas element to write to\n * @param scale {Number} Scale which is applied to each pixel-value\n */\nImageWrapper.prototype.show = function(canvas, scale) {\n    var ctx,\n        frame,\n        data,\n        current,\n        pixel,\n        x,\n        y;\n\n    if (!scale) {\n        scale = 1.0;\n    }\n    ctx = canvas.getContext('2d');\n    canvas.width = this.size.x;\n    canvas.height = this.size.y;\n    frame = ctx.getImageData(0, 0, canvas.width, canvas.height);\n    data = frame.data;\n    current = 0;\n    for (y = 0; y < this.size.y; y++) {\n        for (x = 0; x < this.size.x; x++) {\n            pixel = y * this.size.x + x;\n            current = this.get(x, y) * scale;\n            data[pixel * 4 + 0] = current;\n            data[pixel * 4 + 1] = current;\n            data[pixel * 4 + 2] = current;\n            data[pixel * 4 + 3] = 255;\n        }\n    }\n    //frame.data = data;\n    ctx.putImageData(frame, 0, 0);\n};\n\n/**\n * Displays the {SubImage} in a given canvas\n * @param canvas {Canvas} The canvas element to write to\n * @param scale {Number} Scale which is applied to each pixel-value\n */\nImageWrapper.prototype.overlay = function(canvas, scale, from) {\n    if (!scale || scale < 0 || scale > 360) {\n        scale = 360;\n    }\n    var hsv = [0, 1, 1];\n    var rgb = [0, 0, 0];\n    var whiteRgb = [255, 255, 255];\n    var blackRgb = [0, 0, 0];\n    var result = [];\n    var ctx = canvas.getContext('2d');\n    var frame = ctx.getImageData(from.x, from.y, this.size.x, this.size.y);\n    var data = frame.data;\n    var length = this.data.length;\n    while (length--) {\n        hsv[0] = this.data[length] * scale;\n        result = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : hsv2rgb(hsv, rgb);\n        data[length * 4 + 0] = result[0];\n        data[length * 4 + 1] = result[1];\n        data[length * 4 + 2] = result[2];\n        data[length * 4 + 3] = 255;\n    }\n    ctx.putImageData(frame, from.x, from.y);\n};\n\nexport default ImageWrapper;\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\nimport WebrtcAdapter from 'webrtc-adapter'; // eslint-disable-line no-unused-vars\nimport ImageWrapper from './common/image_wrapper';\nimport BarcodeLocator from './locator/barcode_locator';\nimport BarcodeDecoder from './decoder/barcode_decoder';\nimport Events from './common/events';\nimport CameraAccess from './input/camera_access';\nimport ImageDebug from './common/image_debug';\nimport ResultCollector from './analytics/result_collector';\nimport Config from './config/config';\nimport InputStream from 'input_stream';\nimport FrameGrabber from 'frame_grabber';\nimport {merge} from 'lodash';\nconst vec2 = {\n    clone: require('gl-vec2/clone')\n};\n\nvar _inputStream,\n    _framegrabber,\n    _stopped,\n    _canvasContainer = {\n        ctx: {\n            image: null,\n            overlay: null\n        },\n        dom: {\n            image: null,\n            overlay: null\n        }\n    },\n    _inputImageWrapper,\n    _boxSize,\n    _decoder,\n    _workerPool = [],\n    _onUIThread = true,\n    _resultCollector,\n    _config = {};\n\nfunction initializeData(imageWrapper) {\n    initBuffers(imageWrapper);\n    _decoder = BarcodeDecoder.create(_config.decoder, _inputImageWrapper);\n}\n\nfunction initInputStream(cb) {\n    var video;\n    if (_config.inputStream.type === \"VideoStream\") {\n        video = document.createElement(\"video\");\n        _inputStream = InputStream.createVideoStream(video);\n    } else if (_config.inputStream.type === \"ImageStream\") {\n        _inputStream = InputStream.createImageStream();\n    } else if (_config.inputStream.type === \"LiveStream\") {\n        var $viewport = getViewPort();\n        if ($viewport) {\n            video = $viewport.querySelector(\"video\");\n            if (!video) {\n                video = document.createElement(\"video\");\n                $viewport.appendChild(video);\n            }\n        }\n        _inputStream = InputStream.createLiveStream(video);\n        CameraAccess.request(video, _config.inputStream.constraints)\n        .then(() => {\n            _inputStream.trigger(\"canrecord\");\n        }).catch((err) => {\n            return cb(err);\n        });\n    }\n\n    _inputStream.setAttribute(\"preload\", \"auto\");\n    _inputStream.setAttribute(\"autoplay\", true);\n    _inputStream.setInputStream(_config.inputStream);\n    _inputStream.addEventListener(\"canrecord\", canRecord.bind(undefined, cb));\n}\n\nfunction getViewPort() {\n    var target = _config.inputStream.target;\n    // Check if target is already a DOM element\n    if (target && target.nodeName && target.nodeType === 1) {\n        return target;\n    } else {\n        // Use '#interactive.viewport' as a fallback selector (backwards compatibility)\n        var selector = typeof target === 'string' ? target : '#interactive.viewport';\n        return document.querySelector(selector);\n    }\n}\n\nfunction canRecord(cb) {\n    BarcodeLocator.checkImageConstraints(_inputStream, _config.locator);\n    initCanvas(_config);\n    _framegrabber = FrameGrabber.create(_inputStream, _canvasContainer.dom.image);\n\n    adjustWorkerPool(_config.numOfWorkers, function() {\n        if (_config.numOfWorkers === 0) {\n            initializeData();\n        }\n        ready(cb);\n    });\n}\n\nfunction ready(cb){\n    _inputStream.play();\n    cb();\n}\n\nfunction initCanvas() {\n    if (typeof document !== \"undefined\") {\n        var $viewport = getViewPort();\n        _canvasContainer.dom.image = document.querySelector(\"canvas.imgBuffer\");\n        if (!_canvasContainer.dom.image) {\n            _canvasContainer.dom.image = document.createElement(\"canvas\");\n            _canvasContainer.dom.image.className = \"imgBuffer\";\n            if ($viewport && _config.inputStream.type === \"ImageStream\") {\n                $viewport.appendChild(_canvasContainer.dom.image);\n            }\n        }\n        _canvasContainer.ctx.image = _canvasContainer.dom.image.getContext(\"2d\");\n        _canvasContainer.dom.image.width = _inputStream.getCanvasSize().x;\n        _canvasContainer.dom.image.height = _inputStream.getCanvasSize().y;\n\n        _canvasContainer.dom.overlay = document.querySelector(\"canvas.drawingBuffer\");\n        if (!_canvasContainer.dom.overlay) {\n            _canvasContainer.dom.overlay = document.createElement(\"canvas\");\n            _canvasContainer.dom.overlay.className = \"drawingBuffer\";\n            if ($viewport) {\n                $viewport.appendChild(_canvasContainer.dom.overlay);\n            }\n            var clearFix = document.createElement(\"br\");\n            clearFix.setAttribute(\"clear\", \"all\");\n            if ($viewport) {\n                $viewport.appendChild(clearFix);\n            }\n        }\n        _canvasContainer.ctx.overlay = _canvasContainer.dom.overlay.getContext(\"2d\");\n        _canvasContainer.dom.overlay.width = _inputStream.getCanvasSize().x;\n        _canvasContainer.dom.overlay.height = _inputStream.getCanvasSize().y;\n    }\n}\n\nfunction initBuffers(imageWrapper) {\n    if (imageWrapper) {\n        _inputImageWrapper = imageWrapper;\n    } else {\n        _inputImageWrapper = new ImageWrapper({\n            x: _inputStream.getWidth(),\n            y: _inputStream.getHeight()\n        });\n    }\n\n    if (ENV.development) {\n        console.log(_inputImageWrapper.size);\n    }\n    _boxSize = [\n        vec2.clone([0, 0]),\n        vec2.clone([0, _inputImageWrapper.size.y]),\n        vec2.clone([_inputImageWrapper.size.x, _inputImageWrapper.size.y]),\n        vec2.clone([_inputImageWrapper.size.x, 0])\n    ];\n    BarcodeLocator.init(_inputImageWrapper, _config.locator);\n}\n\nfunction getBoundingBoxes() {\n    if (_config.locate) {\n        return BarcodeLocator.locate();\n    } else {\n        return [[\n            vec2.clone(_boxSize[0]),\n            vec2.clone(_boxSize[1]),\n            vec2.clone(_boxSize[2]),\n            vec2.clone(_boxSize[3])]];\n    }\n}\n\nfunction transformResult(result) {\n    var topRight = _inputStream.getTopRight(),\n        xOffset = topRight.x,\n        yOffset = topRight.y,\n        i;\n\n    if (xOffset === 0 && yOffset === 0) {\n        return;\n    }\n\n    if (result.barcodes) {\n        for (i = 0; i < result.barcodes.length; i++) {\n            transformResult(result.barcodes[i]);\n        }\n    }\n\n    if (result.line && result.line.length === 2) {\n        moveLine(result.line);\n    }\n\n    if (result.box) {\n        moveBox(result.box);\n    }\n\n    if (result.boxes && result.boxes.length > 0) {\n        for (i = 0; i < result.boxes.length; i++) {\n            moveBox(result.boxes[i]);\n        }\n    }\n\n    function moveBox(box) {\n        var corner = box.length;\n\n        while (corner--) {\n            box[corner][0] += xOffset;\n            box[corner][1] += yOffset;\n        }\n    }\n\n    function moveLine(line) {\n        line[0].x += xOffset;\n        line[0].y += yOffset;\n        line[1].x += xOffset;\n        line[1].y += yOffset;\n    }\n}\n\nfunction addResult (result, imageData) {\n    if (!imageData || !_resultCollector) {\n        return;\n    }\n\n    if (result.barcodes) {\n        result.barcodes.filter(barcode => barcode.codeResult)\n            .forEach(barcode => addResult(barcode, imageData));\n    } else if (result.codeResult) {\n        _resultCollector.addResult(imageData, _inputStream.getCanvasSize(), result.codeResult);\n    }\n}\n\nfunction hasCodeResult (result) {\n    return result && (result.barcodes ?\n      result.barcodes.some(barcode => barcode.codeResult) :\n      result.codeResult);\n}\n\nfunction publishResult(result, imageData) {\n    let resultToPublish = result;\n\n    if (result && _onUIThread) {\n        transformResult(result);\n        addResult(result, imageData);\n        resultToPublish = result.barcodes || result;\n    }\n\n    Events.publish(\"processed\", resultToPublish);\n    if (hasCodeResult(result)) {\n        Events.publish(\"detected\", resultToPublish);\n    }\n}\n\nfunction locateAndDecode() {\n    var result,\n        boxes;\n\n    boxes = getBoundingBoxes();\n    if (boxes) {\n        result = _decoder.decodeFromBoundingBoxes(boxes);\n        result = result || {};\n        result.boxes = boxes;\n        publishResult(result, _inputImageWrapper.data);\n    } else {\n        publishResult();\n    }\n}\n\nfunction update() {\n    var availableWorker;\n\n    if (_onUIThread) {\n        if (_workerPool.length > 0) {\n            availableWorker = _workerPool.filter(function(workerThread) {\n                return !workerThread.busy;\n            })[0];\n            if (availableWorker) {\n                _framegrabber.attachData(availableWorker.imageData);\n            } else {\n                return; // all workers are busy\n            }\n        } else {\n            _framegrabber.attachData(_inputImageWrapper.data);\n        }\n        if (_framegrabber.grab()) {\n            if (availableWorker) {\n                availableWorker.busy = true;\n                availableWorker.worker.postMessage({\n                    cmd: 'process',\n                    imageData: availableWorker.imageData\n                }, [availableWorker.imageData.buffer]);\n            } else {\n                locateAndDecode();\n            }\n        }\n    } else {\n        locateAndDecode();\n    }\n}\n\nfunction startContinuousUpdate() {\n    var next = null,\n        delay = 1000 / (_config.frequency || 60);\n\n    _stopped = false;\n    (function frame(timestamp) {\n        next = next || timestamp;\n        if (!_stopped) {\n            if (timestamp >= next) {\n                next += delay;\n                update();\n            }\n            window.requestAnimFrame(frame);\n        }\n    }(performance.now()));\n}\n\nfunction start() {\n    if (_onUIThread && _config.inputStream.type === \"LiveStream\") {\n        startContinuousUpdate();\n    } else {\n        update();\n    }\n}\n\nfunction initWorker(cb) {\n    var blobURL,\n        workerThread = {\n            worker: undefined,\n            imageData: new Uint8Array(_inputStream.getWidth() * _inputStream.getHeight()),\n            busy: true\n        };\n\n    blobURL = generateWorkerBlob();\n    workerThread.worker = new Worker(blobURL);\n\n    workerThread.worker.onmessage = function(e) {\n        if (e.data.event === 'initialized') {\n            URL.revokeObjectURL(blobURL);\n            workerThread.busy = false;\n            workerThread.imageData = new Uint8Array(e.data.imageData);\n            if (ENV.development) {\n                console.log(\"Worker initialized\");\n            }\n            return cb(workerThread);\n        } else if (e.data.event === 'processed') {\n            workerThread.imageData = new Uint8Array(e.data.imageData);\n            workerThread.busy = false;\n            publishResult(e.data.result, workerThread.imageData);\n        } else if (e.data.event === 'error') {\n            if (ENV.development) {\n                console.log(\"Worker error: \" + e.data.message);\n            }\n        }\n    };\n\n    workerThread.worker.postMessage({\n        cmd: 'init',\n        size: {x: _inputStream.getWidth(), y: _inputStream.getHeight()},\n        imageData: workerThread.imageData,\n        config: configForWorker(_config)\n    }, [workerThread.imageData.buffer]);\n}\n\nfunction configForWorker(config) {\n    return {\n        ...config,\n        inputStream: {\n            ...config.inputStream,\n            target: null\n        }\n    };\n}\n\nfunction workerInterface(factory) {\n    /* eslint-disable no-undef*/\n    if (factory) {\n        var Quagga = factory().default;\n        if (!Quagga) {\n            self.postMessage({'event': 'error', message: 'Quagga could not be created'});\n            return;\n        }\n    }\n    var imageWrapper;\n\n    self.onmessage = function(e) {\n        if (e.data.cmd === 'init') {\n            var config = e.data.config;\n            config.numOfWorkers = 0;\n            imageWrapper = new Quagga.ImageWrapper({\n                x: e.data.size.x,\n                y: e.data.size.y\n            }, new Uint8Array(e.data.imageData));\n            Quagga.init(config, ready, imageWrapper);\n            Quagga.onProcessed(onProcessed);\n        } else if (e.data.cmd === 'process') {\n            imageWrapper.data = new Uint8Array(e.data.imageData);\n            Quagga.start();\n        } else if (e.data.cmd === 'setReaders') {\n            Quagga.setReaders(e.data.readers);\n        }\n    };\n\n    function onProcessed(result) {\n        self.postMessage({\n            'event': 'processed',\n            imageData: imageWrapper.data,\n            result: result\n        }, [imageWrapper.data.buffer]);\n    }\n\n    function ready() { // eslint-disable-line\n        self.postMessage({'event': 'initialized', imageData: imageWrapper.data}, [imageWrapper.data.buffer]);\n    }\n\n    /* eslint-enable */\n}\n\nfunction generateWorkerBlob() {\n    var blob,\n        factorySource;\n\n    /* jshint ignore:start */\n    if (typeof __factorySource__ !== 'undefined') {\n        factorySource = __factorySource__; // eslint-disable-line no-undef\n    }\n    /* jshint ignore:end */\n\n    blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'],\n        {type: 'text/javascript'});\n\n    return window.URL.createObjectURL(blob);\n}\n\nfunction setReaders(readers) {\n    if (_decoder) {\n        _decoder.setReaders(readers);\n    } else if (_onUIThread && _workerPool.length > 0) {\n        _workerPool.forEach(function(workerThread) {\n            workerThread.worker.postMessage({cmd: 'setReaders', readers: readers});\n        });\n    }\n}\n\nfunction adjustWorkerPool(capacity, cb) {\n    const increaseBy = capacity - _workerPool.length;\n    if (increaseBy === 0) {\n        return cb && cb();\n    }\n    if (increaseBy < 0) {\n        const workersToTerminate = _workerPool.slice(increaseBy);\n        workersToTerminate.forEach(function(workerThread) {\n            workerThread.worker.terminate();\n            if (ENV.development) {\n                console.log(\"Worker terminated!\");\n            }\n        });\n        _workerPool = _workerPool.slice(0, increaseBy);\n        return cb && cb();\n    } else {\n        for (var i = 0; i < increaseBy; i++) {\n            initWorker(workerInitialized);\n        }\n\n        function workerInitialized(workerThread) {\n            _workerPool.push(workerThread);\n            if (_workerPool.length >= capacity){\n                cb && cb();\n            }\n        }\n    }\n}\n\nexport default {\n    init: function(config, cb, imageWrapper) {\n        _config = merge({}, Config, config);\n        if (imageWrapper) {\n            _onUIThread = false;\n            initializeData(imageWrapper);\n            return cb();\n        } else {\n            initInputStream(cb);\n        }\n    },\n    start: function() {\n        start();\n    },\n    stop: function() {\n        _stopped = true;\n        adjustWorkerPool(0);\n        if (_config.inputStream.type === \"LiveStream\") {\n            CameraAccess.release();\n            _inputStream.clearEventHandlers();\n        }\n    },\n    pause: function() {\n        _stopped = true;\n    },\n    onDetected: function(callback) {\n        Events.subscribe(\"detected\", callback);\n    },\n    offDetected: function(callback) {\n        Events.unsubscribe(\"detected\", callback);\n    },\n    onProcessed: function(callback) {\n        Events.subscribe(\"processed\", callback);\n    },\n    offProcessed: function(callback) {\n        Events.unsubscribe(\"processed\", callback);\n    },\n    setReaders: function(readers) {\n        setReaders(readers);\n    },\n    registerResultCollector: function(resultCollector) {\n        if (resultCollector && typeof resultCollector.addResult === 'function') {\n            _resultCollector = resultCollector;\n        }\n    },\n    canvas: _canvasContainer,\n    decodeSingle: function(config, resultCallback) {\n        config = merge({\n            inputStream: {\n                type: \"ImageStream\",\n                sequence: false,\n                size: 800,\n                src: config.src\n            },\n            numOfWorkers: (ENV.development && config.debug) ? 0 : 1,\n            locator: {\n                halfSample: false\n            }\n        }, config);\n        this.init(config, () => {\n            Events.once(\"processed\", (result) => {\n                this.stop();\n                resultCallback.call(null, result);\n            }, true);\n            start();\n        });\n    },\n    ImageWrapper: ImageWrapper,\n    ImageDebug: ImageDebug,\n    ResultCollector: ResultCollector\n};\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 = {\n    clone: require('gl-vec2/clone'),\n    dot: require('gl-vec2/dot')\n}\n    /**\n     * Creates a cluster for grouping similar orientations of datapoints\n     */\nexport default {\n    create: function(point, threshold) {\n        var points = [],\n            center = {\n                rad: 0,\n                vec: vec2.clone([0, 0])\n            },\n            pointMap = {};\n\n        function init() {\n            add(point);\n            updateCenter();\n        }\n\n        function add(pointToAdd) {\n            pointMap[pointToAdd.id] = pointToAdd;\n            points.push(pointToAdd);\n        }\n\n        function updateCenter() {\n            var i, sum = 0;\n            for ( i = 0; i < points.length; i++) {\n                sum += points[i].rad;\n            }\n            center.rad = sum / points.length;\n            center.vec = vec2.clone([Math.cos(center.rad), Math.sin(center.rad)]);\n        }\n\n        init();\n\n        return {\n            add: function(pointToAdd) {\n                if (!pointMap[pointToAdd.id]) {\n                    add(pointToAdd);\n                    updateCenter();\n                }\n            },\n            fits: function(otherPoint) {\n                // check cosine similarity to center-angle\n                var similarity = Math.abs(vec2.dot(otherPoint.point.vec, center.vec));\n                if (similarity > threshold) {\n                    return true;\n                }\n                return false;\n            },\n            getPoints: function() {\n                return points;\n            },\n            getCenter: function() {\n                return center;\n            }\n        };\n    },\n    createPoint: function(newPoint, id, property) {\n        return {\n            rad: newPoint[property],\n            point: newPoint,\n            id: id\n        };\n    }\n};\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 **/","/*\n * typedefs.js\n * Normalizes browser-specific prefixes\n */\n\nif (typeof window !== 'undefined') {\n    window.requestAnimFrame = (function () {\n        return window.requestAnimationFrame ||\n            window.webkitRequestAnimationFrame ||\n            window.mozRequestAnimationFrame ||\n            window.oRequestAnimationFrame ||\n            window.msRequestAnimationFrame ||\n            function (/* function FrameRequestCallback */ callback) {\n                window.setTimeout(callback, 1000 / 60);\n            };\n    })();\n}\nMath.imul = Math.imul || function(a, b) {\n    var ah = (a >>> 16) & 0xffff,\n        al = a & 0xffff,\n        bh = (b >>> 16) & 0xffff,\n        bl = b & 0xffff;\n    // the shift by 0 fixes the sign on the high part\n    // the final |0 converts the unsigned value into a signed value\n    return ((al * bl) + (((ah * bl + al * bh) << 16) >>> 0) | 0);\n};\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/common/typedefs.js\n **/","module.exports = {\n    inputStream: {\n        name: \"Live\",\n        type: \"LiveStream\",\n        constraints: {\n            width: 640,\n            height: 480,\n            // aspectRatio: 640/480, // optional\n            facingMode: \"environment\", // or user\n            // deviceId: \"38745983457387598375983759834\"\n        },\n        area: {\n            top: \"0%\",\n            right: \"0%\",\n            left: \"0%\",\n            bottom: \"0%\"\n        },\n        singleChannel: false // true: only the red color-channel is read\n    },\n    locate: true,\n    numOfWorkers: 0,\n    decoder: {\n        readers: [\n            'code_128_reader'\n        ],\n        debug: {\n            drawBoundingBox: false,\n            showFrequency: false,\n            drawScanline: false,\n            showPattern: false\n        }\n    },\n    locator: {\n        halfSample: true,\n        patchSize: \"medium\", // x-small, small, medium, large, x-large\n        debug: {\n            showCanvas: false,\n            showPatches: false,\n            showFoundPatches: false,\n            showSkeleton: false,\n            showLabels: false,\n            showPatchLabels: false,\n            showRemainingPatchLabels: false,\n            boxFromPatches: {\n                showTransformed: false,\n                showTransformedBox: false,\n                showBB: false\n            }\n        }\n    }\n};\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';\n\nvar Bresenham = {};\n\nvar Slope = {\n    DIR: {\n        UP: 1,\n        DOWN: -1\n    }\n};\n/**\n * Scans a line of the given image from point p1 to p2 and returns a result object containing\n * gray-scale values (0-255) of the underlying pixels in addition to the min\n * and max values.\n * @param {Object} imageWrapper\n * @param {Object} p1 The start point {x,y}\n * @param {Object} p2 The end point {x,y}\n * @returns {line, min, max}\n */\nBresenham.getBarcodeLine = function(imageWrapper, p1, p2) {\n    var x0 = p1.x | 0,\n        y0 = p1.y | 0,\n        x1 = p2.x | 0,\n        y1 = p2.y | 0,\n        steep = Math.abs(y1 - y0) > Math.abs(x1 - x0),\n        deltax,\n        deltay,\n        error,\n        ystep,\n        y,\n        tmp,\n        x,\n        line = [],\n        imageData = imageWrapper.data,\n        width = imageWrapper.size.x,\n        sum = 0,\n        val,\n        min = 255,\n        max = 0;\n\n    function read(a, b) {\n        val = imageData[b * width + a];\n        sum += val;\n        min = val < min ? val : min;\n        max = val > max ? val : max;\n        line.push(val);\n    }\n\n    if (steep) {\n        tmp = x0;\n        x0 = y0;\n        y0 = tmp;\n\n        tmp = x1;\n        x1 = y1;\n        y1 = tmp;\n    }\n    if (x0 > x1) {\n        tmp = x0;\n        x0 = x1;\n        x1 = tmp;\n\n        tmp = y0;\n        y0 = y1;\n        y1 = tmp;\n    }\n    deltax = x1 - x0;\n    deltay = Math.abs(y1 - y0);\n    error = (deltax / 2) | 0;\n    y = y0;\n    ystep = y0 < y1 ? 1 : -1;\n    for ( x = x0; x < x1; x++) {\n        if (steep){\n            read(y, x);\n        } else {\n            read(x, y);\n        }\n        error = error - deltay;\n        if (error < 0) {\n            y = y + ystep;\n            error = error + deltax;\n        }\n    }\n\n    return {\n        line: line,\n        min: min,\n        max: max\n    };\n};\n\n/**\n * Converts the result from getBarcodeLine into a binary representation\n * also considering the frequency and slope of the signal for more robust results\n * @param {Object} result {line, min, max}\n */\nBresenham.toBinaryLine = function(result) {\n    var min = result.min,\n        max = result.max,\n        line = result.line,\n        slope,\n        slope2,\n        center = min + (max - min) / 2,\n        extrema = [],\n        currentDir,\n        dir,\n        threshold = (max - min) / 12,\n        rThreshold = -threshold,\n        i,\n        j;\n\n    // 1. find extrema\n    currentDir = line[0] > center ? Slope.DIR.UP : Slope.DIR.DOWN;\n    extrema.push({\n        pos: 0,\n        val: line[0]\n    });\n    for ( i = 0; i < line.length - 2; i++) {\n        slope = (line[i + 1] - line[i]);\n        slope2 = (line[i + 2] - line[i + 1]);\n        if ((slope + slope2) < rThreshold && line[i + 1] < (center * 1.5)) {\n            dir = Slope.DIR.DOWN;\n        } else if ((slope + slope2) > threshold && line[i + 1] > (center * 0.5)) {\n            dir = Slope.DIR.UP;\n        } else {\n            dir = currentDir;\n        }\n\n        if (currentDir !== dir) {\n            extrema.push({\n                pos: i,\n                val: line[i]\n            });\n            currentDir = dir;\n        }\n    }\n    extrema.push({\n        pos: line.length,\n        val: line[line.length - 1]\n    });\n\n    for ( j = extrema[0].pos; j < extrema[1].pos; j++) {\n        line[j] = line[j] > center ? 0 : 1;\n    }\n\n    // iterate over extrema and convert to binary based on avg between minmax\n    for ( i = 1; i < extrema.length - 1; i++) {\n        if (extrema[i + 1].val > extrema[i].val) {\n            threshold = (extrema[i].val + ((extrema[i + 1].val - extrema[i].val) / 3) * 2) | 0;\n        } else {\n            threshold = (extrema[i + 1].val + ((extrema[i].val - extrema[i + 1].val) / 3)) | 0;\n        }\n\n        for ( j = extrema[i].pos; j < extrema[i + 1].pos; j++) {\n            line[j] = line[j] > threshold ? 0 : 1;\n        }\n    }\n\n    return {\n        line: line,\n        threshold: threshold\n    };\n};\n\n/**\n * Used for development only\n */\nBresenham.debug = {\n    printFrequency: function(line, canvas) {\n        var i,\n            ctx = canvas.getContext(\"2d\");\n        canvas.width = line.length;\n        canvas.height = 256;\n\n        ctx.beginPath();\n        ctx.strokeStyle = \"blue\";\n        for ( i = 0; i < line.length; i++) {\n            ctx.moveTo(i, 255);\n            ctx.lineTo(i, 255 - line[i]);\n        }\n        ctx.stroke();\n        ctx.closePath();\n    },\n\n    printPattern: function(line, canvas) {\n        var ctx = canvas.getContext(\"2d\"), i;\n\n        canvas.width = line.length;\n        ctx.fillColor = \"black\";\n        for ( i = 0; i < line.length; i++) {\n            if (line[i] === 1) {\n                ctx.fillRect(i, 0, 1, 100);\n            }\n        }\n    }\n};\n\nexport default Bresenham;\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/decoder/bresenham.js\n **/","import {merge, pick} from 'lodash';\n\nvar streamRef,\n    loadedDataHandler;\n\nfunction waitForVideo(video) {\n    return new Promise((resolve, reject) => {\n        let attempts = 10;\n\n        function checkVideo() {\n            if (attempts > 0) {\n                if (video.videoWidth > 0 && video.videoHeight > 0) {\n                    if (ENV.development) {\n                        console.log(video.videoWidth + \"px x \" + video.videoHeight + \"px\");\n                    }\n                    resolve();\n                } else {\n                    window.setTimeout(checkVideo, 500);\n                }\n            } else {\n                reject('Unable to play video stream. Is webcam working?');\n            }\n            attempts--;\n        }\n        checkVideo();\n    });\n}\n\n/**\n * Tries to attach the camera-stream to a given video-element\n * and calls the callback function when the content is ready\n * @param {Object} constraints\n * @param {Object} video\n */\nfunction initCamera(video, constraints) {\n    return navigator.mediaDevices.getUserMedia(constraints)\n    .then((stream) => {\n        return new Promise((resolve, reject) => {\n            streamRef = stream;\n            video.src = window.URL.createObjectURL(stream);\n            video.onloadedmetadata = (e) => {\n                video.play();\n                resolve();\n            };\n        });\n    })\n    .then(waitForVideo.bind(null, video));\n}\n\nfunction deprecatedConstraints(videoConstraints) {\n    const normalized = pick(videoConstraints, [\"width\", \"height\", \"facingMode\",\n            \"aspectRatio\", \"deviceId\"]);\n\n    if (typeof videoConstraints[\"minAspectRatio\"] !== 'undefined' &&\n            videoConstraints[\"minAspectRatio\"] > 0) {\n        normalized[\"aspectRatio\"] = videoConstraints[\"minAspectRatio\"];\n        console.log(\"WARNING: Constraint 'minAspectRatio' is deprecated; Use 'aspectRatio' instead\");\n    }\n    if (typeof videoConstraints[\"facing\"] !== 'undefined') {\n        normalized[\"facingMode\"] = videoConstraints[\"facing\"];\n        console.log(\"WARNING: Constraint 'facing' is deprecated. Use 'facingMode' instead'\");\n    }\n    return normalized;\n}\n\nfunction applyCameraFacing(facing, constraints) {\n    if (typeof constraints.video.deviceId !== 'undefined' || !facing){\n        return Promise.resolve(constraints);\n    }\n    if ( typeof MediaStreamTrack !== 'undefined' &&\n            typeof MediaStreamTrack.getSources !== 'undefined') {\n        return new Promise((resolve, reject) => {\n            MediaStreamTrack.getSources((sourceInfos) => {\n                const videoSource = sourceInfos.filter((sourceInfo) => (\n                    sourceInfo.kind === \"video\" && sourceInfo.facing === facing\n                ))[0];\n                if (videoSource) {\n                    return resolve(merge({}, constraints,\n                        {video: {deviceId: videoSource.id}}));\n                }\n                return resolve(constraints);\n            });\n        });\n    }\n    return Promise.resolve(merge({}, constraints, {video: {facingMode: facing}}));\n}\n\nfunction pickConstraints(videoConstraints) {\n    const constraints = {\n        audio: false,\n        video: deprecatedConstraints(videoConstraints)\n    };\n    return applyCameraFacing(constraints.video.facingMode, constraints);\n}\n\nexport default {\n    request: function(video, videoConstraints) {\n        return pickConstraints(videoConstraints)\n            .then(initCamera.bind(null, video));\n    },\n    release: function() {\n        var tracks = streamRef && streamRef.getVideoTracks();\n        if (tracks && tracks.length) {\n            tracks[0].stop();\n        }\n        streamRef = null;\n    }\n};\n\n\n\n/** WEBPACK FOOTER **\n ** ./src/input/camera_access.js\n **/","import {\n    imageRef,\n    grayAndHalfSampleFromCanvasData,\n    computeGray\n} from '../common/cv_utils';\n\nvar FrameGrabber = {};\n\nFrameGrabber.create = function(inputStream, canvas) {\n    var _that = {},\n        _streamConfig = inputStream.getConfig(),\n        _video_size = imageRef(inputStream.getRealWidth(), inputStream.getRealHeight()),\n        _canvasSize = inputStream.getCanvasSize(),\n        _size = imageRef(inputStream.getWidth(), inputStream.getHeight()),\n        topRight = inputStream.getTopRight(),\n        _sx = topRight.x,\n        _sy = topRight.y,\n        _canvas,\n        _ctx = null,\n        _data = null;\n\n    _canvas = canvas ? canvas : document.createElement(\"canvas\");\n    _canvas.width = _canvasSize.x;\n    _canvas.height = _canvasSize.y;\n    _ctx = _canvas.getContext(\"2d\");\n    _data = new Uint8Array(_size.x * _size.y);\n    if (ENV.development) {\n        console.log(\"FrameGrabber\", JSON.stringify({\n            size: _size,\n            topRight: topRight,\n            videoSize: _video_size,\n            canvasSize: _canvasSize\n        }));\n    }\n\n    /**\n     * Uses the given array as frame-buffer\n     */\n    _that.attachData = function(data) {\n        _data = data;\n    };\n\n    /**\n     * Returns the used frame-buffer\n     */\n    _that.getData = function() {\n        return _data;\n    };\n\n    /**\n     * Fetches a frame from the input-stream and puts into the frame-buffer.\n     * The image-data is converted to gray-scale and then half-sampled if configured.\n     */\n    _that.grab = function() {\n        var doHalfSample = _streamConfig.halfSample,\n            frame = inputStream.getFrame(),\n            ctxData;\n        if (frame) {\n            _ctx.drawImage(frame, 0, 0, _canvasSize.x, _canvasSize.y);\n            ctxData = _ctx.getImageData(_sx, _sy, _size.x, _size.y).data;\n            if (doHalfSample){\n                grayAndHalfSampleFromCanvasData(ctxData, _size, _data);\n            } else {\n                computeGray(ctxData, _data, _streamConfig);\n            }\n            return true;\n        } else {\n            return false;\n        }\n    };\n\n    _that.getSize = function() {\n        return _size;\n    };\n\n    return _that;\n};\n\nexport default FrameGrabber;\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';\nimport {\n    calculatePatchSize,\n    otsuThreshold,\n    hsv2rgb,\n    cluster,\n    topGeneric,\n    imageRef,\n    halfSample,\n    computeImageArea\n} from '../common/cv_utils';\nimport ArrayHelper from '../common/array_helper';\nimport ImageDebug from '../common/image_debug';\nimport Rasterizer from './rasterizer';\nimport Tracer from './tracer';\nimport skeletonizer from './skeletonizer';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n    dot:  require('gl-vec2/dot'),\n    scale: require('gl-vec2/scale'),\n    transformMat2: require('gl-vec2/transformMat2')\n};\nconst mat2 = {\n    copy: require('gl-mat2/copy'),\n    create: require('gl-mat2/create'),\n    invert: require('gl-mat2/invert')\n}\n\nvar _config,\n    _currentImageWrapper,\n    _skelImageWrapper,\n    _subImageWrapper,\n    _labelImageWrapper,\n    _patchGrid,\n    _patchLabelGrid,\n    _imageToPatchGrid,\n    _binaryImageWrapper,\n    _patchSize,\n    _canvasContainer = {\n        ctx: {\n            binary: null\n        },\n        dom: {\n            binary: null\n        }\n    },\n    _numPatches = {x: 0, y: 0},\n    _inputImageWrapper,\n    _skeletonizer;\n\nfunction initBuffers() {\n    var skeletonImageData;\n\n    if (_config.halfSample) {\n        _currentImageWrapper = new ImageWrapper({\n            x: _inputImageWrapper.size.x / 2 | 0,\n            y: _inputImageWrapper.size.y / 2 | 0\n        });\n    } else {\n        _currentImageWrapper = _inputImageWrapper;\n    }\n\n    _patchSize = calculatePatchSize(_config.patchSize, _currentImageWrapper.size);\n\n    _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0;\n    _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0;\n\n    _binaryImageWrapper = new ImageWrapper(_currentImageWrapper.size, undefined, Uint8Array, false);\n\n    _labelImageWrapper = new ImageWrapper(_patchSize, undefined, Array, true);\n\n    skeletonImageData = new ArrayBuffer(64 * 1024);\n    _subImageWrapper = new ImageWrapper(_patchSize,\n        new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y));\n    _skelImageWrapper = new ImageWrapper(_patchSize,\n        new Uint8Array(skeletonImageData, _patchSize.x * _patchSize.y * 3, _patchSize.x * _patchSize.y),\n        undefined, true);\n    _skeletonizer = skeletonizer((typeof window !== 'undefined') ? window : (typeof self !== 'undefined') ? self : global, {\n        size: _patchSize.x\n    }, skeletonImageData);\n\n    _imageToPatchGrid = new ImageWrapper({\n        x: (_currentImageWrapper.size.x / _subImageWrapper.size.x) | 0,\n        y: (_currentImageWrapper.size.y / _subImageWrapper.size.y) | 0\n    }, undefined, Array, true);\n    _patchGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, undefined, true);\n    _patchLabelGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, Int32Array, true);\n}\n\nfunction initCanvas() {\n    if (_config.useWorker || typeof document === 'undefined') {\n        return;\n    }\n    _canvasContainer.dom.binary = document.createElement(\"canvas\");\n    _canvasContainer.dom.binary.className = \"binaryBuffer\";\n    if (ENV.development && _config.debug.showCanvas === true) {\n        document.querySelector(\"#debug\").appendChild(_canvasContainer.dom.binary);\n    }\n    _canvasContainer.ctx.binary = _canvasContainer.dom.binary.getContext(\"2d\");\n    _canvasContainer.dom.binary.width = _binaryImageWrapper.size.x;\n    _canvasContainer.dom.binary.height = _binaryImageWrapper.size.y;\n}\n\n/**\n * Creates a bounding box which encloses all the given patches\n * @returns {Array} The minimal bounding box\n */\nfunction boxFromPatches(patches) {\n    var overAvg,\n        i,\n        j,\n        patch,\n        transMat,\n        minx =\n        _binaryImageWrapper.size.x,\n        miny = _binaryImageWrapper.size.y,\n        maxx = -_binaryImageWrapper.size.x,\n        maxy = -_binaryImageWrapper.size.y,\n        box,\n        scale;\n\n    // draw all patches which are to be taken into consideration\n    overAvg = 0;\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        overAvg += patch.rad;\n        if (ENV.development && _config.debug.showPatches) {\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, {color: \"red\"});\n        }\n    }\n\n    overAvg /= patches.length;\n    overAvg = (overAvg * 180 / Math.PI + 90) % 180 - 90;\n    if (overAvg < 0) {\n        overAvg += 180;\n    }\n\n    overAvg = (180 - overAvg) * Math.PI / 180;\n    transMat = mat2.copy(mat2.create(), [Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]);\n\n    // iterate over patches and rotate by angle\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        for ( j = 0; j < 4; j++) {\n            vec2.transformMat2(patch.box[j], patch.box[j], transMat);\n        }\n\n        if (ENV.development && _config.debug.boxFromPatches.showTransformed) {\n            ImageDebug.drawPath(patch.box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#99ff00', lineWidth: 2});\n        }\n    }\n\n    // find bounding box\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        for ( j = 0; j < 4; j++) {\n            if (patch.box[j][0] < minx) {\n                minx = patch.box[j][0];\n            }\n            if (patch.box[j][0] > maxx) {\n                maxx = patch.box[j][0];\n            }\n            if (patch.box[j][1] < miny) {\n                miny = patch.box[j][1];\n            }\n            if (patch.box[j][1] > maxy) {\n                maxy = patch.box[j][1];\n            }\n        }\n    }\n\n    box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]];\n\n    if (ENV.development && _config.debug.boxFromPatches.showTransformedBox) {\n        ImageDebug.drawPath(box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#ff0000', lineWidth: 2});\n    }\n\n    scale = _config.halfSample ? 2 : 1;\n    // reverse rotation;\n    transMat = mat2.invert(transMat, transMat);\n    for ( j = 0; j < 4; j++) {\n        vec2.transformMat2(box[j], box[j], transMat);\n    }\n\n    if (ENV.development && _config.debug.boxFromPatches.showBB) {\n        ImageDebug.drawPath(box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#ff0000', lineWidth: 2});\n    }\n\n    for ( j = 0; j < 4; j++) {\n        vec2.scale(box[j], box[j], scale);\n    }\n\n    return box;\n}\n\n/**\n * Creates a binary image of the current image\n */\nfunction binarizeImage() {\n    otsuThreshold(_currentImageWrapper, _binaryImageWrapper);\n    _binaryImageWrapper.zeroBorder();\n    if (_config.debug.showCanvas) {\n        _binaryImageWrapper.show(_canvasContainer.dom.binary, 255);\n    }\n}\n\n/**\n * Iterate over the entire image\n * extract patches\n */\nfunction findPatches() {\n    var i,\n        j,\n        x,\n        y,\n        moments,\n        patchesFound = [],\n        rasterizer,\n        rasterResult,\n        patch;\n    for (i = 0; i < _numPatches.x; i++) {\n        for (j = 0; j < _numPatches.y; j++) {\n            x = _subImageWrapper.size.x * i;\n            y = _subImageWrapper.size.y * j;\n\n            // seperate parts\n            skeletonize(x, y);\n\n            // Rasterize, find individual bars\n            _skelImageWrapper.zeroBorder();\n            ArrayHelper.init(_labelImageWrapper.data, 0);\n            rasterizer = Rasterizer.create(_skelImageWrapper, _labelImageWrapper);\n            rasterResult = rasterizer.rasterize(0);\n\n            if (ENV.development && _config.debug.showLabels) {\n                _labelImageWrapper.overlay(_canvasContainer.dom.binary, Math.floor(360 / rasterResult.count),\n                    {x: x, y: y});\n            }\n\n            // calculate moments from the skeletonized patch\n            moments = _labelImageWrapper.moments(rasterResult.count);\n\n            // extract eligible patches\n            patchesFound = patchesFound.concat(describePatch(moments, [i, j], x, y));\n        }\n    }\n\n    if (ENV.development && _config.debug.showFoundPatches) {\n        for ( i = 0; i < patchesFound.length; i++) {\n            patch = patchesFound[i];\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                {color: \"#99ff00\", lineWidth: 2});\n        }\n    }\n\n    return patchesFound;\n}\n\n/**\n * Finds those connected areas which contain at least 6 patches\n * and returns them ordered DESC by the number of contained patches\n * @param {Number} maxLabel\n */\nfunction findBiggestConnectedAreas(maxLabel){\n    var i,\n        sum,\n        labelHist = [],\n        topLabels = [];\n\n    for ( i = 0; i < maxLabel; i++) {\n        labelHist.push(0);\n    }\n    sum = _patchLabelGrid.data.length;\n    while (sum--) {\n        if (_patchLabelGrid.data[sum] > 0) {\n            labelHist[_patchLabelGrid.data[sum] - 1]++;\n        }\n    }\n\n    labelHist = labelHist.map(function(val, idx) {\n        return {\n            val: val,\n            label: idx + 1\n        };\n    });\n\n    labelHist.sort(function(a, b) {\n        return b.val - a.val;\n    });\n\n    // extract top areas with at least 6 patches present\n    topLabels = labelHist.filter(function(el) {\n        return el.val >= 5;\n    });\n\n    return topLabels;\n}\n\n/**\n *\n */\nfunction findBoxes(topLabels, maxLabel) {\n    var i,\n        j,\n        sum,\n        patches = [],\n        patch,\n        box,\n        boxes = [],\n        hsv = [0, 1, 1],\n        rgb = [0, 0, 0];\n\n    for ( i = 0; i < topLabels.length; i++) {\n        sum = _patchLabelGrid.data.length;\n        patches.length = 0;\n        while (sum--) {\n            if (_patchLabelGrid.data[sum] === topLabels[i].label) {\n                patch = _imageToPatchGrid.data[sum];\n                patches.push(patch);\n            }\n        }\n        box = boxFromPatches(patches);\n        if (box) {\n            boxes.push(box);\n\n            // draw patch-labels if requested\n            if (ENV.development && _config.debug.showRemainingPatchLabels) {\n                for ( j = 0; j < patches.length; j++) {\n                    patch = patches[j];\n                    hsv[0] = (topLabels[i].label / (maxLabel + 1)) * 360;\n                    hsv2rgb(hsv, rgb);\n                    ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                        {color: \"rgb(\" + rgb.join(\",\") + \")\", lineWidth: 2});\n                }\n            }\n        }\n    }\n    return boxes;\n}\n\n/**\n * Find similar moments (via cluster)\n * @param {Object} moments\n */\nfunction similarMoments(moments) {\n    var clusters = cluster(moments, 0.90);\n    var topCluster = topGeneric(clusters, 1, function(e) {\n        return e.getPoints().length;\n    });\n    var points = [], result = [];\n    if (topCluster.length === 1) {\n        points = topCluster[0].item.getPoints();\n        for (var i = 0; i < points.length; i++) {\n            result.push(points[i].point);\n        }\n    }\n    return result;\n}\n\nfunction skeletonize(x, y) {\n    _binaryImageWrapper.subImageAsCopy(_subImageWrapper, imageRef(x, y));\n    _skeletonizer.skeletonize();\n\n    // Show skeleton if requested\n    if (ENV.development && _config.debug.showSkeleton) {\n        _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, imageRef(x, y));\n    }\n}\n\n/**\n * Extracts and describes those patches which seem to contain a barcode pattern\n * @param {Array} moments\n * @param {Object} patchPos,\n * @param {Number} x\n * @param {Number} y\n * @returns {Array} list of patches\n */\nfunction describePatch(moments, patchPos, x, y) {\n    var k,\n        avg,\n        eligibleMoments = [],\n        matchingMoments,\n        patch,\n        patchesFound = [],\n        minComponentWeight = Math.ceil(_patchSize.x / 3);\n\n    if (moments.length >= 2) {\n        // only collect moments which's area covers at least minComponentWeight pixels.\n        for ( k = 0; k < moments.length; k++) {\n            if (moments[k].m00 > minComponentWeight) {\n                eligibleMoments.push(moments[k]);\n            }\n        }\n\n        // if at least 2 moments are found which have at least minComponentWeights covered\n        if (eligibleMoments.length >= 2) {\n            matchingMoments = similarMoments(eligibleMoments);\n            avg = 0;\n            // determine the similarity of the moments\n            for ( k = 0; k < matchingMoments.length; k++) {\n                avg += matchingMoments[k].rad;\n            }\n\n            // Only two of the moments are allowed not to fit into the equation\n            // add the patch to the set\n            if (matchingMoments.length > 1\n                    && matchingMoments.length >= (eligibleMoments.length / 4) * 3\n                    && matchingMoments.length > moments.length / 4) {\n                avg /= matchingMoments.length;\n                patch = {\n                    index: patchPos[1] * _numPatches.x + patchPos[0],\n                    pos: {\n                        x: x,\n                        y: y\n                    },\n                    box: [\n                        vec2.clone([x, y]),\n                        vec2.clone([x + _subImageWrapper.size.x, y]),\n                        vec2.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]),\n                        vec2.clone([x, y + _subImageWrapper.size.y])\n                    ],\n                    moments: matchingMoments,\n                    rad: avg,\n                    vec: vec2.clone([Math.cos(avg), Math.sin(avg)])\n                };\n                patchesFound.push(patch);\n            }\n        }\n    }\n    return patchesFound;\n}\n\n/**\n * finds patches which are connected and share the same orientation\n * @param {Object} patchesFound\n */\nfunction rasterizeAngularSimilarity(patchesFound) {\n    var label = 0,\n        threshold = 0.95,\n        currIdx = 0,\n        j,\n        patch,\n        hsv = [0, 1, 1],\n        rgb = [0, 0, 0];\n\n    function notYetProcessed() {\n        var i;\n        for ( i = 0; i < _patchLabelGrid.data.length; i++) {\n            if (_patchLabelGrid.data[i] === 0 && _patchGrid.data[i] === 1) {\n                return i;\n            }\n        }\n        return _patchLabelGrid.length;\n    }\n\n    function trace(currentIdx) {\n        var x,\n            y,\n            currentPatch,\n            idx,\n            dir,\n            current = {\n                x: currentIdx % _patchLabelGrid.size.x,\n                y: (currentIdx / _patchLabelGrid.size.x) | 0\n            },\n            similarity;\n\n        if (currentIdx < _patchLabelGrid.data.length) {\n            currentPatch = _imageToPatchGrid.data[currentIdx];\n            // assign label\n            _patchLabelGrid.data[currentIdx] = label;\n            for ( dir = 0; dir < Tracer.searchDirections.length; dir++) {\n                y = current.y + Tracer.searchDirections[dir][0];\n                x = current.x + Tracer.searchDirections[dir][1];\n                idx = y * _patchLabelGrid.size.x + x;\n\n                // continue if patch empty\n                if (_patchGrid.data[idx] === 0) {\n                    _patchLabelGrid.data[idx] = Number.MAX_VALUE;\n                    continue;\n                }\n\n                if (_patchLabelGrid.data[idx] === 0) {\n                    similarity = Math.abs(vec2.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec));\n                    if (similarity > threshold) {\n                        trace(idx);\n                    }\n                }\n            }\n        }\n    }\n\n    // prepare for finding the right patches\n    ArrayHelper.init(_patchGrid.data, 0);\n    ArrayHelper.init(_patchLabelGrid.data, 0);\n    ArrayHelper.init(_imageToPatchGrid.data, null);\n\n    for ( j = 0; j < patchesFound.length; j++) {\n        patch = patchesFound[j];\n        _imageToPatchGrid.data[patch.index] = patch;\n        _patchGrid.data[patch.index] = 1;\n    }\n\n    // rasterize the patches found to determine area\n    _patchGrid.zeroBorder();\n\n    while (( currIdx = notYetProcessed()) < _patchLabelGrid.data.length) {\n        label++;\n        trace(currIdx);\n    }\n\n    // draw patch-labels if requested\n    if (ENV.development && _config.debug.showPatchLabels) {\n        for ( j = 0; j < _patchLabelGrid.data.length; j++) {\n            if (_patchLabelGrid.data[j] > 0 && _patchLabelGrid.data[j] <= label) {\n                patch = _imageToPatchGrid.data[j];\n                hsv[0] = (_patchLabelGrid.data[j] / (label + 1)) * 360;\n                hsv2rgb(hsv, rgb);\n                ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                    {color: \"rgb(\" + rgb.join(\",\") + \")\", lineWidth: 2});\n            }\n        }\n    }\n\n    return label;\n}\n\nexport default {\n    init: function(inputImageWrapper, config) {\n        _config = config;\n        _inputImageWrapper = inputImageWrapper;\n\n        initBuffers();\n        initCanvas();\n    },\n\n    locate: function() {\n        var patchesFound,\n            topLabels,\n            boxes;\n\n        if (_config.halfSample) {\n            halfSample(_inputImageWrapper, _currentImageWrapper);\n        }\n\n        binarizeImage();\n        patchesFound = findPatches();\n        // return unless 5% or more patches are found\n        if (patchesFound.length < _numPatches.x * _numPatches.y * 0.05) {\n            return null;\n        }\n\n        // rasterrize area by comparing angular similarity;\n        var maxLabel = rasterizeAngularSimilarity(patchesFound);\n        if (maxLabel < 1) {\n            return null;\n        }\n\n        // search for area with the most patches (biggest connected area)\n        topLabels = findBiggestConnectedAreas(maxLabel);\n        if (topLabels.length === 0) {\n            return null;\n        }\n\n        boxes = findBoxes(topLabels, maxLabel);\n        return boxes;\n    },\n\n    checkImageConstraints: function(inputStream, config) {\n        var patchSize,\n            width = inputStream.getWidth(),\n            height = inputStream.getHeight(),\n            halfSample = config.halfSample ? 0.5 : 1,\n            size,\n            area;\n\n        // calculate width and height based on area\n        if (inputStream.getConfig().area) {\n            area = computeImageArea(width, height, inputStream.getConfig().area);\n            inputStream.setTopRight({x: area.sx, y: area.sy});\n            inputStream.setCanvasSize({x: width, y: height});\n            width = area.sw;\n            height = area.sh;\n        }\n\n        size = {\n            x: Math.floor(width * halfSample),\n            y: Math.floor(height * halfSample)\n        };\n\n        patchSize = calculatePatchSize(config.patchSize, size);\n        if (ENV.development) {\n            console.log(\"Patch-Size: \" + JSON.stringify(patchSize));\n        }\n\n        inputStream.setWidth(Math.floor(Math.floor(size.x / patchSize.x) * (1 / halfSample) * patchSize.x));\n        inputStream.setHeight(Math.floor(Math.floor(size.y / patchSize.y) * (1 / halfSample) * patchSize.y));\n\n        if ((inputStream.getWidth() % patchSize.x) === 0 && (inputStream.getHeight() % patchSize.y) === 0) {\n            return true;\n        }\n\n        throw new Error(\"Image dimensions do not comply with the current settings: Width (\" +\n            width + \" )and height (\" + height +\n            \") must a multiple of \" + patchSize.x);\n    }\n};\n\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 */\n/* eslint-disable eqeqeq*/\nfunction Skeletonizer(stdlib, foreign, buffer) {\n    \"use asm\";\n\n    var images = new stdlib.Uint8Array(buffer),\n        size = foreign.size | 0,\n        imul = stdlib.Math.imul;\n\n    function erode(inImagePtr, outImagePtr) {\n        inImagePtr = inImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var v = 0,\n            u = 0,\n            sum = 0,\n            yStart1 = 0,\n            yStart2 = 0,\n            xStart1 = 0,\n            xStart2 = 0,\n            offset = 0;\n\n        for ( v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\n            offset = (offset + size) | 0;\n            for ( u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\n                yStart1 = (offset - size) | 0;\n                yStart2 = (offset + size) | 0;\n                xStart1 = (u - 1) | 0;\n                xStart2 = (u + 1) | 0;\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\n                if ((sum | 0) == (5 | 0)) {\n                    images[(outImagePtr + offset + u) | 0] = 1;\n                } else {\n                    images[(outImagePtr + offset + u) | 0] = 0;\n                }\n            }\n        }\n        return;\n    }\n\n    function subtract(aImagePtr, bImagePtr, outImagePtr) {\n        aImagePtr = aImagePtr | 0;\n        bImagePtr = bImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(outImagePtr + length) | 0] =\n                ((images[(aImagePtr + length) | 0] | 0) - (images[(bImagePtr + length) | 0] | 0)) | 0;\n        }\n    }\n\n    function bitwiseOr(aImagePtr, bImagePtr, outImagePtr) {\n        aImagePtr = aImagePtr | 0;\n        bImagePtr = bImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(outImagePtr + length) | 0] =\n                ((images[(aImagePtr + length) | 0] | 0) | (images[(bImagePtr + length) | 0] | 0)) | 0;\n        }\n    }\n\n    function countNonZero(imagePtr) {\n        imagePtr = imagePtr | 0;\n\n        var sum = 0,\n            length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            sum = ((sum | 0) + (images[(imagePtr + length) | 0] | 0)) | 0;\n        }\n\n        return (sum | 0);\n    }\n\n    function init(imagePtr, value) {\n        imagePtr = imagePtr | 0;\n        value = value | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(imagePtr + length) | 0] = value;\n        }\n    }\n\n    function dilate(inImagePtr, outImagePtr) {\n        inImagePtr = inImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var v = 0,\n            u = 0,\n            sum = 0,\n            yStart1 = 0,\n            yStart2 = 0,\n            xStart1 = 0,\n            xStart2 = 0,\n            offset = 0;\n\n        for ( v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\n            offset = (offset + size) | 0;\n            for ( u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\n                yStart1 = (offset - size) | 0;\n                yStart2 = (offset + size) | 0;\n                xStart1 = (u - 1) | 0;\n                xStart2 = (u + 1) | 0;\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\n                if ((sum | 0) > (0 | 0)) {\n                    images[(outImagePtr + offset + u) | 0] = 1;\n                } else {\n                    images[(outImagePtr + offset + u) | 0] = 0;\n                }\n            }\n        }\n        return;\n    }\n\n    function memcpy(srcImagePtr, dstImagePtr) {\n        srcImagePtr = srcImagePtr | 0;\n        dstImagePtr = dstImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(dstImagePtr + length) | 0] = (images[(srcImagePtr + length) | 0] | 0);\n        }\n    }\n\n    function zeroBorder(imagePtr) {\n        imagePtr = imagePtr | 0;\n\n        var x = 0,\n            y = 0;\n\n        for ( x = 0; (x | 0) < ((size - 1) | 0); x = (x + 1) | 0) {\n            images[(imagePtr + x) | 0] = 0;\n            images[(imagePtr + y) | 0] = 0;\n            y = ((y + size) - 1) | 0;\n            images[(imagePtr + y) | 0] = 0;\n            y = (y + 1) | 0;\n        }\n        for ( x = 0; (x | 0) < (size | 0); x = (x + 1) | 0) {\n            images[(imagePtr + y) | 0] = 0;\n            y = (y + 1) | 0;\n        }\n    }\n\n    function skeletonize() {\n        var subImagePtr = 0,\n            erodedImagePtr = 0,\n            tempImagePtr = 0,\n            skelImagePtr = 0,\n            sum = 0,\n            done = 0;\n\n        erodedImagePtr = imul(size, size) | 0;\n        tempImagePtr = (erodedImagePtr + erodedImagePtr) | 0;\n        skelImagePtr = (tempImagePtr + erodedImagePtr) | 0;\n\n        // init skel-image\n        init(skelImagePtr, 0);\n        zeroBorder(subImagePtr);\n\n        do {\n            erode(subImagePtr, erodedImagePtr);\n            dilate(erodedImagePtr, tempImagePtr);\n            subtract(subImagePtr, tempImagePtr, tempImagePtr);\n            bitwiseOr(skelImagePtr, tempImagePtr, skelImagePtr);\n            memcpy(erodedImagePtr, subImagePtr);\n            sum = countNonZero(subImagePtr) | 0;\n            done = ((sum | 0) == 0 | 0);\n        } while (!done);\n    }\n    return {\n        skeletonize: skeletonize\n    };\n}\n/* @preserve ASM END */\nexport default Skeletonizer;\n/* eslint-enable eqeqeq*/\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';\nimport {merge} from 'lodash';\n\nfunction I2of5Reader(opts) {\n    opts = merge(getDefaulConfig(), opts);\n    BarcodeReader.call(this, opts);\n    this.barSpaceRatio = [1, 1];\n    if (opts.normalizeBarSpaceWidth) {\n        this.SINGLE_CODE_ERROR = 0.38;\n        this.AVG_CODE_ERROR = 0.09;\n    }\n}\n\nfunction getDefaulConfig() {\n    var config = {};\n\n    Object.keys(I2of5Reader.CONFIG_KEYS).forEach(function(key) {\n        config[key] = I2of5Reader.CONFIG_KEYS[key].default;\n    });\n    return config;\n}\n\nvar N = 1,\n    W = 3,\n    properties = {\n        MODULO: {value: 10},\n        START_PATTERN: {value: [N * 2.5, N * 2.5, N * 2.5, N * 2.5]},\n        STOP_PATTERN: {value: [N * 2, N * 2, W * 2]},\n        CODE_PATTERN: {value: [\n            [N, N, W, W, N],\n            [W, N, N, N, W],\n            [N, W, N, N, W],\n            [W, W, N, N, N],\n            [N, N, W, N, W],\n            [W, N, W, N, N],\n            [N, W, W, N, N],\n            [N, N, N, W, W],\n            [W, N, N, W, N],\n            [N, W, N, W, N]\n        ]},\n        SINGLE_CODE_ERROR: {value: 0.78, writable: true},\n        AVG_CODE_ERROR: {value: 0.38, writable: true},\n        MAX_CORRECTION_FACTOR: {value: 5},\n        FORMAT: {value: \"i2of5\"}\n    };\n\nI2of5Reader.prototype = Object.create(BarcodeReader.prototype, properties);\nI2of5Reader.prototype.constructor = I2of5Reader;\n\nI2of5Reader.prototype._matchPattern = function(counter, code) {\n    if (this.config.normalizeBarSpaceWidth) {\n        var i,\n            counterSum = [0, 0],\n            codeSum = [0, 0],\n            correction = [0, 0],\n            correctionRatio = this.MAX_CORRECTION_FACTOR,\n            correctionRatioInverse = 1 / correctionRatio;\n\n        for (i = 0; i < counter.length; i++) {\n            counterSum[i % 2] += counter[i];\n            codeSum[i % 2] += code[i];\n        }\n        correction[0] = codeSum[0] / counterSum[0];\n        correction[1] = codeSum[1] / counterSum[1];\n\n        correction[0] = Math.max(Math.min(correction[0], correctionRatio), correctionRatioInverse);\n        correction[1] = Math.max(Math.min(correction[1], correctionRatio), correctionRatioInverse);\n        this.barSpaceRatio = correction;\n        for (i = 0; i < counter.length; i++) {\n            counter[i] *= this.barSpaceRatio[i % 2];\n        }\n    }\n    return BarcodeReader.prototype._matchPattern.call(this, counter, code);\n};\n\nI2of5Reader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder) {\n    var counter = [],\n        self = this,\n        i,\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        },\n        error,\n        j,\n        sum,\n        normalized,\n        epsilon = self.AVG_CODE_ERROR;\n\n    isWhite = isWhite || false;\n    tryHarder = tryHarder || false;\n\n    if (!offset) {\n        offset = self._nextSet(self._row);\n    }\n\n    for ( i = 0; i < pattern.length; i++) {\n        counter[i] = 0;\n    }\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                sum = 0;\n                for ( j = 0; j < counter.length; j++) {\n                    sum += counter[j];\n                }\n                normalized = self._normalize(counter);\n                if (normalized) {\n                    error = self._matchPattern(normalized, pattern);\n\n                    if (error < epsilon) {\n                        bestMatch.error = error;\n                        bestMatch.start = i - sum;\n                        bestMatch.end = i;\n                        return bestMatch;\n                    }\n                }\n                if (tryHarder) {\n                    for (j = 0; j < counter.length - 2; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[counter.length - 2] = 0;\n                    counter[counter.length - 1] = 0;\n                    counterPos--;\n                } else {\n                    return null;\n                }\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nI2of5Reader.prototype._findStart = function() {\n    var self = this,\n        leadingWhitespaceStart,\n        offset = self._nextSet(self._row),\n        startInfo,\n        narrowBarWidth = 1;\n\n    while (!startInfo) {\n        startInfo = self._findPattern(self.START_PATTERN, offset, false, true);\n        if (!startInfo) {\n            return null;\n        }\n        narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / 4);\n        leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10;\n        if (leadingWhitespaceStart >= 0) {\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                return startInfo;\n            }\n        }\n        offset = startInfo.end;\n        startInfo = null;\n    }\n};\n\nI2of5Reader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n    return null;\n};\n\nI2of5Reader.prototype._findEnd = function() {\n    var self = this,\n        endInfo,\n        tmp;\n\n    self._row.reverse();\n    endInfo = self._findPattern(self.STOP_PATTERN);\n    self._row.reverse();\n\n    if (endInfo === null) {\n        return null;\n    }\n\n    // reverse numbers\n    tmp = endInfo.start;\n    endInfo.start = self._row.length - endInfo.end;\n    endInfo.end = self._row.length - tmp;\n\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\n};\n\nI2of5Reader.prototype._decodePair = function(counterPair) {\n    var i,\n        code,\n        codes = [],\n        self = this;\n\n    for (i = 0; i < counterPair.length; i++) {\n        code = self._decodeCode(counterPair[i]);\n        if (!code) {\n            return null;\n        }\n        codes.push(code);\n    }\n    return codes;\n};\n\nI2of5Reader.prototype._decodeCode = function(counter) {\n    var j,\n        self = this,\n        sum = 0,\n        normalized,\n        error,\n        epsilon = self.AVG_CODE_ERROR,\n        code,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        };\n\n    for ( j = 0; j < counter.length; j++) {\n        sum += counter[j];\n    }\n    normalized = self._normalize(counter);\n    if (normalized) {\n        for (code = 0; code < self.CODE_PATTERN.length; code++) {\n            error = self._matchPattern(normalized, self.CODE_PATTERN[code]);\n            if (error < bestMatch.error) {\n                bestMatch.code = code;\n                bestMatch.error = error;\n            }\n        }\n        if (bestMatch.error < epsilon) {\n            return bestMatch;\n        }\n    }\n    return null;\n};\n\nI2of5Reader.prototype._decodePayload = function(counters, result, decodedCodes) {\n    var i,\n        self = this,\n        pos = 0,\n        counterLength = counters.length,\n        counterPair = [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0]],\n        codes;\n\n    while (pos < counterLength) {\n        for (i = 0; i < 5; i++) {\n            counterPair[0][i] = counters[pos] * this.barSpaceRatio[0];\n            counterPair[1][i] = counters[pos + 1] * this.barSpaceRatio[1];\n            pos += 2;\n        }\n        codes = self._decodePair(counterPair);\n        if (!codes) {\n            return null;\n        }\n        for (i = 0; i < codes.length; i++) {\n            result.push(codes[i].code + \"\");\n            decodedCodes.push(codes[i]);\n        }\n    }\n    return codes;\n};\n\nI2of5Reader.prototype._verifyCounterLength = function(counters) {\n    return (counters.length % 10 === 0);\n};\n\nI2of5Reader.prototype._decode = function() {\n    var startInfo,\n        endInfo,\n        self = this,\n        code,\n        result = [],\n        decodedCodes = [],\n        counters;\n\n    startInfo = self._findStart();\n    if (!startInfo) {\n        return null;\n    }\n    decodedCodes.push(startInfo);\n\n    endInfo = self._findEnd();\n    if (!endInfo) {\n        return null;\n    }\n\n    counters = self._fillCounters(startInfo.end, endInfo.start, false);\n    if (!self._verifyCounterLength(counters)) {\n        return null;\n    }\n    code = self._decodePayload(counters, result, decodedCodes);\n    if (!code) {\n        return null;\n    }\n    if (result.length % 2 !== 0 ||\n            result.length < 6) {\n        return null;\n    }\n\n    decodedCodes.push(endInfo);\n    return {\n        code: result.join(\"\"),\n        start: startInfo.start,\n        end: endInfo.end,\n        startInfo: startInfo,\n        decodedCodes: decodedCodes\n    };\n};\n\nI2of5Reader.CONFIG_KEYS = {\n    normalizeBarSpaceWidth: {\n        'type': 'boolean',\n        'default': false,\n        'description': 'If true, the reader tries to normalize the' +\n        'width-difference between bars and spaces'\n    }\n};\n\nexport default I2of5Reader;\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":""} |