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.
quaggaJS/dist/quagga.js

9350 lines
916 KiB
JavaScript

var Quagga =
(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].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "/";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = "./src/quagga.ts");
/******/ })
/************************************************************************/
/******/ ({
/***/ "../../node_modules/@babel/runtime/helpers/arrayWithoutHoles.js":
/*!***********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/arrayWithoutHoles.js ***!
\***********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _arrayWithoutHoles(arr) {
if (Array.isArray(arr)) {
for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) {
arr2[i] = arr[i];
}
return arr2;
}
}
module.exports = _arrayWithoutHoles;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/assertThisInitialized.js":
/*!***************************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/assertThisInitialized.js ***!
\***************************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _assertThisInitialized(self) {
if (self === void 0) {
throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
}
return self;
}
module.exports = _assertThisInitialized;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/asyncToGenerator.js":
/*!**********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/asyncToGenerator.js ***!
\**********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
try {
var info = gen[key](arg);
var value = info.value;
} catch (error) {
reject(error);
return;
}
if (info.done) {
resolve(value);
} else {
Promise.resolve(value).then(_next, _throw);
}
}
function _asyncToGenerator(fn) {
return function () {
var self = this,
args = arguments;
return new Promise(function (resolve, reject) {
var gen = fn.apply(self, args);
function _next(value) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
}
function _throw(err) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
}
_next(undefined);
});
};
}
module.exports = _asyncToGenerator;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/classCallCheck.js":
/*!********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/classCallCheck.js ***!
\********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _classCallCheck(instance, Constructor) {
if (!(instance instanceof Constructor)) {
throw new TypeError("Cannot call a class as a function");
}
}
module.exports = _classCallCheck;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/createClass.js":
/*!*****************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/createClass.js ***!
\*****************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _defineProperties(target, props) {
for (var i = 0; i < props.length; i++) {
var descriptor = props[i];
descriptor.enumerable = descriptor.enumerable || false;
descriptor.configurable = true;
if ("value" in descriptor) descriptor.writable = true;
Object.defineProperty(target, descriptor.key, descriptor);
}
}
function _createClass(Constructor, protoProps, staticProps) {
if (protoProps) _defineProperties(Constructor.prototype, protoProps);
if (staticProps) _defineProperties(Constructor, staticProps);
return Constructor;
}
module.exports = _createClass;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/defineProperty.js":
/*!********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/defineProperty.js ***!
\********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _defineProperty(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
});
} else {
obj[key] = value;
}
return obj;
}
module.exports = _defineProperty;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/get.js":
/*!*********************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/get.js ***!
\*********************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
var getPrototypeOf = __webpack_require__(/*! ./getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
var superPropBase = __webpack_require__(/*! ./superPropBase */ "../../node_modules/@babel/runtime/helpers/superPropBase.js");
function _get(target, property, receiver) {
if (typeof Reflect !== "undefined" && Reflect.get) {
module.exports = _get = Reflect.get;
} else {
module.exports = _get = function _get(target, property, receiver) {
var base = superPropBase(target, property);
if (!base) return;
var desc = Object.getOwnPropertyDescriptor(base, property);
if (desc.get) {
return desc.get.call(receiver);
}
return desc.value;
};
}
return _get(target, property, receiver || target);
}
module.exports = _get;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js":
/*!********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/getPrototypeOf.js ***!
\********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _getPrototypeOf(o) {
module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
return o.__proto__ || Object.getPrototypeOf(o);
};
return _getPrototypeOf(o);
}
module.exports = _getPrototypeOf;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/inherits.js":
/*!**************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/inherits.js ***!
\**************************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
var setPrototypeOf = __webpack_require__(/*! ./setPrototypeOf */ "../../node_modules/@babel/runtime/helpers/setPrototypeOf.js");
function _inherits(subClass, superClass) {
if (typeof superClass !== "function" && superClass !== null) {
throw new TypeError("Super expression must either be null or a function");
}
subClass.prototype = Object.create(superClass && superClass.prototype, {
constructor: {
value: subClass,
writable: true,
configurable: true
}
});
if (superClass) setPrototypeOf(subClass, superClass);
}
module.exports = _inherits;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/iterableToArray.js":
/*!*********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/iterableToArray.js ***!
\*********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _iterableToArray(iter) {
if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter);
}
module.exports = _iterableToArray;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/nonIterableSpread.js":
/*!***********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/nonIterableSpread.js ***!
\***********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _nonIterableSpread() {
throw new TypeError("Invalid attempt to spread non-iterable instance");
}
module.exports = _nonIterableSpread;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js":
/*!*******************************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/possibleConstructorReturn.js ***!
\*******************************************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
var _typeof = __webpack_require__(/*! ../helpers/typeof */ "../../node_modules/@babel/runtime/helpers/typeof.js");
var assertThisInitialized = __webpack_require__(/*! ./assertThisInitialized */ "../../node_modules/@babel/runtime/helpers/assertThisInitialized.js");
function _possibleConstructorReturn(self, call) {
if (call && (_typeof(call) === "object" || typeof call === "function")) {
return call;
}
return assertThisInitialized(self);
}
module.exports = _possibleConstructorReturn;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/setPrototypeOf.js":
/*!********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/setPrototypeOf.js ***!
\********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _setPrototypeOf(o, p) {
module.exports = _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
o.__proto__ = p;
return o;
};
return _setPrototypeOf(o, p);
}
module.exports = _setPrototypeOf;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/superPropBase.js":
/*!*******************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/superPropBase.js ***!
\*******************************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
var getPrototypeOf = __webpack_require__(/*! ./getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
function _superPropBase(object, property) {
while (!Object.prototype.hasOwnProperty.call(object, property)) {
object = getPrototypeOf(object);
if (object === null) break;
}
return object;
}
module.exports = _superPropBase;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/toConsumableArray.js":
/*!***********************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/toConsumableArray.js ***!
\***********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
var arrayWithoutHoles = __webpack_require__(/*! ./arrayWithoutHoles */ "../../node_modules/@babel/runtime/helpers/arrayWithoutHoles.js");
var iterableToArray = __webpack_require__(/*! ./iterableToArray */ "../../node_modules/@babel/runtime/helpers/iterableToArray.js");
var nonIterableSpread = __webpack_require__(/*! ./nonIterableSpread */ "../../node_modules/@babel/runtime/helpers/nonIterableSpread.js");
function _toConsumableArray(arr) {
return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();
}
module.exports = _toConsumableArray;
/***/ }),
/***/ "../../node_modules/@babel/runtime/helpers/typeof.js":
/*!************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/helpers/typeof.js ***!
\************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
function _typeof2(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof2(obj); }
function _typeof(obj) {
if (typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol") {
module.exports = _typeof = function _typeof(obj) {
return _typeof2(obj);
};
} else {
module.exports = _typeof = function _typeof(obj) {
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : _typeof2(obj);
};
}
return _typeof(obj);
}
module.exports = _typeof;
/***/ }),
/***/ "../../node_modules/@babel/runtime/regenerator/index.js":
/*!***************************************************************************!*\
!*** /Users/adomratchev/node_modules/@babel/runtime/regenerator/index.js ***!
\***************************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
module.exports = __webpack_require__(/*! regenerator-runtime */ "../../node_modules/regenerator-runtime/runtime-module.js");
/***/ }),
/***/ "../../node_modules/regenerator-runtime/runtime-module.js":
/*!*****************************************************************************!*\
!*** /Users/adomratchev/node_modules/regenerator-runtime/runtime-module.js ***!
\*****************************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
/**
* Copyright (c) 2014-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
// This method of obtaining a reference to the global object needs to be
// kept identical to the way it is obtained in runtime.js
var g = (function() {
return this || (typeof self === "object" && self);
})() || Function("return this")();
// Use `getOwnPropertyNames` because not all browsers support calling
// `hasOwnProperty` on the global `self` object in a worker. See #183.
var hadRuntime = g.regeneratorRuntime &&
Object.getOwnPropertyNames(g).indexOf("regeneratorRuntime") >= 0;
// Save the old regeneratorRuntime in case it needs to be restored later.
var oldRuntime = hadRuntime && g.regeneratorRuntime;
// Force reevalutation of runtime.js.
g.regeneratorRuntime = undefined;
module.exports = __webpack_require__(/*! ./runtime */ "../../node_modules/regenerator-runtime/runtime.js");
if (hadRuntime) {
// Restore the original runtime.
g.regeneratorRuntime = oldRuntime;
} else {
// Remove the global property added by runtime.js.
try {
delete g.regeneratorRuntime;
} catch(e) {
g.regeneratorRuntime = undefined;
}
}
/***/ }),
/***/ "../../node_modules/regenerator-runtime/runtime.js":
/*!**********************************************************************!*\
!*** /Users/adomratchev/node_modules/regenerator-runtime/runtime.js ***!
\**********************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
/**
* Copyright (c) 2014-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
!(function(global) {
"use strict";
var Op = Object.prototype;
var hasOwn = Op.hasOwnProperty;
var undefined; // More compressible than void 0.
var $Symbol = typeof Symbol === "function" ? Symbol : {};
var iteratorSymbol = $Symbol.iterator || "@@iterator";
var asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator";
var toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag";
var inModule = typeof module === "object";
var runtime = global.regeneratorRuntime;
if (runtime) {
if (inModule) {
// If regeneratorRuntime is defined globally and we're in a module,
// make the exports object identical to regeneratorRuntime.
module.exports = runtime;
}
// Don't bother evaluating the rest of this file if the runtime was
// already defined globally.
return;
}
// Define the runtime globally (as expected by generated code) as either
// module.exports (if we're in a module) or a new, empty object.
runtime = global.regeneratorRuntime = inModule ? module.exports : {};
function wrap(innerFn, outerFn, self, tryLocsList) {
// If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.
var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;
var generator = Object.create(protoGenerator.prototype);
var context = new Context(tryLocsList || []);
// The ._invoke method unifies the implementations of the .next,
// .throw, and .return methods.
generator._invoke = makeInvokeMethod(innerFn, self, context);
return generator;
}
runtime.wrap = wrap;
// Try/catch helper to minimize deoptimizations. Returns a completion
// record like context.tryEntries[i].completion. This interface could
// have been (and was previously) designed to take a closure to be
// invoked without arguments, but in all the cases we care about we
// already have an existing method we want to call, so there's no need
// to create a new function object. We can even get away with assuming
// the method takes exactly one argument, since that happens to be true
// in every case, so we don't have to touch the arguments object. The
// only additional allocation required is the completion record, which
// has a stable shape and so hopefully should be cheap to allocate.
function tryCatch(fn, obj, arg) {
try {
return { type: "normal", arg: fn.call(obj, arg) };
} catch (err) {
return { type: "throw", arg: err };
}
}
var GenStateSuspendedStart = "suspendedStart";
var GenStateSuspendedYield = "suspendedYield";
var GenStateExecuting = "executing";
var GenStateCompleted = "completed";
// Returning this object from the innerFn has the same effect as
// breaking out of the dispatch switch statement.
var ContinueSentinel = {};
// Dummy constructor functions that we use as the .constructor and
// .constructor.prototype properties for functions that return Generator
// objects. For full spec compliance, you may wish to configure your
// minifier not to mangle the names of these two functions.
function Generator() {}
function GeneratorFunction() {}
function GeneratorFunctionPrototype() {}
// This is a polyfill for %IteratorPrototype% for environments that
// don't natively support it.
var IteratorPrototype = {};
IteratorPrototype[iteratorSymbol] = function () {
return this;
};
var getProto = Object.getPrototypeOf;
var NativeIteratorPrototype = getProto && getProto(getProto(values([])));
if (NativeIteratorPrototype &&
NativeIteratorPrototype !== Op &&
hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {
// This environment has a native %IteratorPrototype%; use it instead
// of the polyfill.
IteratorPrototype = NativeIteratorPrototype;
}
var Gp = GeneratorFunctionPrototype.prototype =
Generator.prototype = Object.create(IteratorPrototype);
GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;
GeneratorFunctionPrototype.constructor = GeneratorFunction;
GeneratorFunctionPrototype[toStringTagSymbol] =
GeneratorFunction.displayName = "GeneratorFunction";
// Helper for defining the .next, .throw, and .return methods of the
// Iterator interface in terms of a single ._invoke method.
function defineIteratorMethods(prototype) {
["next", "throw", "return"].forEach(function(method) {
prototype[method] = function(arg) {
return this._invoke(method, arg);
};
});
}
runtime.isGeneratorFunction = function(genFun) {
var ctor = typeof genFun === "function" && genFun.constructor;
return ctor
? ctor === GeneratorFunction ||
// For the native GeneratorFunction constructor, the best we can
// do is to check its .name property.
(ctor.displayName || ctor.name) === "GeneratorFunction"
: false;
};
runtime.mark = function(genFun) {
if (Object.setPrototypeOf) {
Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);
} else {
genFun.__proto__ = GeneratorFunctionPrototype;
if (!(toStringTagSymbol in genFun)) {
genFun[toStringTagSymbol] = "GeneratorFunction";
}
}
genFun.prototype = Object.create(Gp);
return genFun;
};
// Within the body of any async function, `await x` is transformed to
// `yield regeneratorRuntime.awrap(x)`, so that the runtime can test
// `hasOwn.call(value, "__await")` to determine if the yielded value is
// meant to be awaited.
runtime.awrap = function(arg) {
return { __await: arg };
};
function AsyncIterator(generator) {
function invoke(method, arg, resolve, reject) {
var record = tryCatch(generator[method], generator, arg);
if (record.type === "throw") {
reject(record.arg);
} else {
var result = record.arg;
var value = result.value;
if (value &&
typeof value === "object" &&
hasOwn.call(value, "__await")) {
return Promise.resolve(value.__await).then(function(value) {
invoke("next", value, resolve, reject);
}, function(err) {
invoke("throw", err, resolve, reject);
});
}
return Promise.resolve(value).then(function(unwrapped) {
// When a yielded Promise is resolved, its final value becomes
// the .value of the Promise<{value,done}> result for the
// current iteration.
result.value = unwrapped;
resolve(result);
}, function(error) {
// If a rejected Promise was yielded, throw the rejection back
// into the async generator function so it can be handled there.
return invoke("throw", error, resolve, reject);
});
}
}
var previousPromise;
function enqueue(method, arg) {
function callInvokeWithMethodAndArg() {
return new Promise(function(resolve, reject) {
invoke(method, arg, resolve, reject);
});
}
return previousPromise =
// If enqueue has been called before, then we want to wait until
// all previous Promises have been resolved before calling invoke,
// so that results are always delivered in the correct order. If
// enqueue has not been called before, then it is important to
// call invoke immediately, without waiting on a callback to fire,
// so that the async generator function has the opportunity to do
// any necessary setup in a predictable way. This predictability
// is why the Promise constructor synchronously invokes its
// executor callback, and why async functions synchronously
// execute code before the first await. Since we implement simple
// async functions in terms of async generators, it is especially
// important to get this right, even though it requires care.
previousPromise ? previousPromise.then(
callInvokeWithMethodAndArg,
// Avoid propagating failures to Promises returned by later
// invocations of the iterator.
callInvokeWithMethodAndArg
) : callInvokeWithMethodAndArg();
}
// Define the unified helper method that is used to implement .next,
// .throw, and .return (see defineIteratorMethods).
this._invoke = enqueue;
}
defineIteratorMethods(AsyncIterator.prototype);
AsyncIterator.prototype[asyncIteratorSymbol] = function () {
return this;
};
runtime.AsyncIterator = AsyncIterator;
// Note that simple async functions are implemented on top of
// AsyncIterator objects; they just return a Promise for the value of
// the final result produced by the iterator.
runtime.async = function(innerFn, outerFn, self, tryLocsList) {
var iter = new AsyncIterator(
wrap(innerFn, outerFn, self, tryLocsList)
);
return runtime.isGeneratorFunction(outerFn)
? iter // If outerFn is a generator, return the full iterator.
: iter.next().then(function(result) {
return result.done ? result.value : iter.next();
});
};
function makeInvokeMethod(innerFn, self, context) {
var state = GenStateSuspendedStart;
return function invoke(method, arg) {
if (state === GenStateExecuting) {
throw new Error("Generator is already running");
}
if (state === GenStateCompleted) {
if (method === "throw") {
throw arg;
}
// Be forgiving, per 25.3.3.3.3 of the spec:
// https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume
return doneResult();
}
context.method = method;
context.arg = arg;
while (true) {
var delegate = context.delegate;
if (delegate) {
var delegateResult = maybeInvokeDelegate(delegate, context);
if (delegateResult) {
if (delegateResult === ContinueSentinel) continue;
return delegateResult;
}
}
if (context.method === "next") {
// Setting context._sent for legacy support of Babel's
// function.sent implementation.
context.sent = context._sent = context.arg;
} else if (context.method === "throw") {
if (state === GenStateSuspendedStart) {
state = GenStateCompleted;
throw context.arg;
}
context.dispatchException(context.arg);
} else if (context.method === "return") {
context.abrupt("return", context.arg);
}
state = GenStateExecuting;
var record = tryCatch(innerFn, self, context);
if (record.type === "normal") {
// If an exception is thrown from innerFn, we leave state ===
// GenStateExecuting and loop back for another invocation.
state = context.done
? GenStateCompleted
: GenStateSuspendedYield;
if (record.arg === ContinueSentinel) {
continue;
}
return {
value: record.arg,
done: context.done
};
} else if (record.type === "throw") {
state = GenStateCompleted;
// Dispatch the exception by looping back around to the
// context.dispatchException(context.arg) call above.
context.method = "throw";
context.arg = record.arg;
}
}
};
}
// Call delegate.iterator[context.method](context.arg) and handle the
// result, either by returning a { value, done } result from the
// delegate iterator, or by modifying context.method and context.arg,
// setting context.delegate to null, and returning the ContinueSentinel.
function maybeInvokeDelegate(delegate, context) {
var method = delegate.iterator[context.method];
if (method === undefined) {
// A .throw or .return when the delegate iterator has no .throw
// method always terminates the yield* loop.
context.delegate = null;
if (context.method === "throw") {
if (delegate.iterator.return) {
// If the delegate iterator has a return method, give it a
// chance to clean up.
context.method = "return";
context.arg = undefined;
maybeInvokeDelegate(delegate, context);
if (context.method === "throw") {
// If maybeInvokeDelegate(context) changed context.method from
// "return" to "throw", let that override the TypeError below.
return ContinueSentinel;
}
}
context.method = "throw";
context.arg = new TypeError(
"The iterator does not provide a 'throw' method");
}
return ContinueSentinel;
}
var record = tryCatch(method, delegate.iterator, context.arg);
if (record.type === "throw") {
context.method = "throw";
context.arg = record.arg;
context.delegate = null;
return ContinueSentinel;
}
var info = record.arg;
if (! info) {
context.method = "throw";
context.arg = new TypeError("iterator result is not an object");
context.delegate = null;
return ContinueSentinel;
}
if (info.done) {
// Assign the result of the finished delegate to the temporary
// variable specified by delegate.resultName (see delegateYield).
context[delegate.resultName] = info.value;
// Resume execution at the desired location (see delegateYield).
context.next = delegate.nextLoc;
// If context.method was "throw" but the delegate handled the
// exception, let the outer generator proceed normally. If
// context.method was "next", forget context.arg since it has been
// "consumed" by the delegate iterator. If context.method was
// "return", allow the original .return call to continue in the
// outer generator.
if (context.method !== "return") {
context.method = "next";
context.arg = undefined;
}
} else {
// Re-yield the result returned by the delegate method.
return info;
}
// The delegate iterator is finished, so forget it and continue with
// the outer generator.
context.delegate = null;
return ContinueSentinel;
}
// Define Generator.prototype.{next,throw,return} in terms of the
// unified ._invoke helper method.
defineIteratorMethods(Gp);
Gp[toStringTagSymbol] = "Generator";
// A Generator should always return itself as the iterator object when the
// @@iterator function is called on it. Some browsers' implementations of the
// iterator prototype chain incorrectly implement this, causing the Generator
// object to not be returned from this call. This ensures that doesn't happen.
// See https://github.com/facebook/regenerator/issues/274 for more details.
Gp[iteratorSymbol] = function() {
return this;
};
Gp.toString = function() {
return "[object Generator]";
};
function pushTryEntry(locs) {
var entry = { tryLoc: locs[0] };
if (1 in locs) {
entry.catchLoc = locs[1];
}
if (2 in locs) {
entry.finallyLoc = locs[2];
entry.afterLoc = locs[3];
}
this.tryEntries.push(entry);
}
function resetTryEntry(entry) {
var record = entry.completion || {};
record.type = "normal";
delete record.arg;
entry.completion = record;
}
function Context(tryLocsList) {
// The root entry object (effectively a try statement without a catch
// or a finally block) gives us a place to store values thrown from
// locations where there is no enclosing try statement.
this.tryEntries = [{ tryLoc: "root" }];
tryLocsList.forEach(pushTryEntry, this);
this.reset(true);
}
runtime.keys = function(object) {
var keys = [];
for (var key in object) {
keys.push(key);
}
keys.reverse();
// Rather than returning an object with a next method, we keep
// things simple and return the next function itself.
return function next() {
while (keys.length) {
var key = keys.pop();
if (key in object) {
next.value = key;
next.done = false;
return next;
}
}
// To avoid creating an additional object, we just hang the .value
// and .done properties off the next function object itself. This
// also ensures that the minifier will not anonymize the function.
next.done = true;
return next;
};
};
function values(iterable) {
if (iterable) {
var iteratorMethod = iterable[iteratorSymbol];
if (iteratorMethod) {
return iteratorMethod.call(iterable);
}
if (typeof iterable.next === "function") {
return iterable;
}
if (!isNaN(iterable.length)) {
var i = -1, next = function next() {
while (++i < iterable.length) {
if (hasOwn.call(iterable, i)) {
next.value = iterable[i];
next.done = false;
return next;
}
}
next.value = undefined;
next.done = true;
return next;
};
return next.next = next;
}
}
// Return an iterator with no values.
return { next: doneResult };
}
runtime.values = values;
function doneResult() {
return { value: undefined, done: true };
}
Context.prototype = {
constructor: Context,
reset: function(skipTempReset) {
this.prev = 0;
this.next = 0;
// Resetting context._sent for legacy support of Babel's
// function.sent implementation.
this.sent = this._sent = undefined;
this.done = false;
this.delegate = null;
this.method = "next";
this.arg = undefined;
this.tryEntries.forEach(resetTryEntry);
if (!skipTempReset) {
for (var name in this) {
// Not sure about the optimal order of these conditions:
if (name.charAt(0) === "t" &&
hasOwn.call(this, name) &&
!isNaN(+name.slice(1))) {
this[name] = undefined;
}
}
}
},
stop: function() {
this.done = true;
var rootEntry = this.tryEntries[0];
var rootRecord = rootEntry.completion;
if (rootRecord.type === "throw") {
throw rootRecord.arg;
}
return this.rval;
},
dispatchException: function(exception) {
if (this.done) {
throw exception;
}
var context = this;
function handle(loc, caught) {
record.type = "throw";
record.arg = exception;
context.next = loc;
if (caught) {
// If the dispatched exception was caught by a catch block,
// then let that catch block handle the exception normally.
context.method = "next";
context.arg = undefined;
}
return !! caught;
}
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
var entry = this.tryEntries[i];
var record = entry.completion;
if (entry.tryLoc === "root") {
// Exception thrown outside of any try block that could handle
// it, so set the completion value of the entire function to
// throw the exception.
return handle("end");
}
if (entry.tryLoc <= this.prev) {
var hasCatch = hasOwn.call(entry, "catchLoc");
var hasFinally = hasOwn.call(entry, "finallyLoc");
if (hasCatch && hasFinally) {
if (this.prev < entry.catchLoc) {
return handle(entry.catchLoc, true);
} else if (this.prev < entry.finallyLoc) {
return handle(entry.finallyLoc);
}
} else if (hasCatch) {
if (this.prev < entry.catchLoc) {
return handle(entry.catchLoc, true);
}
} else if (hasFinally) {
if (this.prev < entry.finallyLoc) {
return handle(entry.finallyLoc);
}
} else {
throw new Error("try statement without catch or finally");
}
}
}
},
abrupt: function(type, arg) {
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
var entry = this.tryEntries[i];
if (entry.tryLoc <= this.prev &&
hasOwn.call(entry, "finallyLoc") &&
this.prev < entry.finallyLoc) {
var finallyEntry = entry;
break;
}
}
if (finallyEntry &&
(type === "break" ||
type === "continue") &&
finallyEntry.tryLoc <= arg &&
arg <= finallyEntry.finallyLoc) {
// Ignore the finally entry if control is not jumping to a
// location outside the try/catch block.
finallyEntry = null;
}
var record = finallyEntry ? finallyEntry.completion : {};
record.type = type;
record.arg = arg;
if (finallyEntry) {
this.method = "next";
this.next = finallyEntry.finallyLoc;
return ContinueSentinel;
}
return this.complete(record);
},
complete: function(record, afterLoc) {
if (record.type === "throw") {
throw record.arg;
}
if (record.type === "break" ||
record.type === "continue") {
this.next = record.arg;
} else if (record.type === "return") {
this.rval = this.arg = record.arg;
this.method = "return";
this.next = "end";
} else if (record.type === "normal" && afterLoc) {
this.next = afterLoc;
}
return ContinueSentinel;
},
finish: function(finallyLoc) {
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
var entry = this.tryEntries[i];
if (entry.finallyLoc === finallyLoc) {
this.complete(entry.completion, entry.afterLoc);
resetTryEntry(entry);
return ContinueSentinel;
}
}
},
"catch": function(tryLoc) {
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
var entry = this.tryEntries[i];
if (entry.tryLoc === tryLoc) {
var record = entry.completion;
if (record.type === "throw") {
var thrown = record.arg;
resetTryEntry(entry);
}
return thrown;
}
}
// The context.catch method must only be called with a location
// argument that corresponds to a known catch block.
throw new Error("illegal catch attempt");
},
delegateYield: function(iterable, resultName, nextLoc) {
this.delegate = {
iterator: values(iterable),
resultName: resultName,
nextLoc: nextLoc
};
if (this.method === "next") {
// Deliberately forget the last sent value so that we don't
// accidentally pass it on to the delegate.
this.arg = undefined;
}
return ContinueSentinel;
}
};
})(
// In sloppy mode, unbound `this` refers to the global object, fallback to
// Function constructor if we're in global strict mode. That is sadly a form
// of indirect eval which violates Content Security Policy.
(function() {
return this || (typeof self === "object" && self);
})() || Function("return this")()
);
/***/ }),
/***/ "./node_modules/webpack/buildin/global.js":
/*!***********************************!*\
!*** (webpack)/buildin/global.js ***!
\***********************************/
/*! no static exports found */
/***/ (function(module, exports) {
var g;
// This works in non-strict mode
g = (function() {
return this;
})();
try {
// This works if eval is allowed (see CSP)
g = g || new Function("return this")();
} catch (e) {
// This works if the window reference is available
if (typeof window === "object") g = window;
}
// g can still be undefined, but nothing to do about it...
// We return undefined, instead of nothing here, so it's
// easier to handle this case. if(!global) { ...}
module.exports = g;
/***/ }),
/***/ "./src/analytics/result-collector.ts":
/*!*******************************************!*\
!*** ./src/analytics/result-collector.ts ***!
\*******************************************/
/*! exports provided: ResultCollector */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResultCollector", function() { return ResultCollector; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _common_image_debug__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../common/image-debug */ "./src/common/image-debug.ts");
var ResultCollector =
/*#__PURE__*/
function () {
function ResultCollector(config) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, ResultCollector);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_canvas", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_context", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_config", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_capacity", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_capture", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_results", void 0);
this._results = new Array();
this._config = config;
this._capacity = config.capacity || 20;
this._capture = config.capture === true;
if (this._capture) {
this._canvas = document.createElement('canvas');
this._context = this._canvas.getContext('2d');
}
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(ResultCollector, [{
key: "addResult",
value: function addResult(data, imageWidth, imageHeight, codeResult) {
if (codeResult && this._capacity && !this._contains(codeResult) && this._passesFilter(codeResult)) {
var result = {
codeResult: codeResult
};
this._capacity--;
if (this._capture) {
this._canvas.width = imageWidth;
this._canvas.height = imageHeight;
_common_image_debug__WEBPACK_IMPORTED_MODULE_3__["ImageDebug"].drawImage(data, imageWidth, imageHeight, this._context);
result.frame = this._canvas.toDataURL();
}
this._results.push(result);
}
}
}, {
key: "getResults",
value: function getResults() {
return this._results;
}
}, {
key: "_contains",
value: function _contains(codeResult) {
return this._config.blacklist && this._config.blacklist.some(function (item) {
return Object.keys(item).every(function (key) {
return item[key] === codeResult[key];
});
});
}
}, {
key: "_passesFilter",
value: function _passesFilter(codeResult) {
return typeof this._config.filter !== 'function' || this._config.filter(codeResult);
}
}]);
return ResultCollector;
}();
/***/ }),
/***/ "./src/common/cluster.ts":
/*!*******************************!*\
!*** ./src/common/cluster.ts ***!
\*******************************/
/*! exports provided: Cluster */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Cluster", function() { return Cluster; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
/**
* Creates a cluster for grouping similar orientations of moments
*/
var Cluster =
/*#__PURE__*/
function () {
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Cluster, null, [{
key: "clusterize",
value: function clusterize(moments, threshold) {
var clusters = new Array();
moments.forEach(function (moment) {
var matchingCluster = clusters.find(function (cluster) {
return cluster.fits(moment);
});
if (matchingCluster) {
matchingCluster.add(moment);
} else {
clusters.push(new Cluster(threshold, moment));
}
});
return clusters;
}
}]);
function Cluster(threshold, moment) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Cluster);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_threshold", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_moments", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_center", void 0);
this._threshold = threshold;
this._moments = new Array();
this._center = {
rad: 0,
x: 0,
y: 0
};
if (moment) {
this.add(moment);
}
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Cluster, [{
key: "add",
value: function add(point) {
this._moments.push(point); // Update center
this._center.rad = this._moments.reduce(function (sum, p) {
return sum + p.rad;
}, 0) / this._moments.length;
this._center.x = Math.cos(this._center.rad);
this._center.y = Math.sin(this._center.rad);
}
}, {
key: "fits",
value: function fits(moment) {
// check cosine similarity to center-angle
var similarity = Math.abs(moment.x * this._center.x + moment.y * this._center.y);
return similarity > this._threshold;
}
}, {
key: "moments",
get: function get() {
return this._moments;
}
}]);
return Cluster;
}();
/***/ }),
/***/ "./src/common/events.ts":
/*!******************************!*\
!*** ./src/common/events.ts ***!
\******************************/
/*! exports provided: Events */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return Events; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
var events = {};
var Events =
/*#__PURE__*/
function () {
function Events() {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Events);
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Events, null, [{
key: "subscribe",
value: 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).subscriptions.push(subscription);
}
}, {
key: "publish",
value: function publish(type, data) {
var eventItem = getEvent(type);
var subscriptions = eventItem.subscriptions; // Publish one-time subscriptions
subscriptions.filter(function (_ref) {
var once = _ref.once;
return !!once;
}).forEach(function (subscription) {
return publishSubscription(subscription, data);
}); // remove them from the subscription
eventItem.subscriptions = subscriptions.filter(function (_ref2) {
var once = _ref2.once;
return !once;
}); // publish the rest
eventItem.subscriptions.forEach(function (subscription) {
return publishSubscription(subscription, data);
});
}
}, {
key: "once",
value: function once(event, callback, async) {
Events.subscribe(event, {
callback: callback,
async: async,
once: true
});
}
}, {
key: "unsubscribe",
value: function unsubscribe(eventName, callback) {
if (eventName) {
var event = getEvent(eventName);
if (event && callback) {
event.subscriptions = event.subscriptions.filter(function (subscription) {
return subscription.callback !== callback;
});
} else {
event.subscriptions = [];
}
} else {
events = {};
}
}
}]);
return Events;
}();
function getEvent(eventName) {
if (!events[eventName]) {
events[eventName] = {
subscriptions: []
};
}
return events[eventName];
}
function publishSubscription(subscription, data) {
if (subscription.async) {
setTimeout(function () {
subscription.callback(data);
}, 4);
} else {
subscription.callback(data);
}
}
/***/ }),
/***/ "./src/common/hsv2rgb.ts":
/*!*******************************!*\
!*** ./src/common/hsv2rgb.ts ***!
\*******************************/
/*! exports provided: hsv2rgb */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hsv2rgb", function() { return hsv2rgb; });
function hsv2rgb(hsv, rgb) {
var h = hsv[0];
var s = hsv[1];
var v = hsv[2];
var c = v * s;
var x = c * (1 - Math.abs(h / 60 % 2 - 1));
var m = v - c;
var r = 0;
var g = 0;
var b = 0;
if (h < 60) {
r = c;
g = x;
} else if (h < 120) {
r = x;
g = c;
} else if (h < 180) {
g = c;
b = x;
} else if (h < 240) {
g = x;
b = c;
} else if (h < 300) {
r = x;
b = c;
} else if (h < 360) {
r = c;
b = x;
}
rgb = rgb || [0, 0, 0];
rgb[0] = (r + m) * 255 | 0;
rgb[1] = (g + m) * 255 | 0;
rgb[2] = (b + m) * 255 | 0;
return rgb;
}
/***/ }),
/***/ "./src/common/image-debug.ts":
/*!***********************************!*\
!*** ./src/common/image-debug.ts ***!
\***********************************/
/*! exports provided: ImageDebug */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ImageDebug", function() { return ImageDebug; });
var ImageDebug = {
drawPath: function drawPath(path, context, color, lineWidth) {
if (path && path.length > 1) {
context.strokeStyle = color;
context.fillStyle = color;
context.lineWidth = lineWidth;
context.beginPath();
context.moveTo(path[0].x, path[0].y);
path.slice(1).forEach(function (_ref) {
var x = _ref.x,
y = _ref.y;
return context.lineTo(x, y);
});
context.closePath();
context.stroke();
}
},
drawImage: function drawImage(imageData, width, height, context) {
var canvasData = context.getImageData(0, 0, width, height);
var data = canvasData.data;
var imageIndex = imageData.length | 0;
var canvasIndex = data.length | 0;
if (canvasIndex / imageIndex !== 4) {
return false;
}
while (imageIndex--) {
var value = imageData[imageIndex];
data[--canvasIndex] = 255;
data[--canvasIndex] = value;
data[--canvasIndex] = value;
data[--canvasIndex] = value;
}
context.putImageData(canvasData, 0, 0);
return true;
}
};
/***/ }),
/***/ "./src/common/image-wrapper.ts":
/*!*************************************!*\
!*** ./src/common/image-wrapper.ts ***!
\*************************************/
/*! exports provided: ImageWrapper */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ImageWrapper", function() { return ImageWrapper; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _hsv2rgb__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./hsv2rgb */ "./src/common/hsv2rgb.ts");
/**
* Represents a basic image combining the data and size.
* In addition, some methods for manipulation are contained.
*/
var ImageWrapper =
/*#__PURE__*/
function () {
/**
* @param size The size of the image in pixel
* @param data If given, a flat array containing the pixel data
* @param arrayType If given, the desired DataType of the Array (may be typed/non-typed)
* @param initialize Indicating if the array should be initialized on creation.
*/
function ImageWrapper(size, data, arrayType, initialize) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, ImageWrapper);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "data", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "size", void 0);
if (!data) {
this.data = new (arrayType || Uint8Array)(size.x * size.y);
if (initialize) {
this.data.fill(0);
}
} else {
this.data = data;
}
this.size = size;
}
/**
* Tests if a position is within the image with a given offset
* @param point The location to test
* @param border The padding value in pixels
* @returns true if location inside the image's border, false otherwise
* @see cvd/image.h
*/
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(ImageWrapper, [{
key: "inImageWithBorder",
value: function inImageWithBorder(point, border) {
return point.x >= border && point.y >= border && point.x < this.size.x - border && point.y < this.size.y - border;
}
/**
* Creates an {ImageWrapper) and copies the needed underlying image-data area
* @param imageWrapper The target {ImageWrapper} where the data should be copied
* @param fromX The horizontal position where to copy from
* @param fromY The vertical position where to copy from
*/
}, {
key: "subImageAsCopy",
value: function subImageAsCopy(imageWrapper, fromX, fromY) {
var sizeY = imageWrapper.size.y;
var sizeX = imageWrapper.size.x;
for (var x = 0; x < sizeX; x++) {
for (var y = 0; y < sizeY; y++) {
imageWrapper.data[y * sizeX + x] = this.data[(fromY + y) * this.size.x + fromX + x];
}
}
}
/**
* Retrieves a given pixel position from the image
* @param x The x-position
* @param y The y-position
* @returns The grayscale value at the pixel-position
*/
}, {
key: "get",
value: function get(x, y) {
return this.data[y * this.size.x + x];
}
/**
* Sets a given pixel position in the image
* @param x The x-position
* @param y The y-position
* @param value The grayscale value to set
* @returns The Image itself (for possible chaining)
*/
}, {
key: "set",
value: function set(x, y, value) {
this.data[y * this.size.x + x] = value;
return this;
}
/**
* Sets the border of the image (1 pixel) to zero
*/
}, {
key: "zeroBorder",
value: function zeroBorder() {
var width = this.size.x;
var height = this.size.y;
var data = this.data;
for (var i = 0; i < width; i++) {
data[i] = data[(height - 1) * width + i] = 0;
}
for (var _i = 1; _i < height - 1; _i++) {
data[_i * width] = data[_i * width + (width - 1)] = 0;
}
}
/**
* Inverts a binary image in place
*/
}, {
key: "invert",
value: function invert() {
var data = this.data;
for (var i = data.length; i--;) {
data[i] = data[i] ? 0 : 1;
}
}
}, {
key: "moments",
value: function moments(labelCount) {
var height = this.size.y;
var width = this.size.x;
var labelSum = new Array();
var result = new Array();
if (labelCount <= 0) {
return result;
}
for (var i = 0; i < labelCount; i++) {
labelSum[i] = {
m00: 0,
m01: 0,
m10: 0,
m11: 0,
m02: 0,
m20: 0,
theta: 0,
rad: 0
};
}
for (var y = 0; y < height; y++) {
var ysq = y * y;
for (var x = 0; x < width; x++) {
var val = this.data[y * width + x];
if (val > 0) {
var label = labelSum[val - 1];
label.m00 += 1;
label.m01 += y;
label.m10 += x;
label.m11 += x * y;
label.m02 += ysq;
label.m20 += x * x;
}
}
}
var PI = Math.PI;
var PI_4 = PI / 4;
for (var _i2 = 0; _i2 < labelCount; _i2++) {
var _label = labelSum[_i2];
if (!isNaN(_label.m00) && _label.m00 !== 0) {
var x_ = _label.m10 / _label.m00;
var y_ = _label.m01 / _label.m00;
var mu11 = _label.m11 / _label.m00 - x_ * y_;
var mu02 = _label.m02 / _label.m00 - y_ * y_;
var mu20 = _label.m20 / _label.m00 - x_ * x_;
var tmp = 0.5 * Math.atan((mu02 - mu20) / (2 * mu11)) + (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.x = Math.cos(tmp);
_label.y = Math.sin(tmp);
result.push(_label);
}
}
return result;
}
/**
* Displays the {ImageWrapper} in a given canvas
* @param context The rendering context to write to
* @param scale Scale which is applied to each pixel-value
*/
}, {
key: "show",
value: function show(context, scale) {
var height = this.size.y;
var width = this.size.x; // const context = canvas.getContext('2d');
// canvas.height = height;
// canvas.width = width;
var frame = context.getImageData(0, 0, width, height);
var data = frame.data;
var current = 0;
if (!scale) {
scale = 1.0;
}
for (var y = 0; y < height; y++) {
for (var x = 0; x < width; x++) {
var pixel = y * width + 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;
context.putImageData(frame, 0, 0);
}
/**
* Displays the part of the image in a given canvas
* @param context The rendering context to write to
* @param scale Scale which is applied to each pixel-value
* @param fromX The horizontal position where to overlay from
* @param fromY The vertical position where to overlay from
*/
}, {
key: "overlay",
value: function overlay(context, scale, fromX, fromY) {
var hsv = [0, 1, 1];
var whiteRgb = [255, 255, 255];
var blackRgb = [0, 0, 0];
var frame = context.getImageData(fromX, fromY, this.size.x, this.size.y);
var data = frame.data;
if (!scale || scale < 0 || scale > 360) {
scale = 360;
}
for (var length = this.data.length; length--;) {
hsv[0] = this.data[length] * scale;
var rgb = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : Object(_hsv2rgb__WEBPACK_IMPORTED_MODULE_3__["hsv2rgb"])(hsv);
data[length * 4 + 0] = rgb[0];
data[length * 4 + 1] = rgb[1];
data[length * 4 + 2] = rgb[2];
data[length * 4 + 3] = 255;
}
context.putImageData(frame, fromX, fromY);
}
}]);
return ImageWrapper;
}();
/***/ }),
/***/ "./src/common/media-devices.ts":
/*!*************************************!*\
!*** ./src/common/media-devices.ts ***!
\*************************************/
/*! exports provided: enumerateDevices, getUserMedia */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "enumerateDevices", function() { return enumerateDevices; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getUserMedia", function() { return getUserMedia; });
function enumerateDevices() {
if (navigator.mediaDevices && typeof navigator.mediaDevices.enumerateDevices === 'function') {
return navigator.mediaDevices.enumerateDevices();
}
return Promise.reject(new Error('enumerateDevices is not defined'));
}
function getUserMedia(constraints) {
if (navigator.mediaDevices && typeof navigator.mediaDevices.getUserMedia === 'function') {
return navigator.mediaDevices.getUserMedia(constraints);
}
return Promise.reject(new Error('getUserMedia is not defined'));
}
/***/ }),
/***/ "./src/common/merge.ts":
/*!*****************************!*\
!*** ./src/common/merge.ts ***!
\*****************************/
/*! exports provided: merge */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "merge", function() { return merge; });
/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "../../node_modules/@babel/runtime/helpers/typeof.js");
/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__);
/**
* Performs a deep merge of objects and returns new object.
* Does not modify objects (immutable).
* @see https://stackoverflow.com/a/48218209
*
* @param objects - Objects to merge
* @returns New object with merged key/values
*/
function merge() {
var isObject = function isObject(obj) {
return obj && _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(obj) === 'object';
};
for (var _len = arguments.length, objects = new Array(_len), _key = 0; _key < _len; _key++) {
objects[_key] = arguments[_key];
}
return objects.reduce(function (prev, obj) {
if (obj) {
Object.keys(obj).forEach(function (key) {
var pVal = prev[key];
var oVal = obj[key];
if (Array.isArray(pVal) && Array.isArray(oVal)) {
// prev[key] = pVal.concat(...oVal);
prev[key] = oVal;
} else if (isObject(pVal) && isObject(oVal)) {
prev[key] = merge(pVal, oVal);
} else {
prev[key] = oVal;
}
});
}
return prev;
}, {});
}
/***/ }),
/***/ "./src/config/config.dev.ts":
/*!**********************************!*\
!*** ./src/config/config.dev.ts ***!
\**********************************/
/*! exports provided: config */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "config", function() { return config; });
var config = {
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
}
}
}
};
/***/ }),
/***/ "./src/decoder/barcode-decoder.ts":
/*!****************************************!*\
!*** ./src/decoder/barcode-decoder.ts ***!
\****************************************/
/*! exports provided: BarcodeDecoder */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BarcodeDecoder", function() { return BarcodeDecoder; });
/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ "../../node_modules/@babel/runtime/helpers/toConsumableArray.js");
/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "../../node_modules/@babel/runtime/helpers/typeof.js");
/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _reader_index__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../reader/index */ "./src/reader/index.ts");
/* harmony import */ var _bresenham__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./bresenham */ "./src/decoder/bresenham.ts");
/* harmony import */ var _common_image_debug__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../common/image-debug */ "./src/common/image-debug.ts");
;
var BarcodeDecoder =
/*#__PURE__*/
function () {
function BarcodeDecoder(config, inputImageWrapper) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_2___default()(this, BarcodeDecoder);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4___default()(this, "_config", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4___default()(this, "_inputImageWrapper", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4___default()(this, "_frequencyCanvas", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4___default()(this, "_patternCanvas", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4___default()(this, "_overlayContext", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_4___default()(this, "_barcodeReaders", void 0);
this._config = config;
this._inputImageWrapper = inputImageWrapper;
this._barcodeReaders = [];
if ( true && this._config.debug && typeof document !== 'undefined') {
var debugDiv = document.querySelector('#debug.detection');
this._frequencyCanvas = document.querySelector('canvas.frequency');
if (!this._frequencyCanvas) {
this._frequencyCanvas = document.createElement('canvas');
this._frequencyCanvas.className = 'frequency';
if (debugDiv) {
debugDiv.appendChild(this._frequencyCanvas);
}
}
this._frequencyCanvas.style.display = this._config.debug.showFrequency ? 'block' : 'none';
this._patternCanvas = document.querySelector('canvas.patternBuffer');
if (!this._patternCanvas) {
this._patternCanvas = document.createElement('canvas');
this._patternCanvas.className = 'patternBuffer';
if (debugDiv) {
debugDiv.appendChild(this._patternCanvas);
}
}
this._patternCanvas.style.display = this._config.debug.showPattern ? 'block' : 'none';
var overlayCanvas = document.querySelector('canvas.drawingBuffer');
this._overlayContext = overlayCanvas ? overlayCanvas.getContext('2d') : null;
}
this._initReaders();
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3___default()(BarcodeDecoder, [{
key: "decodeFromBoundingBoxes",
value: function decodeFromBoundingBoxes(boxes) {
var _this = this;
var barcode = null;
if (boxes) {
if (this._config.multiple) {
var barcodes = boxes.map(function (box) {
return _this.decodeFromBoundingBox(box);
});
return {
barcodes: barcodes,
boxes: boxes
};
}
if (boxes.some(function (box) {
return !!(barcode = _this.decodeFromBoundingBox(box));
})) {
barcode.boxes = boxes;
}
}
return barcode;
}
/**
* With the help of the configured readers this function tries to detect
* a valid barcode pattern within the given area.
* @param box The area to search in
* @returns The result {codeResult, line, angle, pattern, threshold}
*/
}, {
key: "decodeFromBoundingBox",
value: function decodeFromBoundingBox(box) {
var debug = true && this._overlayContext && this._config.debug;
if (debug && debug.drawBoundingBox) {
this._drawPath(box, 'blue', 2);
}
var line = this._getLine(box);
if (line === null) {
return null;
}
var angle = Math.atan2(line[1].y - line[0].y, line[1].x - line[0].x);
line = this._getExtendedLine(line, angle);
var result = this._tryDecode(line);
if (result === null) {
result = this._tryDecodeBruteForce(box, line, angle);
}
if (result === null) {
return null;
}
if (debug && debug.drawScanline) {
this._drawPath(line, 'red', 3);
}
return {
angle: angle,
box: box,
codeResult: result.codeResult,
line: line,
pattern: result.barcodeLine.line,
threshold: result.barcodeLine.threshold
};
}
}, {
key: "setReaders",
value: function setReaders(readers) {
this._config.readers = readers;
this._barcodeReaders.length = 0;
this._initReaders();
}
}, {
key: "_initReaders",
value: function _initReaders() {
var _this2 = this;
this._config.readers.forEach(function (readerConfig) {
var reader;
var configuration = {};
var supplements = [];
if (_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_1___default()(readerConfig) === 'object') {
reader = readerConfig.format;
configuration = readerConfig.config || {};
} else if (typeof readerConfig === 'string') {
reader = readerConfig;
}
if (true) {
console.log('Before registering reader:', reader);
}
if (configuration.supplements) {
supplements = configuration.supplements.map(function (supplement) {
return new _reader_index__WEBPACK_IMPORTED_MODULE_5__["Readers"][supplement]();
});
}
_this2._barcodeReaders.push(new _reader_index__WEBPACK_IMPORTED_MODULE_5__["Readers"][reader](configuration, supplements));
});
if (true) {
var _console;
(_console = console).log.apply(_console, ['Registered Readers:'].concat(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_0___default()(this._barcodeReaders.map(function (_ref) {
var config = _ref.config,
FORMAT = _ref.FORMAT;
return JSON.stringify({
config: config,
FORMAT: FORMAT
});
}))));
}
}
/**
* extend the line on both ends
* @param line
* @param angle
*/
}, {
key: "_getExtendedLine",
value: function _getExtendedLine(line, angle) {
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;
}
var lineLength = Math.sqrt(Math.pow(line[1].y - line[0].y, 2) + Math.pow(line[1].x - line[0].x, 2));
var extensionLength = lineLength * 0.1 | 0;
extendLine(extensionLength); // check if inside image
while (extensionLength > 1 && (!this._inputImageWrapper.inImageWithBorder(line[0], 0) || !this._inputImageWrapper.inImageWithBorder(line[1], 0))) {
extensionLength >>= 1;
extendLine(-extensionLength);
}
return line;
}
}, {
key: "_getLine",
value: function _getLine(box) {
return [{
x: (box[1].x + box[0].x) / 2,
y: (box[1].y + box[0].y) / 2
}, {
x: (box[3].x + box[2].x) / 2,
y: (box[3].y + box[2].y) / 2
}];
}
}, {
key: "_tryDecode",
value: function _tryDecode(line) {
var debug = true && this._config.debug;
if (debug && this._overlayContext) {
this._drawPath(line, 'red', 3);
}
var barcodeLine = _bresenham__WEBPACK_IMPORTED_MODULE_6__["Bresenham"].getBarcodeLine(this._inputImageWrapper, line[0], line[1]);
if (debug && debug.showFrequency) {
this._printFrequency(barcodeLine.line);
}
barcodeLine = _bresenham__WEBPACK_IMPORTED_MODULE_6__["Bresenham"].toBinaryLine(barcodeLine);
if (debug && debug.showPattern) {
this._printPattern(barcodeLine.line);
}
var codeResult = null;
this._barcodeReaders.some(function (reader) {
return !!(codeResult = reader.decodePattern(barcodeLine.line));
});
return codeResult ? {
codeResult: codeResult,
barcodeLine: barcodeLine
} : null;
}
/**
* 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 box
* @param line
* @param lineAngle
*/
}, {
key: "_tryDecodeBruteForce",
value: function _tryDecodeBruteForce(box, line, lineAngle) {
var sideLength = Math.sqrt(Math.pow(box[1].x - box[0].x, 2) + Math.pow(box[1].y - box[0].y, 2));
var slices = 16;
var xdir = Math.sin(lineAngle);
var ydir = Math.cos(lineAngle);
for (var i = 1; i < slices; i++) {
// move line perpendicular to angle
var dir = sideLength / slices * i * (i % 2 === 0 ? -1 : 1);
line[0].y += dir * xdir;
line[0].x -= dir * ydir;
line[1].y += dir * xdir;
line[1].x -= dir * ydir;
var result = this._tryDecode(line);
if (result) {
return result;
}
}
return null;
}
/**
* Used for development only
*/
}, {
key: "_printFrequency",
value: function _printFrequency(line) {
var context = this._frequencyCanvas.getContext('2d');
this._frequencyCanvas.width = line.length;
this._frequencyCanvas.height = 256;
context.beginPath();
context.strokeStyle = 'blue';
for (var i = 0; i < line.length; i++) {
context.moveTo(i, 255);
context.lineTo(i, 255 - line[i]);
}
context.closePath();
context.stroke();
}
/**
* Used for development only
*/
}, {
key: "_printPattern",
value: function _printPattern(line) {
var context = this._patternCanvas.getContext('2d');
this._patternCanvas.width = line.length;
context.fillStyle = 'black';
for (var i = 0; i < line.length; i++) {
if (line[i] === 1) {
context.fillRect(i, 0, 1, 100);
}
}
}
}, {
key: "_drawPath",
value: function _drawPath(path, color, lineWidth) {
_common_image_debug__WEBPACK_IMPORTED_MODULE_7__["ImageDebug"].drawPath(path, this._overlayContext, color, lineWidth);
}
}]);
return BarcodeDecoder;
}();
/***/ }),
/***/ "./src/decoder/bresenham.ts":
/*!**********************************!*\
!*** ./src/decoder/bresenham.ts ***!
\**********************************/
/*! exports provided: Bresenham */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Bresenham", function() { return Bresenham; });
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__);
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var Slope;
(function (Slope) {
Slope[Slope["Up"] = 1] = "Up";
Slope[Slope["Down"] = -1] = "Down";
})(Slope || (Slope = {}));
;
var Bresenham = {
/**
* 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 imageWrapper
* @param p1 The start point {x,y}
* @param p2 The end point {x,y}
* @returns {line, min, max}
*/
getBarcodeLine: function getBarcodeLine(imageWrapper, p1, p2) {
var x0 = p1.x | 0;
var y0 = p1.y | 0;
var x1 = p2.x | 0;
var y1 = p2.y | 0;
var steep = Math.abs(y1 - y0) > Math.abs(x1 - x0);
var tmp;
var line = [];
var imageData = imageWrapper.data;
var width = imageWrapper.size.x;
var val;
var min = 255;
var max = 0;
function read(a, b) {
val = imageData[b * width + a];
min = val < min ? val : min;
max = val > max ? val : max;
line.push(val);
}
if (steep) {
tmp = x0;
x0 = y0;
y0 = tmp;
tmp = x1;
x1 = y1;
y1 = tmp;
}
if (x0 > x1) {
tmp = x0;
x0 = x1;
x1 = tmp;
tmp = y0;
y0 = y1;
y1 = tmp;
}
var deltax = x1 - x0;
var deltay = Math.abs(y1 - y0);
var error = deltax / 2 | 0;
var y = y0;
var ystep = y0 < y1 ? 1 : -1;
for (var x = x0; x < x1; x++) {
if (steep) {
read(y, x);
} else {
read(x, y);
}
error = error - deltay;
if (error < 0) {
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 result {line, min, max}
*/
toBinaryLine: function toBinaryLine(result) {
var min = result.min;
var max = result.max;
var line = result.line;
var center = min + (max - min) / 2;
var extrema = new Array();
var threshold = (max - min) / 12;
var rThreshold = -threshold; // 1. find extrema
var currentDir = line[0] > center ? Slope.Up : Slope.Down;
extrema.push({
pos: 0,
val: line[0]
});
for (var i = 0; i < line.length - 2; i++) {
var slope = line[i + 1] - line[i];
var slope2 = line[i + 2] - line[i + 1];
var dir = void 0;
if (slope + slope2 < rThreshold && line[i + 1] < center * 1.5) {
dir = Slope.Down;
} else if (slope + slope2 > threshold && line[i + 1] > center * 0.5) {
dir = Slope.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 (var 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 (var _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 (var _j = extrema[_i].pos; _j < extrema[_i + 1].pos; _j++) {
line[_j] = line[_j] > threshold ? 0 : 1;
}
}
return _objectSpread({}, result, {
threshold: threshold
});
}
};
/***/ }),
/***/ "./src/input/camera-access.ts":
/*!************************************!*\
!*** ./src/input/camera-access.ts ***!
\************************************/
/*! exports provided: CameraAccess */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CameraAccess", function() { return CameraAccess; });
/* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/regenerator */ "../../node_modules/@babel/runtime/regenerator/index.js");
/* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ "../../node_modules/@babel/runtime/helpers/asyncToGenerator.js");
/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _common_media_devices__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../common/media-devices */ "./src/common/media-devices.ts");
var _stream;
var CameraAccess = {
/**
* Attempts to attach the camera-stream to a given video element
* and calls the callback function when the content is ready
* @param video
* @param videoConstraints
*/
request: function () {
var _request = _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default()(
/*#__PURE__*/
_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.mark(function _callee(video, videoConstraints) {
var normalizedConstraints;
return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
normalizedConstraints = CameraAccess.pickConstraints(videoConstraints);
_context.next = 3;
return Object(_common_media_devices__WEBPACK_IMPORTED_MODULE_2__["getUserMedia"])(normalizedConstraints);
case 3:
_stream = _context.sent;
video.srcObject = _stream;
video.setAttribute('autoplay', '');
video.setAttribute('muted', '');
video.setAttribute('playsinline', '');
return _context.abrupt("return", new Promise(function (resolve) {
return video.addEventListener('loadedmetadata', function () {
video.play();
resolve();
});
}).then(_waitForVideo.bind(null, video)));
case 9:
case "end":
return _context.stop();
}
}
}, _callee);
}));
function request(_x, _x2) {
return _request.apply(this, arguments);
}
return request;
}(),
release: function release() {
var tracks = _stream && _stream.getVideoTracks();
if (tracks && tracks.length) {
tracks[0].stop();
}
_stream = null;
},
enumerateVideoDevices: function () {
var _enumerateVideoDevices = _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default()(
/*#__PURE__*/
_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.mark(function _callee2() {
var devices;
return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
_context2.next = 2;
return Object(_common_media_devices__WEBPACK_IMPORTED_MODULE_2__["enumerateDevices"])();
case 2:
devices = _context2.sent;
return _context2.abrupt("return", devices.filter(function (_ref) {
var kind = _ref.kind;
return kind === 'videoinput';
}));
case 4:
case "end":
return _context2.stop();
}
}
}, _callee2);
}));
function enumerateVideoDevices() {
return _enumerateVideoDevices.apply(this, arguments);
}
return enumerateVideoDevices;
}(),
getActiveStreamLabel: function getActiveStreamLabel() {
var track = CameraAccess.getActiveTrack();
return track ? track.label : '';
},
getActiveTrack: function getActiveTrack() {
var tracks = _stream && _stream.getVideoTracks();
if (tracks && tracks.length) {
return tracks[0];
}
return null;
},
pickConstraints: function pickConstraints(videoConstraints) {
var width = videoConstraints.width,
height = videoConstraints.height,
facingMode = videoConstraints.facingMode,
aspectRatio = videoConstraints.aspectRatio,
deviceId = videoConstraints.deviceId;
var _ref2 = videoConstraints,
minAspectRatio = _ref2.minAspectRatio,
facing = _ref2.facing;
if (typeof minAspectRatio !== 'undefined' && minAspectRatio > 0) {
aspectRatio = minAspectRatio;
console.log("WARNING: Constraint 'minAspectRatio' is deprecated; Use 'aspectRatio' instead");
}
if (typeof facing !== 'undefined') {
facingMode = facing;
console.log("WARNING: Constraint 'facing' is deprecated. Use 'facingMode' instead'");
}
var normalizedConstraints = deviceId && facingMode ? {
width: width,
height: height,
aspectRatio: aspectRatio,
deviceId: deviceId
} : {
width: width,
height: height,
facingMode: facingMode,
aspectRatio: aspectRatio,
deviceId: deviceId
};
return {
audio: false,
video: normalizedConstraints
};
}
};
function _waitForVideo(_ref3) {
var videoWidth = _ref3.videoWidth,
videoHeight = _ref3.videoHeight;
return new Promise(function (resolve, reject) {
var attempts = 10;
function checkVideo() {
if (attempts > 0) {
if (videoWidth > 10 && videoHeight > 10) {
if (true) {
console.log("".concat(videoWidth, "px x ").concat(videoHeight, "px"));
}
resolve();
} else {
window.setTimeout(checkVideo, 500);
}
} else {
reject('Unable to play video stream. Is webcam working?');
}
attempts--;
}
checkVideo();
});
}
/***/ }),
/***/ "./src/input/exif-helper.ts":
/*!**********************************!*\
!*** ./src/input/exif-helper.ts ***!
\**********************************/
/*! exports provided: AvailableTags, findTagsInObjectURL, findTagsInBuffer */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AvailableTags", function() { return AvailableTags; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "findTagsInObjectURL", function() { return findTagsInObjectURL; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "findTagsInBuffer", function() { return findTagsInBuffer; });
/* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/regenerator */ "../../node_modules/@babel/runtime/regenerator/index.js");
/* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ "../../node_modules/@babel/runtime/helpers/asyncToGenerator.js");
/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1__);
/**
* @borrows https://github.com/exif-js/exif-js
*/
var ExifTags = {
0x0112: 'orientation'
};
var AvailableTags = Object.keys(ExifTags).map(function (key) {
return ExifTags[key];
});
function findTagsInObjectURL(_x) {
return _findTagsInObjectURL.apply(this, arguments);
}
function _findTagsInObjectURL() {
_findTagsInObjectURL = _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default()(
/*#__PURE__*/
_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.mark(function _callee(src) {
var tags,
buffer,
_args = arguments;
return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
tags = _args.length > 1 && _args[1] !== undefined ? _args[1] : AvailableTags;
if (!/^blob:/i.test(src)) {
_context.next = 6;
break;
}
_context.next = 4;
return objectURLToBlob(src);
case 4:
buffer = _context.sent;
return _context.abrupt("return", findTagsInBuffer(buffer, tags));
case 6:
return _context.abrupt("return", Promise.resolve(null));
case 7:
case "end":
return _context.stop();
}
}
}, _callee);
}));
return _findTagsInObjectURL.apply(this, arguments);
}
function findTagsInBuffer(file) {
var selectedTags = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : AvailableTags;
var dataView = new DataView(file);
var length = file.byteLength;
var exifTags = selectedTags.reduce(function (result, selectedTag) {
var exifTag = Object.keys(ExifTags).find(function (tag) {
return ExifTags[tag] === selectedTag;
});
if (exifTag) {
result[exifTag] = selectedTag;
}
return result;
}, {});
var offset = 2;
if (dataView.getUint8(0) !== 0xFF || dataView.getUint8(1) !== 0xD8) {
return null;
}
while (offset < length) {
if (dataView.getUint8(offset) !== 0xFF) {
return null;
}
var marker = dataView.getUint8(offset + 1);
if (marker === 0xE1) {
return readEXIFData(dataView, offset + 4, exifTags);
} else {
offset += 2 + dataView.getUint16(offset + 2);
}
}
return null;
}
function objectURLToBlob(_x2) {
return _objectURLToBlob.apply(this, arguments);
}
function _objectURLToBlob() {
_objectURLToBlob = _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default()(
/*#__PURE__*/
_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.mark(function _callee2(url) {
var response;
return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
_context2.next = 2;
return fetch(url);
case 2:
response = _context2.sent;
if (!response.ok) {
_context2.next = 5;
break;
}
return _context2.abrupt("return", response.arrayBuffer());
case 5:
throw new Error('HTTP Error ' + response.status);
case 6:
case "end":
return _context2.stop();
}
}
}, _callee2);
}));
return _objectURLToBlob.apply(this, arguments);
}
function readEXIFData(dataView, start, exifTags) {
if ('Exif'.split('').some(function (_char, index) {
return dataView.getUint8(start + index) !== _char.charCodeAt(0);
})) {
return null;
}
var tiffOffset = start + 6;
var bigEnd;
if (dataView.getUint16(tiffOffset) === 0x4949) {
bigEnd = false;
} else if (dataView.getUint16(tiffOffset) === 0x4D4D) {
bigEnd = true;
} else {
return null;
}
if (dataView.getUint16(tiffOffset + 2, !bigEnd) !== 0x002A) {
return null;
}
var firstIFDOffset = dataView.getUint32(tiffOffset + 4, !bigEnd);
if (firstIFDOffset < 0x00000008) {
return null;
}
var tags = readTags(dataView, tiffOffset + firstIFDOffset, exifTags, bigEnd);
return tags;
}
function readTags(dataView, dirStart, strings, bigEnd) {
var entries = dataView.getUint16(dirStart, !bigEnd);
var tags = {};
for (var i = 0; i < entries; i++) {
var entryOffset = dirStart + i * 12 + 2;
var tag = strings[dataView.getUint16(entryOffset, !bigEnd)];
if (tag) {
tags[tag] = readTagValue(dataView, entryOffset, bigEnd);
}
}
return tags;
}
function readTagValue(dataView, entryOffset, bigEnd) {
var type = dataView.getUint16(entryOffset + 2, !bigEnd);
var numValues = dataView.getUint32(entryOffset + 4, !bigEnd);
return type === 3 && numValues === 1 ? dataView.getUint16(entryOffset + 8, !bigEnd) : undefined;
}
/***/ }),
/***/ "./src/input/frame-grabber.ts":
/*!************************************!*\
!*** ./src/input/frame-grabber.ts ***!
\************************************/
/*! exports provided: FrameGrabber */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FrameGrabber", function() { return FrameGrabber; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
var QUATER_CIRCLE = Math.PI / 2;
var FrameGrabber =
/*#__PURE__*/
function () {
function FrameGrabber(inputStream, canvas) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, FrameGrabber);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_inputStream", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_streamConfig", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_canvas", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_context", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_data", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_canvasHeight", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_canvasWidth", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_height", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_width", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_topLeft", void 0);
this._inputStream = inputStream;
this._streamConfig = inputStream.config;
this._canvasWidth = inputStream.canvasWidth;
this._canvasHeight = inputStream.canvasHeight;
this._width = inputStream.width;
this._height = inputStream.height;
this._topLeft = inputStream.topLeft;
this._canvas = canvas || document.createElement('canvas');
this._canvas.width = this._canvasWidth;
this._canvas.height = this._canvasHeight;
this._context = this._canvas.getContext('2d');
this._data = new Uint8Array(this._width * this._height);
if (true) {
console.log('FrameGrabber', JSON.stringify({
size: {
x: this._width,
y: this._height
},
topLeft: this._topLeft,
videoSize: {
x: inputStream.realWidth,
y: inputStream.realHeight
},
canvasSize: {
x: this._canvasWidth,
y: this._canvasHeight
}
}));
}
}
/**
* 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.
*/
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(FrameGrabber, [{
key: "grab",
value: function grab(data) {
this._data = data;
var frame = this._inputStream.getFrame();
if (frame) {
this._adjustCanvasSize();
var drawable;
var drawAngle = 0;
if (frame instanceof HTMLVideoElement) {
drawable = frame;
} else {
drawable = frame.image;
if (frame.tags) {
switch (frame.tags.orientation) {
case 6:
{
drawAngle = QUATER_CIRCLE;
break;
}
case 8:
{
drawAngle = -QUATER_CIRCLE;
break;
}
}
}
}
if (drawAngle !== 0) {
var halfWidth = this._canvasWidth >> 1;
var halfHeight = this._canvasHeight >> 1;
this._context.translate(halfWidth, halfHeight);
this._context.rotate(drawAngle);
this._context.drawImage(drawable, -halfHeight, -halfWidth, this._canvasHeight, this._canvasWidth);
this._context.rotate(-drawAngle);
this._context.translate(-halfWidth, -halfHeight);
} else {
this._context.drawImage(drawable, 0, 0, this._canvasWidth, this._canvasHeight);
}
var imageData = this._context.getImageData(this._topLeft.x, this._topLeft.y, this._width, this._height).data;
if (this._streamConfig.halfSample) {
this._grayAndHalfSampleFromCanvasData(imageData);
} else {
this._computeGray(imageData);
}
return true;
} else {
return false;
}
}
}, {
key: "_adjustCanvasSize",
value: function _adjustCanvasSize() {
if (this._canvas.height !== this._canvasHeight || this._canvas.width !== this._canvasWidth) {
if (true) {
console.warn('Canvas size needs to be adjusted');
}
this._canvas.height = this._canvasHeight;
this._canvas.width = this._canvasWidth;
}
}
}, {
key: "_grayAndHalfSampleFromCanvasData",
value: function _grayAndHalfSampleFromCanvasData(imageData) {
var endIndex = imageData.length >> 2;
var outWidth = this._width >> 1;
var topRowIndex = 0;
var bottomRowIndex = this._width;
var outImageIndex = 0;
while (bottomRowIndex < endIndex) {
for (var i = 0; i < outWidth; i++) {
var top4 = topRowIndex << 2;
var bottom4 = bottomRowIndex << 2;
this._data[outImageIndex] = (0.299 * imageData[top4 + 0] + 0.587 * imageData[top4 + 1] + 0.114 * imageData[top4 + 2] + (0.299 * imageData[top4 + 4] + 0.587 * imageData[top4 + 5] + 0.114 * imageData[top4 + 6]) + (0.299 * imageData[bottom4 + 0] + 0.587 * imageData[bottom4 + 1] + 0.114 * imageData[bottom4 + 2]) + (0.299 * imageData[bottom4 + 4] + 0.587 * imageData[bottom4 + 5] + 0.114 * imageData[bottom4 + 6])) / 4 | 0;
outImageIndex++;
topRowIndex += 2;
bottomRowIndex += 2;
}
topRowIndex += this._width;
bottomRowIndex += this._width;
}
}
}, {
key: "_computeGray",
value: function _computeGray(imageData) {
var imageDataLength = imageData.length;
if (this._streamConfig && this._streamConfig.singleChannel) {
for (var i = 0, j = 0; i < imageDataLength; i += 4, j++) {
this._data[j] = imageData[i];
}
} else {
for (var _i = 0, _j = 0; _i < imageDataLength; _i += 4, _j++) {
this._data[_j] = 0.299 * imageData[_i] + 0.587 * imageData[_i + 1] + 0.114 * imageData[_i + 2] | 0;
}
}
}
}]);
return FrameGrabber;
}();
/***/ }),
/***/ "./src/input/image-loader.ts":
/*!***********************************!*\
!*** ./src/input/image-loader.ts ***!
\***********************************/
/*! exports provided: ImageLoader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ImageLoader", function() { return ImageLoader; });
/* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/regenerator */ "../../node_modules/@babel/runtime/regenerator/index.js");
/* harmony import */ var _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ "../../node_modules/@babel/runtime/helpers/asyncToGenerator.js");
/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _exif_helper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./exif-helper */ "./src/input/exif-helper.ts");
var ImageLoader =
/*#__PURE__*/
function () {
function ImageLoader() {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_2___default()(this, ImageLoader);
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3___default()(ImageLoader, null, [{
key: "load",
value: function () {
var _load = _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default()(
/*#__PURE__*/
_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.mark(function _callee2(baseUri, callback, offset, size, sequence) {
var imageSrcs, loadedImages, notLoadedImages, i, loaded, _loaded;
return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
_loaded = function _ref2() {
_loaded = _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_1___default()(
/*#__PURE__*/
_babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.mark(function _callee(loadedImage) {
var x, y, imageName, firstImage;
return _babel_runtime_regenerator__WEBPACK_IMPORTED_MODULE_0___default.a.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
x = 0;
case 1:
if (!(x < notLoadedImages.length)) {
_context.next = 17;
break;
}
if (!(notLoadedImages[x] === loadedImage)) {
_context.next = 14;
break;
}
notLoadedImages.splice(x, 1); // TODO: assume the index is the same
y = 0;
case 5:
if (!(y < imageSrcs.length)) {
_context.next = 13;
break;
}
imageName = imageSrcs[y].substr(imageSrcs[y].lastIndexOf('/'));
if (!(loadedImage.src.lastIndexOf(imageName) !== -1)) {
_context.next = 10;
break;
}
loadedImages[y] = {
image: loadedImage
};
return _context.abrupt("break", 13);
case 10:
y++;
_context.next = 5;
break;
case 13:
return _context.abrupt("break", 17);
case 14:
x++;
_context.next = 1;
break;
case 17:
if (!(notLoadedImages.length === 0)) {
_context.next = 33;
break;
}
if (true) {
console.log('Images loaded');
}
_context.prev = 19;
if (!(sequence === false)) {
_context.next = 25;
break;
}
firstImage = loadedImages[0];
_context.next = 24;
return Object(_exif_helper__WEBPACK_IMPORTED_MODULE_4__["findTagsInObjectURL"])(baseUri);
case 24:
firstImage.tags = _context.sent;
case 25:
_context.next = 30;
break;
case 27:
_context.prev = 27;
_context.t0 = _context["catch"](19);
console.log(_context.t0);
case 30:
_context.prev = 30;
callback(loadedImages);
return _context.finish(30);
case 33:
case "end":
return _context.stop();
}
}
}, _callee, null, [[19, 27, 30, 33]]);
}));
return _loaded.apply(this, arguments);
};
loaded = function _ref(_x6) {
return _loaded.apply(this, arguments);
};
imageSrcs = new Array(size);
loadedImages = new Array(size);
notLoadedImages = new Array();
if (sequence === false) {
imageSrcs[0] = baseUri;
} else {
for (i = 0; i < size; i++) {
imageSrcs[i] = "".concat(baseUri, "image-").concat(('00' + (offset + i)).slice(-3), ".jpg");
}
}
imageSrcs.forEach(function (src) {
var image = new Image();
notLoadedImages.push(image);
image.onload = function () {
return loaded(image);
};
image.src = src;
});
case 7:
case "end":
return _context2.stop();
}
}
}, _callee2);
}));
function load(_x, _x2, _x3, _x4, _x5) {
return _load.apply(this, arguments);
}
return load;
}()
}]);
return ImageLoader;
}();
/***/ }),
/***/ "./src/input/image-stream.ts":
/*!***********************************!*\
!*** ./src/input/image-stream.ts ***!
\***********************************/
/*! exports provided: ImageStream */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ImageStream", function() { return ImageStream; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/assertThisInitialized */ "../../node_modules/@babel/runtime/helpers/assertThisInitialized.js");
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6__);
/* harmony import */ var _image_loader__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./image-loader */ "./src/input/image-loader.ts");
/* harmony import */ var _input_stream__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./input-stream */ "./src/input/input-stream.ts");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var ImageStream =
/*#__PURE__*/
function (_InputStream) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default()(ImageStream, _InputStream);
function ImageStream() {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, ImageStream);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(ImageStream).call(this));
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_baseUrl", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_ended", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_frameIndex", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_height", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_images", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_loaded", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_offset", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_paused", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_size", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_width", void 0);
_this._canvasHeight = 0;
_this._canvasWidth = 0;
_this._baseUrl = null;
_this._ended = false;
_this._frameIndex = 0;
_this._height = 0;
_this._images = null;
_this._loaded = false;
_this._offset = 1;
_this._paused = true;
_this._size = 0;
_this._width = 0;
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(ImageStream, [{
key: "setAttribute",
value: function setAttribute() {}
}, {
key: "pause",
value: function pause() {
this._paused = true;
}
}, {
key: "play",
value: function play() {
this._paused = false;
}
}, {
key: "getFrame",
value: function getFrame() {
var _this2 = this;
var frame = null;
if (this._loaded && !this._paused) {
frame = this._images[this._frameIndex];
if (this._frameIndex < this._size - 1) {
this._frameIndex++;
} else {
setTimeout(function () {
_this2._ended = true;
_this2.trigger('ended', []);
}, 0);
}
}
return frame;
}
}, {
key: "_loadImages",
value: function _loadImages() {
var _this3 = this;
this._loaded = false;
_image_loader__WEBPACK_IMPORTED_MODULE_7__["ImageLoader"].load(this._baseUrl, function (images) {
_this3._images = images;
switch (images[0].tags && images[0].tags.orientation) {
case 6:
case 8:
{
_this3._width = images[0].image.height;
_this3._height = images[0].image.width;
break;
}
default:
{
_this3._width = images[0].image.width;
_this3._height = images[0].image.height;
}
}
_this3._canvasWidth = _this3._calculatedWidth = _this3._config.size ? _this3._width > _this3._height ? _this3._config.size : _this3._width * _this3._config.size / _this3._height | 0 : _this3._width;
_this3._canvasHeight = _this3._calculatedHeight = _this3._config.size ? _this3._width > _this3._height ? _this3._height * _this3._config.size / _this3._width | 0 : _this3._config.size : _this3._height;
_this3._loaded = true;
_this3._frameIndex = 0;
setTimeout(function () {
return _this3.trigger('canrecord', []);
}, 0);
}, this._offset, this._size, this._config.sequence);
}
}, {
key: "realHeight",
get: function get() {
return this._height;
}
}, {
key: "realWidth",
get: function get() {
return this._width;
}
}, {
key: "config",
get: function get() {
return this._config;
},
set: function set(config) {
this._config = _objectSpread({}, config);
this._baseUrl = config.src;
this._size = config.sequence && config.length ? config.length : 1;
this._loadImages();
}
}, {
key: "ended",
get: function get() {
return this._ended;
}
}, {
key: "currentTime",
set: function set(time) {
this._frameIndex = time;
}
}]);
return ImageStream;
}(_input_stream__WEBPACK_IMPORTED_MODULE_8__["InputStream"]);
/***/ }),
/***/ "./src/input/input-stream-utils.ts":
/*!*****************************************!*\
!*** ./src/input/input-stream-utils.ts ***!
\*****************************************/
/*! exports provided: calculatePatchSize, checkImageConstraints, _parseCssDimensionValues, _dimensionsConverters, computeImageArea */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "calculatePatchSize", function() { return calculatePatchSize; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "checkImageConstraints", function() { return checkImageConstraints; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "_parseCssDimensionValues", function() { return _parseCssDimensionValues; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "_dimensionsConverters", function() { return _dimensionsConverters; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "computeImageArea", function() { return computeImageArea; });
function _computeDivisors(n) {
var divisors = new Array();
var largeDivisors = new Array();
for (var divisor = 1; divisor * divisor <= n; divisor++) {
if (n % divisor === 0) {
divisors.push(divisor);
if (divisor * divisor !== n) {
largeDivisors.unshift(n / divisor | 0);
}
}
}
return divisors.concat(largeDivisors);
}
function _computeCommonDivisors(m, n) {
if (m === n) {
return _computeDivisors(m);
}
var max = m > n ? m : n;
var min = m > n ? n : m;
var divisors = new Array();
var largeDivisors = new Array();
for (var divisor = 1; divisor * divisor <= min; divisor++) {
if (max % divisor === 0 && min % divisor === 0) {
divisors.push(divisor);
var largeDivisor = min / divisor | 0;
if (divisor !== largeDivisor && max % largeDivisor === 0) {
largeDivisors.unshift();
}
}
}
return divisors.concat(largeDivisors);
}
function calculatePatchSize(patchSize, _ref) {
var x = _ref.x,
y = _ref.y;
var wideSide = Math.max(x | 0, y | 0) | 0;
var nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80];
var nrOfPatchesMap = {
'x-small': 5,
small: 4,
medium: 3,
large: 2,
'x-large': 1
};
var nrOfPatchesIndex = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium | 0;
var nrOfPatches = nrOfPatchesList[nrOfPatchesIndex] | 0;
var desiredPatchSize = wideSide / nrOfPatches | 0;
function findPatchSizeForDivisors(divisors) {
var i = 0;
var found = divisors[divisors.length >> 1] | 0;
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] | 0;
} else {
found = divisors[i] | 0;
}
}
if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIndex + 1] / nrOfPatchesList[nrOfPatchesIndex] && desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIndex - 1] / nrOfPatchesList[nrOfPatchesIndex]) {
return {
x: found,
y: found
};
}
return null;
}
var optimalPatchSize = findPatchSizeForDivisors(_computeCommonDivisors(x, y)) || findPatchSizeForDivisors(_computeDivisors(wideSide)) || findPatchSizeForDivisors(_computeDivisors(desiredPatchSize * nrOfPatches));
return optimalPatchSize;
}
function checkImageConstraints(inputStream, config) {
var width = inputStream.width;
var height = inputStream.height;
var shift = config.halfSample ? 1 : 0 | 0;
var inputStreamConfig = inputStream.config; // calculate width and height based on area
if (inputStreamConfig && inputStreamConfig.area) {
var area = computeImageArea(width, height, inputStreamConfig.area);
inputStream.topLeft = area.topLeft;
inputStream.setCanvasSize(width, height);
width = area.width;
height = area.height;
}
var size = {
x: width >> shift,
y: height >> shift
};
var patchSize = calculatePatchSize(config.patchSize, size);
if (true) {
console.log('Patch-Size:', JSON.stringify(patchSize));
}
inputStream.width = (size.x / patchSize.x << shift) * patchSize.x | 0;
inputStream.height = (size.y / patchSize.y << shift) * patchSize.y | 0;
if (inputStream.width % patchSize.x === 0 && inputStream.height % patchSize.y === 0) {
return true;
} // eslint-disable-next-line max-len
throw new Error("Image dimensions do not comply with the current settings: width (".concat(width, ") and height (").concat(height, ") must be a multiple of ").concat(patchSize.x));
}
function _parseCssDimensionValues(value) {
var dimension = {
value: parseFloat(value),
unit: value.indexOf('%') === value.length - 1 ? '%' : value.indexOf('px') === value.length - 2 ? 'px' : '%'
};
return dimension;
}
var _dimensionsConverters = {
bottom: function bottom(dimension, _ref2) {
var height = _ref2.height;
return dimension.unit === '%' ? height - height * dimension.value / 100 | 0 : dimension.unit === 'px' ? height - dimension.value : height;
},
left: function left(dimension, _ref3) {
var width = _ref3.width;
return dimension.unit === '%' ? width * dimension.value / 100 | 0 : dimension.unit === 'px' ? dimension.value : 0;
},
right: function right(dimension, _ref4) {
var width = _ref4.width;
return dimension.unit === '%' ? width - width * dimension.value / 100 | 0 : dimension.unit === 'px' ? width - dimension.value : width;
},
top: function top(dimension, _ref5) {
var height = _ref5.height;
return dimension.unit === '%' ? height * dimension.value / 100 | 0 : dimension.unit === 'px' ? dimension.value : 0;
}
};
function computeImageArea(inputWidth, inputHeight, area) {
var context = {
width: inputWidth,
height: inputHeight
};
var parsedArea = Object.keys(area).reduce(function (result, key) {
var value = area[key];
var parsed = _parseCssDimensionValues(value);
var calculated = _dimensionsConverters[key](parsed, context);
result[key] = calculated;
return result;
}, {});
return {
topLeft: {
x: parsedArea.left,
y: parsedArea.top
},
width: parsedArea.right - parsedArea.left,
height: parsedArea.bottom - parsedArea.top
};
}
/***/ }),
/***/ "./src/input/input-stream.ts":
/*!***********************************!*\
!*** ./src/input/input-stream.ts ***!
\***********************************/
/*! exports provided: InputStream */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InputStream", function() { return InputStream; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var InputStream =
/*#__PURE__*/
function () {
function InputStream() {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, InputStream);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_calculatedHeight", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_calculatedWidth", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_canvasHeight", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_canvasWidth", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_config", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_eventNames", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_eventHandlers", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_topLeft", void 0);
this._canvasWidth = 0;
this._canvasHeight = 0;
this._config = null;
this._eventNames = ['canrecord', 'ended'];
this._eventHandlers = new Map();
this._topLeft = {
x: 0,
y: 0
};
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(InputStream, [{
key: "setCanvasSize",
value: function setCanvasSize(width, height) {
this._canvasWidth = width;
this._canvasHeight = height;
}
}, {
key: "addEventListener",
value: function addEventListener(event, listener, _options) {
if (this._eventNames.indexOf(event) !== -1) {
if (!this._eventHandlers.has(event)) {
this._eventHandlers.set(event, new Array());
}
this._eventHandlers.get(event).push(listener);
}
}
}, {
key: "clearEventHandlers",
value: function clearEventHandlers() {
this._eventHandlers.clear();
}
}, {
key: "trigger",
value: function trigger(eventName, argArray) {
var _this = this;
var handlers = this._eventHandlers.get(eventName);
if (handlers) {
handlers.forEach(function (handler) {
return handler.apply(_this, argArray);
});
}
}
}, {
key: "height",
get: function get() {
return this._calculatedHeight;
},
set: function set(height) {
this._calculatedHeight = height;
}
}, {
key: "width",
get: function get() {
return this._calculatedWidth;
},
set: function set(width) {
this._calculatedWidth = width;
}
}, {
key: "topLeft",
get: function get() {
return _objectSpread({}, this._topLeft);
},
set: function set(topLeft) {
this._topLeft.x = topLeft.x;
this._topLeft.y = topLeft.y;
}
}, {
key: "canvasHeight",
get: function get() {
return this._canvasHeight;
}
}, {
key: "canvasWidth",
get: function get() {
return this._canvasWidth;
}
}]);
return InputStream;
}();
/***/ }),
/***/ "./src/input/live-stream.ts":
/*!**********************************!*\
!*** ./src/input/live-stream.ts ***!
\**********************************/
/*! exports provided: LiveStream */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LiveStream", function() { return LiveStream; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _video_stream__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./video-stream */ "./src/input/video-stream.ts");
var LiveStream =
/*#__PURE__*/
function (_VideoStream) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default()(LiveStream, _VideoStream);
function LiveStream(video) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, LiveStream);
video.setAttribute('autoplay', '');
return _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(LiveStream).call(this, video));
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(LiveStream, [{
key: "ended",
get: function get() {
return false;
}
}]);
return LiveStream;
}(_video_stream__WEBPACK_IMPORTED_MODULE_5__["VideoStream"]);
/***/ }),
/***/ "./src/input/video-stream.ts":
/*!***********************************!*\
!*** ./src/input/video-stream.ts ***!
\***********************************/
/*! exports provided: VideoStream, LiveStream */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VideoStream", function() { return VideoStream; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LiveStream", function() { return LiveStream; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/assertThisInitialized */ "../../node_modules/@babel/runtime/helpers/assertThisInitialized.js");
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/get */ "../../node_modules/@babel/runtime/helpers/get.js");
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7__);
/* harmony import */ var _input_stream__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./input-stream */ "./src/input/input-stream.ts");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var VideoStream =
/*#__PURE__*/
function (_InputStream) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6___default()(VideoStream, _InputStream);
function VideoStream(video) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, VideoStream);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default()(VideoStream).call(this));
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_3___default()(_this), "_video", void 0);
_this._video = video;
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(VideoStream, [{
key: "setAttribute",
value: function setAttribute(name, value) {
this._video.setAttribute(name, value);
}
}, {
key: "pause",
value: function pause() {
this._video.pause();
}
}, {
key: "play",
value: function play() {
this._video.play();
}
}, {
key: "addEventListener",
value: function addEventListener(event, listener, options) {
_babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5___default()(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default()(VideoStream.prototype), "addEventListener", this).call(this, event, listener, options);
if (this._eventNames.indexOf(event) === -1) {
this._video.addEventListener(event, listener, options);
}
}
}, {
key: "clearEventHandlers",
value: function clearEventHandlers() {
// TODO: come up with a way to remove video event handlers
// this._eventNames.forEach(eventName => {
// const handlers = this._eventHandlers.get(eventName);
// if (handlers && handlers.length > 0) {
// handlers.forEach(handler => this._video.removeEventListener(eventName, handler));
// }
// });
_babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5___default()(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default()(VideoStream.prototype), "clearEventHandlers", this).call(this);
}
}, {
key: "trigger",
value: function trigger(eventName, argArray) {
if (eventName === 'canrecord') {
this._initSize();
}
_babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5___default()(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default()(VideoStream.prototype), "trigger", this).call(this, eventName, argArray);
}
}, {
key: "getFrame",
value: function getFrame() {
return this._video;
}
}, {
key: "_initSize",
value: function _initSize() {
var width = this._video.videoWidth;
var height = this._video.videoHeight;
this._canvasWidth = this._calculatedWidth = this._config.size ? width > height ? this._config.size : width * this._config.size / height | 0 : width;
this._canvasHeight = this._calculatedHeight = this._config.size ? width > height ? height * this._config.size / width | 0 : this._config.size : height;
}
}, {
key: "realHeight",
get: function get() {
return this._video.videoHeight;
}
}, {
key: "realWidth",
get: function get() {
return this._video.videoWidth;
}
}, {
key: "config",
get: function get() {
return this._config;
},
set: function set(config) {
this._config = _objectSpread({}, config);
this._video.src = config.src || '';
}
}, {
key: "ended",
get: function get() {
return this._video.ended;
}
}, {
key: "currentTime",
set: function set(time) {
if (this._config.type !== 'LiveStream') {
this._video.currentTime = time;
}
}
}]);
return VideoStream;
}(_input_stream__WEBPACK_IMPORTED_MODULE_8__["InputStream"]);
var LiveStream =
/*#__PURE__*/
function (_VideoStream) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6___default()(LiveStream, _VideoStream);
function LiveStream(video) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, LiveStream);
video.setAttribute('autoplay', '');
return _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default()(LiveStream).call(this, video));
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(LiveStream, [{
key: "ended",
get: function get() {
return false;
}
}]);
return LiveStream;
}(VideoStream);
/***/ }),
/***/ "./src/locator/barcode-locator-utils.ts":
/*!**********************************************!*\
!*** ./src/locator/barcode-locator-utils.ts ***!
\**********************************************/
/*! exports provided: invert, transformWithMatrix, otsuThreshold, halfSample */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "invert", function() { return invert; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "transformWithMatrix", function() { return transformWithMatrix; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "otsuThreshold", function() { return otsuThreshold; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "halfSample", function() { return halfSample; });
/**
* Invert matrix
* @param matrix the matrix to invert
* @returns the inverted matrix
*/
function invert(matrix) {
var a0 = matrix[0];
var a1 = matrix[1];
var a2 = matrix[2];
var a3 = matrix[3];
var determinant = a0 * a3 - a2 * a1;
if (!determinant) {
return null;
}
return new Float32Array([a3 / determinant, -a1 / determinant, -a2 / determinant, a0 / determinant]);
}
/**
* Transforms the vector with a matrix
* @param { x, y } vector to transform
* @param matrix matrix to transform with
* @returns the transformed vector
*/
function transformWithMatrix(_ref, matrix) {
var x = _ref.x,
y = _ref.y;
return {
x: matrix[0] * x + matrix[2] * y,
y: matrix[1] * x + matrix[3] * y
};
}
function _computeHistogram(imageWrapper, bitsPerPixel) {
if (!bitsPerPixel) {
bitsPerPixel = 8;
}
var imageData = imageWrapper.data;
var bitShift = 8 - bitsPerPixel;
var bucketCount = 1 << bitsPerPixel;
var histogram = new Int32Array(bucketCount);
for (var i = imageData.length; i--;) {
histogram[imageData[i] >> bitShift]++;
}
return histogram;
}
function _determineOtsuThreshold(imageWrapper, bitsPerPixel) {
if (!bitsPerPixel) {
bitsPerPixel = 8;
}
var bitShift = 8 - bitsPerPixel;
var hist = _computeHistogram(imageWrapper, bitsPerPixel);
var vet = [0];
var max = (1 << bitsPerPixel) - 1;
function px(init, end) {
var sum = 0;
for (var i = init; i <= end; i++) {
sum += hist[i];
}
return sum;
}
function mx(init, end) {
var sum = 0;
for (var i = init; i <= end; i++) {
sum += i * hist[i];
}
return sum;
}
for (var k = 1; k < max; k++) {
var p1 = px(0, k);
var p2 = px(k + 1, max);
var p12 = p1 * p2 || 1;
var m1 = mx(0, k) * p2;
var m2 = mx(k + 1, max) * p1;
var m12 = m1 - m2;
vet[k] = m12 * m12 / p12;
} // index of max element
var threshold = vet.reduce(function (maxIndex, item, index, array) {
return item > array[maxIndex] ? index : maxIndex;
}, 0);
return threshold << bitShift;
}
function otsuThreshold(imageWrapper, targetWrapper) {
var threshold = _determineOtsuThreshold(imageWrapper);
var targetData = targetWrapper.data;
imageWrapper.data.forEach(function (value, index) {
targetData[index] = value < threshold ? 1 : 0;
});
return threshold;
}
/**
* @param imageWrapper input image to be sampled
* @param outImageWrapper {ImageWrapper} to be stored in
*/
function halfSample(imageWrapper, outImageWrapper) {
var image = imageWrapper.data;
var width = imageWrapper.size.x;
var outImage = outImageWrapper.data;
var endIndex = image.length;
var outWidth = width >> 1;
var topRowIndex = 0;
var bottomRowIndex = width;
var outImgIndex = 0;
while (bottomRowIndex < endIndex) {
for (var i = 0; i < outWidth; i++) {
outImage[outImgIndex] = image[topRowIndex] + image[topRowIndex + 1] + image[bottomRowIndex] + image[bottomRowIndex + 1] >> 2;
outImgIndex++;
topRowIndex += 2;
bottomRowIndex += 2;
}
topRowIndex += width;
bottomRowIndex += width;
}
}
/***/ }),
/***/ "./src/locator/barcode-locator.ts":
/*!****************************************!*\
!*** ./src/locator/barcode-locator.ts ***!
\****************************************/
/*! exports provided: BarcodeLocator */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* WEBPACK VAR INJECTION */(function(global) {/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BarcodeLocator", function() { return BarcodeLocator; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _common_cluster__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../common/cluster */ "./src/common/cluster.ts");
/* harmony import */ var _common_hsv2rgb__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../common/hsv2rgb */ "./src/common/hsv2rgb.ts");
/* harmony import */ var _common_image_debug__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../common/image-debug */ "./src/common/image-debug.ts");
/* harmony import */ var _common_image_wrapper__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../common/image-wrapper */ "./src/common/image-wrapper.ts");
/* harmony import */ var _input_input_stream_utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../input/input-stream-utils */ "./src/input/input-stream-utils.ts");
/* harmony import */ var _barcode_locator_utils__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./barcode-locator-utils */ "./src/locator/barcode-locator-utils.ts");
/* harmony import */ var _rasterizer__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./rasterizer */ "./src/locator/rasterizer.ts");
/* harmony import */ var _skeletonizer__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./skeletonizer */ "./src/locator/skeletonizer.js");
/* harmony import */ var _tracer__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./tracer */ "./src/locator/tracer.ts");
var MomentSimilarityThreshold = 0.9;
var BarcodeLocator =
/*#__PURE__*/
function () {
function BarcodeLocator(inputImageWrapper, config) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, BarcodeLocator);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_config", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_inputImageWrapper", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_currentImageWrapper", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_skelImageWrapper", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_subImageWrapper", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_labelImageWrapper", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_binaryImageWrapper", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_patchGrid", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_patchLabelGrid", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_imageToPatchGrid", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_patchSize", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_binaryContext", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_numPatches", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_skeletonizer", void 0);
this._config = config;
this._inputImageWrapper = inputImageWrapper;
this._numPatches = {
x: 0,
y: 0
};
this._initBuffers();
this._initCanvas();
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(BarcodeLocator, [{
key: "locate",
value: function locate() {
if (this._config.halfSample) {
Object(_barcode_locator_utils__WEBPACK_IMPORTED_MODULE_8__["halfSample"])(this._inputImageWrapper, this._currentImageWrapper);
}
this._binarizeImage();
var patchesFound = this._findPatches(); // return unless 5% or more patches are found
if (patchesFound.length < this._numPatches.x * this._numPatches.y * 0.05) {
return null;
} // rasterize area by comparing angular similarity;
var maxLabel = this._rasterizeAngularSimilarity(patchesFound);
if (maxLabel < 1) {
return null;
} // search for area with the most patches (biggest connected area)
var topLabels = this._findBiggestConnectedAreas(maxLabel);
if (topLabels.length === 0) {
return null;
}
var boxes = this._findBoxes(topLabels, maxLabel);
return boxes;
}
}, {
key: "_initBuffers",
value: function _initBuffers() {
if (this._config.halfSample) {
this._currentImageWrapper = new _common_image_wrapper__WEBPACK_IMPORTED_MODULE_6__["ImageWrapper"]({
x: this._inputImageWrapper.size.x / 2 | 0,
y: this._inputImageWrapper.size.y / 2 | 0
});
} else {
this._currentImageWrapper = this._inputImageWrapper;
}
this._patchSize = Object(_input_input_stream_utils__WEBPACK_IMPORTED_MODULE_7__["calculatePatchSize"])(this._config.patchSize, this._currentImageWrapper.size);
this._numPatches.x = this._currentImageWrapper.size.x / this._patchSize.x | 0;
this._numPatches.y = this._currentImageWrapper.size.y / this._patchSize.y | 0;
this._binaryImageWrapper = new _common_image_wrapper__WEBPACK_IMPORTED_MODULE_6__["ImageWrapper"](this._currentImageWrapper.size, undefined, Uint8Array, false);
this._labelImageWrapper = new _common_image_wrapper__WEBPACK_IMPORTED_MODULE_6__["ImageWrapper"](this._patchSize, undefined, Array, true);
var skeletonImageData = new ArrayBuffer(64 * 1024);
this._subImageWrapper = new _common_image_wrapper__WEBPACK_IMPORTED_MODULE_6__["ImageWrapper"](this._patchSize, new Uint8Array(skeletonImageData, 0, this._patchSize.x * this._patchSize.y));
this._skelImageWrapper = new _common_image_wrapper__WEBPACK_IMPORTED_MODULE_6__["ImageWrapper"](this._patchSize, new Uint8Array(skeletonImageData, this._patchSize.x * this._patchSize.y * 3, this._patchSize.x * this._patchSize.y), undefined, true);
this._skeletonizer = Object(_skeletonizer__WEBPACK_IMPORTED_MODULE_10__["default"])(typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : global, {
size: this._patchSize.x
}, skeletonImageData);
var size = {
x: this._currentImageWrapper.size.x / this._subImageWrapper.size.x | 0,
y: this._currentImageWrapper.size.y / this._subImageWrapper.size.y | 0
};
this._patchLabelGrid = new _common_image_wrapper__WEBPACK_IMPORTED_MODULE_6__["ImageWrapper"](size, undefined, Int32Array, true);
this._patchGrid = new _common_image_wrapper__WEBPACK_IMPORTED_MODULE_6__["ImageWrapper"](size, undefined, undefined, true);
this._imageToPatchGrid = new Array(this._patchLabelGrid.data.length);
}
}, {
key: "_initCanvas",
value: function _initCanvas() {
if (this._config.useWorker || typeof document === 'undefined') {
return;
}
var canvas = document.createElement('canvas');
canvas.className = 'binaryBuffer';
canvas.width = this._binaryImageWrapper.size.x;
canvas.height = this._binaryImageWrapper.size.y;
if ( true && this._config.debug && this._config.debug.showCanvas) {
document.querySelector('#debug').appendChild(canvas);
}
this._binaryContext = canvas.getContext('2d');
}
/**
* Creates a bounding box which encloses all the given patches
* @returns The minimal bounding box
*/
}, {
key: "_boxFromPatches",
value: function _boxFromPatches(patches) {
var _this = this;
var debug = true && this._config.debug;
var averageRad = patches.reduce(function (sum, _ref) {
var pos = _ref.pos,
rad = _ref.rad;
if (debug && debug.showPatches) {
// draw all patches which are to be taken into consideration
_this._drawRect(pos, _this._subImageWrapper.size, 'red', 1);
}
return sum + rad;
}, 0) / patches.length;
averageRad = (averageRad * 180 / Math.PI + 90) % 180 - 90;
if (averageRad < 0) {
averageRad += 180;
}
averageRad = (180 - averageRad) * Math.PI / 180;
var cos = Math.cos(averageRad);
var sin = Math.sin(averageRad);
var matrix = new Float32Array([cos, sin, -sin, cos]);
var inverseMatrix = Object(_barcode_locator_utils__WEBPACK_IMPORTED_MODULE_8__["invert"])(matrix); // iterate over patches and rotate by angle
patches.forEach(function (_ref2) {
var box = _ref2.box;
for (var j = 0; j < 4; j++) {
box[j] = Object(_barcode_locator_utils__WEBPACK_IMPORTED_MODULE_8__["transformWithMatrix"])(box[j], matrix);
}
if (debug && debug.boxFromPatches.showTransformed) {
_this._drawPath(box, '#99ff00', 2);
}
});
var minX = this._binaryImageWrapper.size.x;
var minY = this._binaryImageWrapper.size.y;
var maxX = -minX;
var maxY = -minY; // find bounding box
patches.forEach(function (_ref3) {
var box = _ref3.box;
box.forEach(function (_ref4) {
var x = _ref4.x,
y = _ref4.y;
if (x < minX) {
minX = x;
}
if (x > maxX) {
maxX = x;
}
if (y < minY) {
minY = y;
}
if (y > maxY) {
maxY = y;
}
});
});
var box = [{
x: minX,
y: minY
}, {
x: maxX,
y: minY
}, {
x: maxX,
y: maxY
}, {
x: minX,
y: maxY
}];
if (debug && debug.boxFromPatches.showTransformedBox) {
this._drawPath(box, '#ff0000', 2);
} // reverse rotation
box = box.map(function (vertex) {
return Object(_barcode_locator_utils__WEBPACK_IMPORTED_MODULE_8__["transformWithMatrix"])(vertex, inverseMatrix);
});
if (debug && debug.boxFromPatches.showBB) {
this._drawPath(box, '#ff0000', 2);
}
if (this._config.halfSample) {
// scale
box = box.map(function (_ref5) {
var x = _ref5.x,
y = _ref5.y;
return {
x: x * 2,
y: y *= 2
};
});
}
return box;
}
/**
* Creates a binary image of the current image
*/
}, {
key: "_binarizeImage",
value: function _binarizeImage() {
Object(_barcode_locator_utils__WEBPACK_IMPORTED_MODULE_8__["otsuThreshold"])(this._currentImageWrapper, this._binaryImageWrapper);
this._binaryImageWrapper.zeroBorder();
if ( true && this._config.debug && this._config.debug.showCanvas) {
this._binaryImageWrapper.show(this._binaryContext, 255);
}
}
/**
* Iterate over the entire image, extract patches
*/
}, {
key: "_findPatches",
value: function _findPatches() {
var debug = true && this._config.debug;
var patchesFound = new Array();
for (var i = 0; i < this._numPatches.x; i++) {
for (var j = 0; j < this._numPatches.y; j++) {
var x = this._subImageWrapper.size.x * i;
var y = this._subImageWrapper.size.y * j; // seperate parts
this._skeletonize(x, y); // Rasterize, find individual bars
this._skelImageWrapper.zeroBorder();
this._labelImageWrapper.data.fill(0);
var rasterizer = new _rasterizer__WEBPACK_IMPORTED_MODULE_9__["Rasterizer"](this._skelImageWrapper, this._labelImageWrapper);
var rasterResult = rasterizer.rasterize(0);
if (debug && debug.showLabels) {
this._labelImageWrapper.overlay(this._binaryContext, 360 / rasterResult.count | 0, x, y);
} // calculate moments from the skeletonized patch
var moments = this._labelImageWrapper.moments(rasterResult.count); // extract eligible patches
var patch = this._describePatch(moments, j * this._numPatches.x + i, x, y);
if (patch) {
patchesFound.push(patch);
if (debug && debug.showFoundPatches) {
this._drawRect(patch.pos, this._subImageWrapper.size, '#99ff00', 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 maxLabel
*/
}, {
key: "_findBiggestConnectedAreas",
value: function _findBiggestConnectedAreas(maxLabel) {
var labelHist = new Array(maxLabel).fill(0);
this._patchLabelGrid.data.forEach(function (data) {
if (data > 0) {
labelHist[data - 1]++;
}
}); // extract top areas with at least 6 patches present
var topLabels = labelHist.map(function (value, index) {
return {
value: value,
index: index
};
}).filter(function (_ref6) {
var value = _ref6.value;
return value >= 5;
}).sort(function (a, b) {
return b.value - a.value;
}).map(function (_ref7) {
var index = _ref7.index;
return index + 1;
});
return topLabels;
}
/**
*
*/
}, {
key: "_findBoxes",
value: function _findBoxes(topLabels, maxLabel) {
var _this2 = this;
var boxes = new Array();
var showRemainingPatchLabels = true && this._config.debug && this._config.debug.showRemainingPatchLabels;
topLabels.forEach(function (label) {
var patches = new Array();
_this2._patchLabelGrid.data.forEach(function (data, index) {
if (data === label) {
patches.push(_this2._imageToPatchGrid[index]);
}
});
var box = _this2._boxFromPatches(patches);
if (box) {
boxes.push(box);
if (showRemainingPatchLabels) {
// draw patch-labels if requested
var hsv = [label / (maxLabel + 1) * 360, 1, 1];
var rgb = [0, 0, 0];
Object(_common_hsv2rgb__WEBPACK_IMPORTED_MODULE_4__["hsv2rgb"])(hsv, rgb);
var color = "rgb(".concat(rgb.join(','), ")");
patches.forEach(function (_ref8) {
var pos = _ref8.pos;
return _this2._drawRect(pos, _this2._subImageWrapper.size, color, 2);
});
}
}
});
return boxes;
}
/**
* Find similar moments (via cluster)
* @param moments
*/
}, {
key: "_similarMoments",
value: function _similarMoments(moments) {
var clusters = _common_cluster__WEBPACK_IMPORTED_MODULE_3__["Cluster"].clusterize(moments, MomentSimilarityThreshold);
var topCluster = clusters.reduce(function (top, item) {
var count = item.moments.length;
return count > top.count ? {
item: item,
count: count
} : top;
}, {
item: {
moments: []
},
count: 0
});
var result = topCluster.item.moments;
return result;
}
}, {
key: "_skeletonize",
value: function _skeletonize(x, y) {
this._binaryImageWrapper.subImageAsCopy(this._subImageWrapper, x, y);
this._skeletonizer.skeletonize(); // Show skeleton if requested
if ( true && this._config.debug && this._config.debug.showSkeleton) {
this._skelImageWrapper.overlay(this._binaryContext, 360, x, y);
}
}
/**
* Extracts and describes those patches which seem to contain a barcode pattern
* @param moments
* @param index
* @param x
* @param y
* @returns list of patches
*/
}, {
key: "_describePatch",
value: function _describePatch(moments, index, x, y) {
if (moments.length > 1) {
var minComponentWeight = Math.ceil(this._patchSize.x / 3); // only collect moments which area covers at least minComponentWeight pixels
var eligibleMoments = moments.filter(function (moment) {
return moment.m00 > minComponentWeight;
}); // if at least 2 moments are found which have at least minComponentWeights covered
if (eligibleMoments.length > 1) {
var matchingMoments = this._similarMoments(eligibleMoments);
var length = matchingMoments.length | 0; // Only two of the moments are allowed not to fit into the equation
if (length > 1 && length << 2 >= eligibleMoments.length * 3 && length << 2 > moments.length) {
// determine the similarity of the moments
var rad = matchingMoments.reduce(function (sum, moment) {
return sum + moment.rad;
}, 0) / length;
return {
index: index,
pos: {
x: x,
y: y
},
box: [{
x: x,
y: y
}, {
x: x + this._subImageWrapper.size.x,
y: y
}, {
x: x + this._subImageWrapper.size.x,
y: y + this._subImageWrapper.size.y
}, {
x: x,
y: y + this._subImageWrapper.size.y
}],
moments: matchingMoments,
rad: rad,
x: Math.cos(rad),
y: Math.sin(rad)
};
}
}
}
return null;
}
}, {
key: "_notYetProcessed",
value: function _notYetProcessed() {
for (var i = 0; i < this._patchLabelGrid.data.length; i++) {
if (this._patchLabelGrid.data[i] === 0 && this._patchGrid.data[i] === 1) {
return i;
}
}
return this._patchLabelGrid.data.length;
}
}, {
key: "_trace",
value: function _trace(currentIndex, label) {
var _this3 = this;
var threshold = 0.95;
var current = {
x: currentIndex % this._patchLabelGrid.size.x,
y: currentIndex / this._patchLabelGrid.size.x | 0
};
if (currentIndex < this._patchLabelGrid.data.length) {
var currentPatch = this._imageToPatchGrid[currentIndex]; // assign label
this._patchLabelGrid.data[currentIndex] = label;
_tracer__WEBPACK_IMPORTED_MODULE_11__["SearchDirections"].forEach(function (direction) {
var y = current.y + direction[0];
var x = current.x + direction[1];
var index = y * _this3._patchLabelGrid.size.x + x; // continue if patch empty
if (_this3._patchGrid.data[index] === 0) {
_this3._patchLabelGrid.data[index] = Number.MAX_VALUE;
} else if (_this3._patchLabelGrid.data[index] === 0) {
var patch = _this3._imageToPatchGrid[index];
var similarity = Math.abs(patch.x * currentPatch.x + patch.y * currentPatch.y);
if (similarity > threshold) {
_this3._trace(index, label);
}
}
});
}
}
/**
* Finds patches which are connected and share the same orientation
* @param patchesFound
*/
}, {
key: "_rasterizeAngularSimilarity",
value: function _rasterizeAngularSimilarity(patchesFound) {
var _this4 = this;
var label = 0;
var hsv = [0, 1, 1];
var rgb = [0, 0, 0]; // prepare for finding the right patches
this._patchGrid.data.fill(0);
this._patchLabelGrid.data.fill(0);
this._imageToPatchGrid.fill(null);
patchesFound.forEach(function (patch) {
_this4._imageToPatchGrid[patch.index] = patch;
_this4._patchGrid.data[patch.index] = 1;
}); // rasterize the patches found to determine area
this._patchGrid.zeroBorder();
var currentIndex = 0;
while ((currentIndex = this._notYetProcessed()) < this._patchLabelGrid.data.length) {
label++;
this._trace(currentIndex, label);
} // draw patch-labels if requested
if ( true && this._config.debug && this._config.debug.showPatchLabels) {
for (var j = 0; j < this._patchLabelGrid.data.length; j++) {
if (this._patchLabelGrid.data[j] > 0 && this._patchLabelGrid.data[j] <= label) {
var patch = this._imageToPatchGrid[j];
hsv[0] = this._patchLabelGrid.data[j] / (label + 1) * 360;
Object(_common_hsv2rgb__WEBPACK_IMPORTED_MODULE_4__["hsv2rgb"])(hsv, rgb);
this._drawRect(patch.pos, this._subImageWrapper.size, "rgb(".concat(rgb.join(','), ")"), 2);
}
}
}
return label;
}
}, {
key: "_drawRect",
value: function _drawRect(_ref9, size, color, lineWidth) {
var x = _ref9.x,
y = _ref9.y;
this._binaryContext.strokeStyle = color;
this._binaryContext.fillStyle = color;
this._binaryContext.lineWidth = lineWidth || 1;
this._binaryContext.strokeRect(x, y, size.x, size.y);
}
}, {
key: "_drawPath",
value: function _drawPath(path, color, lineWidth) {
_common_image_debug__WEBPACK_IMPORTED_MODULE_5__["ImageDebug"].drawPath(path, this._binaryContext, color, lineWidth);
}
}]);
return BarcodeLocator;
}();
/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../node_modules/webpack/buildin/global.js */ "./node_modules/webpack/buildin/global.js")))
/***/ }),
/***/ "./src/locator/rasterizer.ts":
/*!***********************************!*\
!*** ./src/locator/rasterizer.ts ***!
\***********************************/
/*! exports provided: Rasterizer */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Rasterizer", function() { return Rasterizer; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _tracer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./tracer */ "./src/locator/tracer.ts");
/**
* @borrows http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization
*/
var EdgeLabel;
(function (EdgeLabel) {
EdgeLabel[EdgeLabel["Outside"] = -32767] = "Outside";
EdgeLabel[EdgeLabel["Inside"] = -32766] = "Inside";
})(EdgeLabel || (EdgeLabel = {}));
;
var ContourDirection;
(function (ContourDirection) {
ContourDirection[ContourDirection["CW"] = 0] = "CW";
ContourDirection[ContourDirection["CCW"] = 1] = "CCW";
ContourDirection[ContourDirection["Unknown"] = 2] = "Unknown";
})(ContourDirection || (ContourDirection = {}));
;
var Rasterizer =
/*#__PURE__*/
function () {
function Rasterizer(imageWrapper, labelWrapper) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Rasterizer);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_width", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_height", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_tracer", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_imageData", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_labelData", void 0);
this._imageData = imageWrapper.data;
this._labelData = labelWrapper.data;
this._width = imageWrapper.size.x;
this._height = imageWrapper.size.y;
this._tracer = new _tracer__WEBPACK_IMPORTED_MODULE_3__["Tracer"](imageWrapper, labelWrapper);
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Rasterizer, [{
key: "rasterize",
value: function rasterize(depthLabel) {
var colorMap = new Array();
for (var i = 0; i < 400; i++) {
colorMap[i] = 0;
}
colorMap[0] = this._imageData[0];
var cc = null;
var sc;
var connectedCount = 0;
for (var cy = 1; cy < this._height - 1; cy++) {
var labelIndex = 0;
var bc = colorMap[0];
for (var cx = 1; cx < this._width - 1; cx++) {
var pos = cy * this._width + cx;
if (this._labelData[pos] === 0) {
var color = this._imageData[pos];
if (color !== bc) {
if (labelIndex === 0) {
var lc = connectedCount + 1;
colorMap[lc] = color;
bc = color;
var vertex = this._tracer.contourTracing(cy, cx, lc, color, EdgeLabel.Outside);
if (vertex !== null) {
connectedCount++;
labelIndex = lc;
var p = {
dir: ContourDirection.CW,
index: labelIndex,
firstVertex: vertex,
nextPeer: cc,
insideContours: null
};
if (cc !== null) {
cc.previousPeer = p;
}
cc = p;
}
} else {
var _vertex = this._tracer.contourTracing(cy, cx, EdgeLabel.Inside, color, labelIndex);
if (_vertex !== null) {
var _p = {
dir: depthLabel === 0 ? ContourDirection.CCW : ContourDirection.CW,
firstVertex: _vertex,
index: depthLabel,
insideContours: null
};
sc = cc;
while (sc !== null && sc.index !== labelIndex) {
sc = sc.nextPeer;
}
if (sc !== null) {
_p.nextPeer = sc.insideContours;
if (sc.insideContours !== null) {
sc.insideContours.previousPeer = _p;
}
sc.insideContours = _p;
}
}
}
} else {
this._labelData[pos] = labelIndex;
}
} else if (this._labelData[pos] === EdgeLabel.Inside) {
labelIndex = 0;
bc = this._imageData[pos];
} else if (this._labelData[pos] === EdgeLabel.Outside) {
labelIndex = 0;
bc = colorMap[0];
} else {
labelIndex = this._labelData[pos];
bc = colorMap[labelIndex];
}
}
}
sc = cc;
while (sc !== null) {
sc.index = depthLabel;
sc = sc.nextPeer;
}
return {
cc: cc,
count: connectedCount
};
}
}, {
key: "drawContour",
value: function drawContour(canvas, firstContour) {
var context = canvas.getContext('2d');
context.strokeStyle = 'red';
context.fillStyle = 'red';
context.lineWidth = 1;
var pq = firstContour;
var iq = pq && pq.insideContours;
while (pq !== null) {
var q = iq || pq;
if (iq !== null) {
iq = iq.nextPeer;
} else {
pq = pq.nextPeer;
iq = pq && pq.insideContours;
}
switch (q.dir) {
case ContourDirection.CW:
{
context.strokeStyle = 'red';
break;
}
case ContourDirection.CCW:
{
context.strokeStyle = 'blue';
break;
}
case ContourDirection.Unknown:
{
context.strokeStyle = 'green';
break;
}
}
var p = q.firstVertex;
context.beginPath();
context.moveTo(p.x, p.y);
do {
p = p.next;
context.lineTo(p.x, p.y);
} while (p !== q.firstVertex);
context.stroke();
}
}
}]);
return Rasterizer;
}();
/***/ }),
/***/ "./src/locator/skeletonizer.js":
/*!*************************************!*\
!*** ./src/locator/skeletonizer.js ***!
\*************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* 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
};
}
/* harmony default export */ __webpack_exports__["default"] = (Skeletonizer);
/* eslint-enable eqeqeq */
/***/ }),
/***/ "./src/locator/tracer.ts":
/*!*******************************!*\
!*** ./src/locator/tracer.ts ***!
\*******************************/
/*! exports provided: SearchDirections, Tracer */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SearchDirections", function() { return SearchDirections; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Tracer", function() { return Tracer; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
/**
* @borrows http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization
*/
var SearchDirections = [[0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [-1, -1], [-1, 0], [-1, 1]];
var Tracer =
/*#__PURE__*/
function () {
function Tracer(imageWrapper, labelWrapper) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Tracer);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_imageData", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_labelData", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_width", void 0);
this._imageData = imageWrapper.data;
this._labelData = labelWrapper.data;
this._width = imageWrapper.size.x;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Tracer, [{
key: "trace",
value: function trace(current, color, label, edgeLabel) {
for (var i = 0; i < 7; i++) {
var y = current.cy + SearchDirections[current.dir][0] | 0;
var x = current.cx + SearchDirections[current.dir][1] | 0;
var pos = y * this._width + x | 0;
if (this._imageData[pos] === color && (this._labelData[pos] === 0 || this._labelData[pos] === label)) {
this._labelData[pos] = label;
current.cx = x;
current.cy = y;
return true;
} else {
if (this._labelData[pos] === 0) {
this._labelData[pos] = edgeLabel;
}
current.dir = (current.dir + 1) % 8;
}
}
return false;
}
}, {
key: "contourTracing",
value: function contourTracing(sy, sx, label, color, edgeLabel) {
var Fv = null;
var current = {
cx: sx,
cy: sy,
dir: 0
};
if (this.trace(current, color, label, edgeLabel)) {
Fv = {
x: sx,
y: sy,
dir: current.dir,
next: null,
prev: null
};
var Cv = Fv;
var ldir = current.dir;
var P = {
x: current.cx,
y: current.cy,
dir: 0,
next: null,
prev: Cv
};
Cv.next = P;
Cv = P;
do {
current.dir = (current.dir + 6) % 8;
this.trace(current, color, label, edgeLabel);
if (ldir !== current.dir) {
Cv.dir = current.dir;
P = {
x: current.cx,
y: current.cy,
dir: 0,
next: null,
prev: Cv
};
Cv.next = P;
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 Tracer;
}();
/***/ }),
/***/ "./src/quagga.ts":
/*!***********************!*\
!*** ./src/quagga.ts ***!
\***********************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _analytics_result_collector__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./analytics/result-collector */ "./src/analytics/result-collector.ts");
/* harmony import */ var _common_events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./common/events */ "./src/common/events.ts");
/* harmony import */ var _common_image_debug__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./common/image-debug */ "./src/common/image-debug.ts");
/* harmony import */ var _common_image_wrapper__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./common/image-wrapper */ "./src/common/image-wrapper.ts");
/* harmony import */ var _common_merge__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./common/merge */ "./src/common/merge.ts");
/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./config/config */ "./src/config/config.dev.ts");
/* harmony import */ var _decoder_barcode_decoder__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./decoder/barcode-decoder */ "./src/decoder/barcode-decoder.ts");
/* harmony import */ var _input_camera_access__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./input/camera-access */ "./src/input/camera-access.ts");
/* harmony import */ var _input_frame_grabber__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./input/frame-grabber */ "./src/input/frame-grabber.ts");
/* harmony import */ var _input_image_stream__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./input/image-stream */ "./src/input/image-stream.ts");
/* harmony import */ var _input_live_stream__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./input/live-stream */ "./src/input/live-stream.ts");
/* harmony import */ var _input_video_stream__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./input/video-stream */ "./src/input/video-stream.ts");
/* harmony import */ var _input_input_stream_utils__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./input/input-stream-utils */ "./src/input/input-stream-utils.ts");
/* harmony import */ var _locator_barcode_locator__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./locator/barcode-locator */ "./src/locator/barcode-locator.ts");
var _inputStream;
var _frameGrabber;
var _stopped;
var _canvasContainer = {
ctx: {
image: null,
overlay: null
},
dom: {
image: null,
overlay: null
}
};
var _inputImageWrapper;
var _locator;
var _boxSize;
var _decoder;
var _workerPool = new Array();
var _onUIThread;
var _resultCollector;
var _config;
/* harmony default export */ __webpack_exports__["default"] = ({
init: function init(config, cb, imageWrapper) {
_onUIThread = true;
_config = Object(_common_merge__WEBPACK_IMPORTED_MODULE_4__["merge"])(_config_config__WEBPACK_IMPORTED_MODULE_5__["config"], config);
if (imageWrapper) {
_onUIThread = false;
_initializeData(imageWrapper);
cb();
} else {
_initInputStream(cb);
}
},
CameraAccess: _input_camera_access__WEBPACK_IMPORTED_MODULE_7__["CameraAccess"],
ImageDebug: _common_image_debug__WEBPACK_IMPORTED_MODULE_2__["ImageDebug"],
ImageWrapper: _common_image_wrapper__WEBPACK_IMPORTED_MODULE_3__["ImageWrapper"],
ResultCollector: _analytics_result_collector__WEBPACK_IMPORTED_MODULE_0__["ResultCollector"],
get canvas() {
return _canvasContainer;
},
start: function start() {
if (_onUIThread && _config.inputStream.type === 'LiveStream') {
_startContinuousUpdate();
} else {
_update();
}
},
stop: function stop() {
_stopped = true;
_adjustWorkerPool(0);
if (_config.inputStream.type === 'LiveStream') {
_input_camera_access__WEBPACK_IMPORTED_MODULE_7__["CameraAccess"].release();
_inputStream.clearEventHandlers();
}
},
decodeSingle: function decodeSingle(config, resultCallback) {
var _this = this;
config = Object(_common_merge__WEBPACK_IMPORTED_MODULE_4__["merge"])({
inputStream: {
type: 'ImageStream',
sequence: false,
size: 800,
src: config.src
},
numOfWorkers: true && config.debug ? 0 : 1,
locator: {
halfSample: false
}
}, config);
this.init(config, function () {
_common_events__WEBPACK_IMPORTED_MODULE_1__["Events"].once('processed', function (result) {
_this.stop();
resultCallback.call(null, result);
}, true);
_this.start();
});
},
pause: function pause() {
_stopped = true;
},
onDetected: function onDetected(callback) {
_common_events__WEBPACK_IMPORTED_MODULE_1__["Events"].subscribe('detected', callback);
},
offDetected: function offDetected(callback) {
_common_events__WEBPACK_IMPORTED_MODULE_1__["Events"].unsubscribe('detected', callback);
},
onProcessed: function onProcessed(callback) {
_common_events__WEBPACK_IMPORTED_MODULE_1__["Events"].subscribe('processed', callback);
},
offProcessed: function offProcessed(callback) {
_common_events__WEBPACK_IMPORTED_MODULE_1__["Events"].unsubscribe('processed', callback);
},
setReaders: function setReaders(readers) {
if (_decoder) {
_decoder.setReaders(readers);
} else if (_onUIThread && _workerPool.length > 0) {
_workerPool.forEach(function (_ref) {
var worker = _ref.worker;
return worker.postMessage({
cmd: 'setReaders',
readers: readers
});
});
}
},
registerResultCollector: function registerResultCollector(resultCollector) {
if (resultCollector && typeof resultCollector.addResult === 'function') {
_resultCollector = resultCollector;
}
}
});
function _initializeData(imageWrapper) {
_initBuffers(imageWrapper);
_decoder = new _decoder_barcode_decoder__WEBPACK_IMPORTED_MODULE_6__["BarcodeDecoder"](_config.decoder, _inputImageWrapper);
}
function _initInputStream(callback) {
var video;
if (_config.inputStream.type === 'VideoStream') {
video = document.createElement('video');
_inputStream = new _input_video_stream__WEBPACK_IMPORTED_MODULE_11__["VideoStream"](video);
} else if (_config.inputStream.type === 'ImageStream') {
_inputStream = new _input_image_stream__WEBPACK_IMPORTED_MODULE_9__["ImageStream"]();
} 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 = new _input_live_stream__WEBPACK_IMPORTED_MODULE_10__["LiveStream"](video);
_input_camera_access__WEBPACK_IMPORTED_MODULE_7__["CameraAccess"].request(video, _config.inputStream.constraints).then(function () {
return _inputStream.trigger('canrecord');
}, function (err) {
return callback(err);
});
}
_inputStream.setAttribute('preload', 'auto');
_inputStream.config = _config.inputStream;
_inputStream.addEventListener('canrecord', _canRecord.bind(this, callback));
}
function _getViewPort() {
var target = _config.inputStream.target; // Check if target is already a DOM element
if (target instanceof HTMLElement) {
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) {
Object(_input_input_stream_utils__WEBPACK_IMPORTED_MODULE_12__["checkImageConstraints"])(_inputStream, _config.locator);
_initCanvas();
_frameGrabber = new _input_frame_grabber__WEBPACK_IMPORTED_MODULE_8__["FrameGrabber"](_inputStream, _canvasContainer.dom.image);
_adjustWorkerPool(_config.numOfWorkers, function () {
if (_config.numOfWorkers === 0) {
_initializeData();
}
_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.canvasWidth;
_canvasContainer.dom.image.height = _inputStream.canvasHeight;
_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.canvasWidth;
_canvasContainer.dom.overlay.height = _inputStream.canvasHeight;
}
}
function _initBuffers(imageWrapper) {
if (imageWrapper) {
_inputImageWrapper = imageWrapper;
} else {
_inputImageWrapper = new _common_image_wrapper__WEBPACK_IMPORTED_MODULE_3__["ImageWrapper"]({
x: _inputStream.width,
y: _inputStream.height
});
}
if (true) {
console.log(_inputImageWrapper.size);
}
_boxSize = [{
x: 0,
y: 0
}, {
x: 0,
y: _inputImageWrapper.size.y
}, {
x: _inputImageWrapper.size.x,
y: _inputImageWrapper.size.y
}, {
x: _inputImageWrapper.size.x,
y: 0
}];
_locator = new _locator_barcode_locator__WEBPACK_IMPORTED_MODULE_13__["BarcodeLocator"](_inputImageWrapper, _config.locator);
}
function _transform(polygon, offset) {
polygon.forEach(function (vertex) {
vertex.x += offset.x;
vertex.y += offset.y;
});
}
function _transformResult(result, offset) {
if (result.barcodes) {
result.barcodes.forEach(function (barcode) {
return _transformResult(barcode, offset);
});
}
if (result.line) {
_transform(result.line, offset);
}
if (result.box) {
_transform(result.box, offset);
}
if (result.boxes) {
result.boxes.forEach(function (box) {
return _transform(box, offset);
});
}
}
function _addResult(result, imageData, canvasWidth, canvasHeight) {
if (imageData && _resultCollector) {
if (result.barcodes) {
result.barcodes.forEach(function (_ref2) {
var codeResult = _ref2.codeResult;
if (codeResult) {
_resultCollector.addResult(imageData, canvasWidth, canvasHeight, codeResult);
}
});
} else if (result.codeResult) {
_resultCollector.addResult(imageData, canvasWidth, canvasHeight, result.codeResult);
}
}
}
function _hasCodeResult(result) {
return result && (!!result.codeResult || result.barcodes && result.barcodes.some(function (barcode) {
return !!barcode.codeResult;
}));
}
function _publishResult(result, imageData) {
var resultToPublish = result;
if (result && _onUIThread) {
var offset = _inputStream.topLeft;
if (offset.x !== 0 || offset.y !== 0) {
_transformResult(result, offset);
}
_addResult(result, imageData, _inputStream.canvasWidth, _inputStream.canvasHeight);
resultToPublish = result.barcodes || result;
}
_common_events__WEBPACK_IMPORTED_MODULE_1__["Events"].publish('processed', resultToPublish);
if (_hasCodeResult(result)) {
_common_events__WEBPACK_IMPORTED_MODULE_1__["Events"].publish('detected', resultToPublish);
}
}
function _locateAndDecode() {
var boxes = _config.locate ? _locator.locate() : [_boxSize];
var result = _decoder.decodeFromBoundingBoxes(boxes);
_publishResult(result, _inputImageWrapper.data);
}
function _update() {
if (_onUIThread) {
if (_workerPool.length > 0) {
var availableWorker = _workerPool.find(function (_ref3) {
var busy = _ref3.busy;
return !busy;
});
if (!availableWorker) {
return; // all workers are busy
}
var imageData = availableWorker.imageData;
if (_frameGrabber.grab(imageData)) {
availableWorker.busy = true;
availableWorker.worker.postMessage({
cmd: 'process',
imageData: imageData
}, [imageData.buffer]);
}
} else if (_frameGrabber.grab(_inputImageWrapper.data)) {
_locateAndDecode();
}
} else {
_locateAndDecode();
}
}
function _startContinuousUpdate() {
var delay = 1000 / (_config.frequency || 60);
var next = null;
_stopped = false;
(function frame(timestamp) {
next = next || timestamp;
if (!_stopped) {
if (timestamp >= next) {
next += delay;
_update();
}
window.requestAnimationFrame(frame);
}
})(performance.now());
}
function _initWorker(cb) {
var blobURL = _generateWorkerBlob();
var workerThread = {
worker: new Worker(blobURL),
imageData: new Uint8Array(_inputStream.width * _inputStream.height),
busy: true
};
workerThread.worker.onmessage = function (_ref4) {
var data = _ref4.data;
if (data.event === 'initialized') {
URL.revokeObjectURL(blobURL);
workerThread.busy = false;
workerThread.imageData = new Uint8Array(data.imageData);
if (true) {
console.log('Worker initialized');
}
cb(workerThread);
} else if (data.event === 'processed') {
workerThread.busy = false;
workerThread.imageData = new Uint8Array(data.imageData);
_publishResult(data.result, workerThread.imageData);
} else if (data.event === 'error') {
if (true) {
console.log('Worker error:', data.message);
}
}
};
workerThread.worker.postMessage({
cmd: 'init',
size: {
x: _inputStream.width,
y: _inputStream.height
},
imageData: workerThread.imageData,
config: Object(_common_merge__WEBPACK_IMPORTED_MODULE_4__["merge"])(_config, {
inputStream: {
target: null
}
})
}, [workerThread.imageData.buffer]);
}
function _workerInterface(factory) {
var Quagga;
var worker = self;
var imageWrapper;
if (factory) {
Quagga = factory()["default"];
if (!Quagga) {
worker.postMessage({
event: 'error',
message: 'Quagga could not be created'
});
return;
}
}
self.onmessage = function (_ref5) {
var data = _ref5.data;
if (data.cmd === 'init') {
var config = data.config;
config.numOfWorkers = 0;
imageWrapper = new Quagga.ImageWrapper({
x: data.size.x,
y: data.size.y
}, new Uint8Array(data.imageData));
Quagga.init(config, function () {
return worker.postMessage({
event: 'initialized',
imageData: imageWrapper.data
}, [imageWrapper.data.buffer]);
}, imageWrapper);
Quagga.onProcessed(function (result) {
return worker.postMessage({
event: 'processed',
imageData: imageWrapper.data,
result: result
}, [imageWrapper.data.buffer]);
});
} else if (data.cmd === 'process') {
imageWrapper.data = new Uint8Array(data.imageData);
Quagga.start();
} else if (data.cmd === 'setReaders') {
Quagga.setReaders(data.readers);
}
};
}
function _generateWorkerBlob() {
// @ts-ignore
var factorySource = __factorySource__ || '';
var blob = new Blob(["(".concat(_workerInterface.toString(), ")(").concat(factorySource, ");")], {
type: 'text/javascript'
});
return window.URL.createObjectURL(blob);
}
function _adjustWorkerPool(capacity, cb) {
var increaseBy = capacity - _workerPool.length;
if (increaseBy > 0) {
for (var i = 0; i < increaseBy; i++) {
_initWorker(function (workerThread) {
_workerPool.push(workerThread);
if (_workerPool.length >= capacity && cb) {
cb();
}
});
}
} else {
if (increaseBy < 0) {
_workerPool.slice(increaseBy).forEach(function (_ref6) {
var worker = _ref6.worker;
worker.terminate();
if (true) {
console.log('Worker terminated!');
}
});
_workerPool = _workerPool.slice(0, increaseBy);
}
return cb && cb();
}
}
/***/ }),
/***/ "./src/reader/2of5-reader.ts":
/*!***********************************!*\
!*** ./src/reader/2of5-reader.ts ***!
\***********************************/
/*! exports provided: TwoOfFiveReader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TwoOfFiveReader", function() { return TwoOfFiveReader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/assertThisInitialized */ "../../node_modules/@babel/runtime/helpers/assertThisInitialized.js");
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6__);
/* harmony import */ var _barcode_reader__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./barcode-reader */ "./src/reader/barcode-reader.ts");
var N = 1;
var W = 3;
var START_PATTERN = [W, N, W, N, N, N];
var STOP_PATTERN = [W, N, N, N, W];
var CODE_PATTERN = [[N, N, W, W, N], [W, N, N, N, W], [N, W, N, N, W], [W, W, N, N, N], [N, N, W, N, W], [W, N, W, N, N], [N, W, W, N, N], [N, N, N, W, W], [W, N, N, W, N], [N, W, N, W, N]];
var startPatternLength = START_PATTERN.reduce(function (sum, val) {
return sum + val;
}, 0);
var TwoOfFiveReader =
/*#__PURE__*/
function (_BarcodeReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default()(TwoOfFiveReader, _BarcodeReader);
function TwoOfFiveReader(config) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, TwoOfFiveReader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(TwoOfFiveReader).call(this, config));
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_6___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_4___default()(_this), "_barSpaceRatio", void 0);
_this._barSpaceRatio = [1, 1];
_this._format = '2of5';
_this._singleCodeError = 0.78;
_this._averageCodeError = 0.30;
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(TwoOfFiveReader, [{
key: "decode",
value: function decode() {
var startInfo = this._findStart();
if (!startInfo) {
return null;
}
var endInfo = this._findEnd();
if (!endInfo) {
return null;
}
var counters = this._fillCounters(startInfo.end, endInfo.start, 0);
if (counters.length % 10 !== 0) {
return null;
}
var result = new Array();
var decodedCodes = new Array();
decodedCodes.push(startInfo);
var code = this._decodePayload(counters, result, decodedCodes);
if (!code || result.length < 5) {
return null;
}
decodedCodes.push(endInfo);
return {
code: result.join(''),
start: startInfo.start,
end: endInfo.end,
startInfo: startInfo,
decodedCodes: decodedCodes
};
}
}, {
key: "_findStart",
value: function _findStart() {
var offset = this._nextSet(this._row);
var narrowBarWidth = 1;
var startInfo;
while (!startInfo) {
startInfo = this._findPattern(START_PATTERN, offset, 0, true);
if (!startInfo) {
return null;
}
narrowBarWidth = (startInfo.end - startInfo.start) / startPatternLength | 0;
var leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5;
if (leadingWhitespaceStart >= 0) {
if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
return startInfo;
}
}
offset = startInfo.end;
startInfo = null;
}
return null;
}
}, {
key: "_verifyTrailingWhitespace",
value: function _verifyTrailingWhitespace(endInfo) {
var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;
if (trailingWhitespaceEnd < this._row.length) {
if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
return endInfo;
}
}
return null;
}
}, {
key: "_findEnd",
value: function _findEnd() {
this._row.reverse();
var offset = this._nextSet(this._row);
var endInfo = this._findPattern(STOP_PATTERN, offset, 0, true);
this._row.reverse();
if (endInfo === null) {
return null;
} // reverse numbers
var start = endInfo.start;
endInfo.start = this._row.length - endInfo.end;
endInfo.end = this._row.length - start;
return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;
}
}, {
key: "_decodeCode",
value: function _decodeCode(counter) {
var bestMatch = {
error: Number.MAX_VALUE,
code: -1,
start: 0,
end: 0
};
for (var code = 0; code < CODE_PATTERN.length; code++) {
var error = this._matchPattern(counter, CODE_PATTERN[code]);
if (error < bestMatch.error) {
bestMatch.code = code;
bestMatch.error = error;
}
}
return bestMatch.error < this.AVERAGE_CODE_ERROR ? bestMatch : null;
}
}, {
key: "_decodePayload",
value: function _decodePayload(counters, result, decodedCodes) {
var counterLength = counters.length;
var counter = [0, 0, 0, 0, 0];
var pos = 0;
var code;
while (pos < counterLength) {
for (var i = 0; i < 5; i++) {
counter[i] = counters[pos] * this._barSpaceRatio[0];
pos += 2;
}
code = this._decodeCode(counter);
if (!code) {
return null;
}
result.push(code.code);
decodedCodes.push(code);
}
return code;
}
}]);
return TwoOfFiveReader;
}(_barcode_reader__WEBPACK_IMPORTED_MODULE_7__["BarcodeReader"]);
/***/ }),
/***/ "./src/reader/barcode-reader.ts":
/*!**************************************!*\
!*** ./src/reader/barcode-reader.ts ***!
\**************************************/
/*! exports provided: BarcodeDirection, BarcodeReader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BarcodeDirection", function() { return BarcodeDirection; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BarcodeReader", function() { return BarcodeReader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2__);
var BarcodeDirection;
(function (BarcodeDirection) {
BarcodeDirection[BarcodeDirection["Forward"] = 1] = "Forward";
BarcodeDirection[BarcodeDirection["Reverse"] = -1] = "Reverse";
})(BarcodeDirection || (BarcodeDirection = {}));
;
var BarcodeReader =
/*#__PURE__*/
function () {
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(BarcodeReader, [{
key: "SINGLE_CODE_ERROR",
get: function get() {
return this._singleCodeError;
}
}, {
key: "AVERAGE_CODE_ERROR",
get: function get() {
return this._averageCodeError;
}
}, {
key: "FORMAT",
get: function get() {
return this._format;
}
}], [{
key: "Exception",
get: function get() {
return {
StartNotFoundException: 'Start-Info was not found!',
CodeNotFoundException: 'Code could not be found!',
PatternNotFoundException: 'Pattern could not be found!'
};
}
}]);
function BarcodeReader(config, supplements) {
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, BarcodeReader);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_singleCodeError", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_averageCodeError", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_format", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "_row", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "config", void 0);
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_2___default()(this, "supplements", void 0);
this._format = 'unknown';
this._row = [];
this.config = config || {};
this.supplements = supplements;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(BarcodeReader, [{
key: "_findPattern",
value: function _findPattern(pattern, offset, isWhite, tryHarder) {
var counter = new Array(pattern.length);
var bestMatch = {
error: Number.MAX_VALUE,
code: -1,
start: 0,
end: 0
};
var epsilon = this.AVERAGE_CODE_ERROR;
var counterPos = 0;
if (!offset) {
offset = this._nextSet(this._row);
}
counter.fill(0);
for (var i = offset; i < this._row.length; i++) {
if (this._row[i] ^ isWhite) {
counter[counterPos]++;
} else {
if (counterPos === counter.length - 1) {
var error = this._matchPattern(counter, pattern);
if (error < epsilon) {
bestMatch.error = error;
bestMatch.start = i - counter.reduce(function (sum, value) {
return sum + value;
}, 0);
bestMatch.end = i;
return bestMatch;
}
if (tryHarder) {
for (var j = 0; j < counter.length - 2; j++) {
counter[j] = counter[j + 2];
}
counter[counter.length - 2] = 0;
counter[counter.length - 1] = 0;
counterPos--;
} else {
return null;
}
} else {
counterPos++;
}
counter[counterPos] = 1;
isWhite = isWhite ? 0 : 1;
}
}
return null;
}
}, {
key: "_nextUnset",
value: function _nextUnset(line, start) {
for (var i = start || 0; i < line.length; i++) {
if (!line[i]) {
return i;
}
}
return line.length;
}
}, {
key: "_nextSet",
value: function _nextSet(line, start) {
for (var i = start || 0; i < line.length; i++) {
if (line[i]) {
return i;
}
}
return line.length;
}
}, {
key: "_matchRange",
value: function _matchRange(start, end, value) {
for (var i = start < 0 ? 0 : start; i < end; i++) {
if (this._row[i] !== value) {
return false;
}
}
return true;
}
}, {
key: "_matchPattern",
value: function _matchPattern(counter, code, maxSingleError) {
var error = 0;
var sum = 0;
var modulo = 0;
maxSingleError = maxSingleError || this.SINGLE_CODE_ERROR || 1;
for (var i = 0; i < counter.length; i++) {
sum += counter[i];
modulo += code[i];
}
if (sum < modulo) {
return Number.MAX_VALUE;
}
var barWidth = sum / modulo;
maxSingleError *= barWidth;
for (var _i = 0; _i < counter.length; _i++) {
var count = counter[_i];
var scaled = code[_i] * barWidth;
var singleError = Math.abs(count - scaled) / scaled;
if (singleError > maxSingleError) {
return Number.MAX_VALUE;
}
error += singleError;
}
return error / modulo;
}
}, {
key: "_correctBars",
value: function _correctBars(counter, correction, indices) {
var length = indices.length;
var tmp = 0;
while (length--) {
tmp = counter[indices[length]] * (1 - (1 - correction) / 2);
if (tmp > 1) {
counter[indices[length]] = tmp;
}
}
}
}, {
key: "decodePattern",
value: function decodePattern(pattern) {
this._row = pattern;
var result = this.decode();
if (result === null) {
this._row.reverse();
result = this.decode();
if (result) {
result.direction = BarcodeDirection.Reverse;
result.start = this._row.length - result.start;
result.end = this._row.length - result.end;
}
} else {
result.direction = BarcodeDirection.Forward;
}
if (result) {
result.format = this.FORMAT;
}
return result;
}
}, {
key: "_fillCounters",
value: function _fillCounters(offset, end, isWhite) {
var counters = new Array();
var counterPos = 0;
counters[counterPos] = 0;
for (var i = offset; i < end; i++) {
if (this._row[i] ^ isWhite) {
counters[counterPos]++;
} else {
counterPos++;
counters[counterPos] = 1;
isWhite = isWhite ? 0 : 1;
}
}
return counters;
}
}, {
key: "_toCounters",
value: function _toCounters(start, counters) {
var numCounters = counters.length;
var end = this._row.length;
var isWhite = this._row[start] ? 0 : 1;
var counterPos = 0;
counters.fill(0);
for (var i = start; i < end; i++) {
if (this._row[i] ^ isWhite) {
counters[counterPos]++;
} else {
counterPos++;
if (counterPos === numCounters) {
break;
} else {
counters[counterPos] = 1;
isWhite = isWhite ? 0 : 1;
}
}
}
return counters;
}
}]);
return BarcodeReader;
}();
/***/ }),
/***/ "./src/reader/codabar-reader.ts":
/*!**************************************!*\
!*** ./src/reader/codabar-reader.ts ***!
\**************************************/
/*! exports provided: CodabarReader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CodabarReader", function() { return CodabarReader; });
/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "../../node_modules/@babel/runtime/helpers/typeof.js");
/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/assertThisInitialized */ "../../node_modules/@babel/runtime/helpers/assertThisInitialized.js");
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7__);
/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ "../../node_modules/@babel/runtime/helpers/toConsumableArray.js");
/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_8___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_8__);
/* harmony import */ var _barcode_reader__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./barcode-reader */ "./src/reader/barcode-reader.ts");
var ALPHABETH_STRING = '0123456789-$:/.+ABCD';
var ALPHABET = _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_8___default()(ALPHABETH_STRING).map(function (_char) {
return _char.charCodeAt(0);
}); // const ALPHABET = [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 45, 36, 58, 47, 46, 43, 65, 66, 67, 68];
var CHARACTER_ENCODINGS = [0x003, 0x006, 0x009, 0x060, 0x012, 0x042, 0x021, 0x024, 0x030, 0x048, 0x00c, 0x018, 0x045, 0x051, 0x054, 0x015, 0x01A, 0x029, 0x00B, 0x00E];
var START_END = [0x01A, 0x029, 0x00B, 0x00E];
var MIN_ENCODED_CHARS = 4;
var MAX_ACCEPTABLE = 2.0;
var PADDING = 1.5;
var CodabarReader =
/*#__PURE__*/
function (_BarcodeReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6___default()(CodabarReader, _BarcodeReader);
function CodabarReader() {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1___default()(this, CodabarReader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_3___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default()(CodabarReader).call(this));
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_5___default()(_this), "_counters", void 0);
_this._format = 'codabar';
_this._counters = [];
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2___default()(CodabarReader, [{
key: "decode",
value: function decode() {
this._counters = this._fillCounters(this._nextUnset(this._row), this._row.length, 1);
var start = this._findStart();
if (!start) {
return null;
}
var result = new Array();
var nextStart = start.startCounter;
var pattern;
do {
pattern = this._toPattern(nextStart);
if (pattern < 0) {
return null;
}
var decodedChar = this._patternToChar(pattern);
if (decodedChar === null) {
return null;
}
result.push(decodedChar);
nextStart += 8;
if (result.length > 1 && START_END.some(function (code) {
return code === pattern;
})) {
break;
}
} while (nextStart < this._counters.length); // verify end
if (result.length - 2 < MIN_ENCODED_CHARS || !START_END.some(function (code) {
return code === pattern;
})) {
return null;
} // verify end white space
if (!this._verifyWhitespace(start.startCounter, nextStart - 8)) {
return null;
}
if (!this._validateResult(result, start.startCounter)) {
return null;
}
nextStart = nextStart > this._counters.length ? this._counters.length : nextStart;
var end = start.start + this._sumCounters(start.startCounter, nextStart - 8);
return {
code: result.join(''),
start: start.start,
end: end,
startInfo: start,
decodedCodes: result
};
}
}, {
key: "_verifyWhitespace",
value: function _verifyWhitespace(startCounter, endCounter) {
if (startCounter - 1 <= 0 || this._counters[startCounter - 1] >= this._calculatePatternLength(startCounter) / 2.0) {
if (endCounter + 8 >= this._counters.length || this._counters[endCounter + 7] >= this._calculatePatternLength(endCounter) / 2.0) {
return true;
}
}
return false;
}
}, {
key: "_calculatePatternLength",
value: function _calculatePatternLength(offset) {
var sum = 0;
for (var i = offset; i < offset + 7; i++) {
sum += this._counters[i];
}
return sum;
}
}, {
key: "_thresholdResultPattern",
value: function _thresholdResultPattern(result, startCounter) {
var categorization = {
space: {
narrow: {
size: 0,
counts: 0,
min: 0,
max: Number.MAX_VALUE
},
wide: {
size: 0,
counts: 0,
min: 0,
max: Number.MAX_VALUE
}
},
bar: {
narrow: {
size: 0,
counts: 0,
min: 0,
max: Number.MAX_VALUE
},
wide: {
size: 0,
counts: 0,
min: 0,
max: Number.MAX_VALUE
}
}
};
var pos = startCounter;
for (var i = 0; i < result.length; i++) {
var pattern = this._charToPattern(result[i]);
for (var j = 6; j >= 0; j--) {
var kind = (j & 1) === 2 ? categorization.bar : categorization.space;
var cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;
cat.size += this._counters[pos + j];
cat.counts++;
pattern >>= 1;
}
pos += 8;
}
['space', 'bar'].forEach(function (key) {
var kind = categorization[key];
kind.wide.min = Math.floor((kind.narrow.size / kind.narrow.counts + kind.wide.size / kind.wide.counts) / 2);
kind.narrow.max = Math.ceil(kind.wide.min);
kind.wide.max = Math.ceil((kind.wide.size * MAX_ACCEPTABLE + PADDING) / kind.wide.counts);
});
return categorization;
}
}, {
key: "_charToPattern",
value: function _charToPattern(_char2) {
var charCode = _char2.charCodeAt(0);
for (var i = 0; i < ALPHABET.length; i++) {
if (ALPHABET[i] === charCode) {
return CHARACTER_ENCODINGS[i];
}
}
return 0x0;
}
}, {
key: "_validateResult",
value: function _validateResult(result, startCounter) {
var threshold = this._thresholdResultPattern(result, startCounter);
var pos = startCounter;
for (var i = 0; i < result.length; i++) {
var pattern = this._charToPattern(result[i]);
for (var j = 6; j >= 0; j--) {
var kind = (j & 1) === 0 ? threshold.bar : threshold.space;
var cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;
var size = this._counters[pos + j];
if (size < cat.min || size > cat.max) {
return false;
}
pattern >>= 1;
}
pos += 8;
}
return true;
}
}, {
key: "_patternToChar",
value: function _patternToChar(pattern) {
for (var i = 0; i < CHARACTER_ENCODINGS.length; i++) {
if (CHARACTER_ENCODINGS[i] === pattern) {
return String.fromCharCode(ALPHABET[i]);
}
}
return null;
}
}, {
key: "_computeAlternatingThreshold",
value: function _computeAlternatingThreshold(offset, end) {
var min = Number.MAX_VALUE;
var max = 0;
for (var i = offset; i < end; i += 2) {
var counter = this._counters[i];
if (counter > max) {
max = counter;
}
if (counter < min) {
min = counter;
}
}
return (min + max) / 2.0 | 0;
}
}, {
key: "_toPattern",
value: function _toPattern(offset) {
var numCounters = 7;
var end = offset + numCounters;
if (end > this._counters.length) {
return -1;
}
var barThreshold = this._computeAlternatingThreshold(offset, end);
var spaceThreshold = this._computeAlternatingThreshold(offset + 1, end);
var bitmask = 1 << numCounters - 1;
var pattern = 0;
for (var i = 0; i < numCounters; i++) {
var threshold = (i & 1) === 0 ? barThreshold : spaceThreshold;
if (this._counters[offset + i] > threshold) {
pattern |= bitmask;
}
bitmask >>= 1;
}
return pattern;
}
}, {
key: "_sumCounters",
value: function _sumCounters(start, end) {
var sum = 0;
for (var i = start; i < end; i++) {
sum += this._counters[i];
}
return sum;
}
}, {
key: "_findStart",
value: function _findStart() {
var _this2 = this;
var start = this._nextUnset(this._row);
var _loop = function _loop(i) {
var pattern = _this2._toPattern(i);
if (pattern !== -1 && START_END.some(function (code) {
return code === pattern;
})) {
// TODO: Look for whitespace ahead
start += _this2._sumCounters(0, i);
var end = start + _this2._sumCounters(i, i + 8);
return {
v: {
start: start,
end: end,
startCounter: i,
endCounter: i + 8
}
};
}
};
for (var i = 1; i < this._counters.length; i++) {
var _ret = _loop(i);
if (_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(_ret) === "object") return _ret.v;
}
return null;
}
}]);
return CodabarReader;
}(_barcode_reader__WEBPACK_IMPORTED_MODULE_9__["BarcodeReader"]);
/***/ }),
/***/ "./src/reader/code-128-reader.ts":
/*!***************************************!*\
!*** ./src/reader/code-128-reader.ts ***!
\***************************************/
/*! exports provided: Code128Reader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Code128Reader", function() { return Code128Reader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _barcode_reader__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./barcode-reader */ "./src/reader/barcode-reader.ts");
var CODE_SHIFT = 98;
var CODE_C = 99;
var CODE_B = 100;
var CODE_A = 101;
var START_CODE_A = 103;
var START_CODE_B = 104;
var START_CODE_C = 105;
var STOP_CODE = 106;
var CODE_PATTERN = [[2, 1, 2, 2, 2, 2], [2, 2, 2, 1, 2, 2], [2, 2, 2, 2, 2, 1], [1, 2, 1, 2, 2, 3], [1, 2, 1, 3, 2, 2], [1, 3, 1, 2, 2, 2], [1, 2, 2, 2, 1, 3], [1, 2, 2, 3, 1, 2], [1, 3, 2, 2, 1, 2], [2, 2, 1, 2, 1, 3], [2, 2, 1, 3, 1, 2], [2, 3, 1, 2, 1, 2], [1, 1, 2, 2, 3, 2], [1, 2, 2, 1, 3, 2], [1, 2, 2, 2, 3, 1], [1, 1, 3, 2, 2, 2], [1, 2, 3, 1, 2, 2], [1, 2, 3, 2, 2, 1], [2, 2, 3, 2, 1, 1], [2, 2, 1, 1, 3, 2], [2, 2, 1, 2, 3, 1], [2, 1, 3, 2, 1, 2], [2, 2, 3, 1, 1, 2], [3, 1, 2, 1, 3, 1], [3, 1, 1, 2, 2, 2], [3, 2, 1, 1, 2, 2], [3, 2, 1, 2, 2, 1], [3, 1, 2, 2, 1, 2], [3, 2, 2, 1, 1, 2], [3, 2, 2, 2, 1, 1], [2, 1, 2, 1, 2, 3], [2, 1, 2, 3, 2, 1], [2, 3, 2, 1, 2, 1], [1, 1, 1, 3, 2, 3], [1, 3, 1, 1, 2, 3], [1, 3, 1, 3, 2, 1], [1, 1, 2, 3, 1, 3], [1, 3, 2, 1, 1, 3], [1, 3, 2, 3, 1, 1], [2, 1, 1, 3, 1, 3], [2, 3, 1, 1, 1, 3], [2, 3, 1, 3, 1, 1], [1, 1, 2, 1, 3, 3], [1, 1, 2, 3, 3, 1], [1, 3, 2, 1, 3, 1], [1, 1, 3, 1, 2, 3], [1, 1, 3, 3, 2, 1], [1, 3, 3, 1, 2, 1], [3, 1, 3, 1, 2, 1], [2, 1, 1, 3, 3, 1], [2, 3, 1, 1, 3, 1], [2, 1, 3, 1, 1, 3], [2, 1, 3, 3, 1, 1], [2, 1, 3, 1, 3, 1], [3, 1, 1, 1, 2, 3], [3, 1, 1, 3, 2, 1], [3, 3, 1, 1, 2, 1], [3, 1, 2, 1, 1, 3], [3, 1, 2, 3, 1, 1], [3, 3, 2, 1, 1, 1], [3, 1, 4, 1, 1, 1], [2, 2, 1, 4, 1, 1], [4, 3, 1, 1, 1, 1], [1, 1, 1, 2, 2, 4], [1, 1, 1, 4, 2, 2], [1, 2, 1, 1, 2, 4], [1, 2, 1, 4, 2, 1], [1, 4, 1, 1, 2, 2], [1, 4, 1, 2, 2, 1], [1, 1, 2, 2, 1, 4], [1, 1, 2, 4, 1, 2], [1, 2, 2, 1, 1, 4], [1, 2, 2, 4, 1, 1], [1, 4, 2, 1, 1, 2], [1, 4, 2, 2, 1, 1], [2, 4, 1, 2, 1, 1], [2, 2, 1, 1, 1, 4], [4, 1, 3, 1, 1, 1], [2, 4, 1, 1, 1, 2], [1, 3, 4, 1, 1, 1], [1, 1, 1, 2, 4, 2], [1, 2, 1, 1, 4, 2], [1, 2, 1, 2, 4, 1], [1, 1, 4, 2, 1, 2], [1, 2, 4, 1, 1, 2], [1, 2, 4, 2, 1, 1], [4, 1, 1, 2, 1, 2], [4, 2, 1, 1, 1, 2], [4, 2, 1, 2, 1, 1], [2, 1, 2, 1, 4, 1], [2, 1, 4, 1, 2, 1], [4, 1, 2, 1, 2, 1], [1, 1, 1, 1, 4, 3], [1, 1, 1, 3, 4, 1], [1, 3, 1, 1, 4, 1], [1, 1, 4, 1, 1, 3], [1, 1, 4, 3, 1, 1], [4, 1, 1, 1, 1, 3], [4, 1, 1, 3, 1, 1], [1, 1, 3, 1, 4, 1], [1, 1, 4, 1, 3, 1], [3, 1, 1, 1, 4, 1], [4, 1, 1, 1, 3, 1], [2, 1, 1, 4, 1, 2], [2, 1, 1, 2, 1, 4], [2, 1, 1, 2, 3, 2], [2, 3, 3, 1, 1, 1, 2]];
var MODULE_INDICES = {
bar: [0, 2, 4],
space: [1, 3, 5]
};
var Code128Reader =
/*#__PURE__*/
function (_BarcodeReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default()(Code128Reader, _BarcodeReader);
function Code128Reader() {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Code128Reader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(Code128Reader).call(this));
_this._format = 'code_128';
_this._singleCodeError = 0.64;
_this._averageCodeError = 0.30;
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Code128Reader, [{
key: "_decodeCode",
value: function _decodeCode(start, correction) {
var counter = [0, 0, 0, 0, 0, 0];
var offset = start;
var bestMatch = {
error: Number.MAX_VALUE,
code: -1,
start: start,
end: start,
correction: {
bar: 1,
space: 1
}
};
var epsilon = this.AVERAGE_CODE_ERROR;
var isWhite = this._row[offset] ? 0 : 1;
var counterPos = 0;
for (var i = offset; i < this._row.length; i++) {
if (this._row[i] ^ isWhite) {
counter[counterPos]++;
} else {
if (counterPos === counter.length - 1) {
if (correction) {
this._correct(counter, correction);
}
for (var code = 0; code < CODE_PATTERN.length; code++) {
var error = this._matchPattern(counter, CODE_PATTERN[code]);
if (error < bestMatch.error) {
bestMatch.code = code;
bestMatch.error = error;
}
}
bestMatch.end = i;
if (bestMatch.code === -1 || bestMatch.error > epsilon) {
return null;
}
var expected = CODE_PATTERN[bestMatch.code];
if (expected) {
bestMatch.correction.bar = this._calculateCorrection(expected, counter, MODULE_INDICES.bar);
bestMatch.correction.space = this._calculateCorrection(expected, counter, MODULE_INDICES.space);
}
return bestMatch;
} else {
counterPos++;
}
counter[counterPos] = 1;
isWhite = isWhite ? 0 : 1;
}
}
return null;
}
}, {
key: "_correct",
value: function _correct(counter, correction) {
this._correctBars(counter, correction.bar, MODULE_INDICES.bar);
this._correctBars(counter, correction.space, MODULE_INDICES.space);
}
}, {
key: "_findStart",
value: function _findStart() {
var counter = [0, 0, 0, 0, 0, 0];
var offset = this._nextSet(this._row);
var bestMatch = {
error: Number.MAX_VALUE,
code: -1,
start: 0,
end: 0,
correction: {
bar: 1,
space: 1
}
};
var epsilon = this.AVERAGE_CODE_ERROR;
var isWhite = 0;
var counterPos = 0;
var sum;
for (var i = offset; i < this._row.length; i++) {
if (this._row[i] ^ isWhite) {
counter[counterPos]++;
} else {
if (counterPos === counter.length - 1) {
sum = 0;
for (var j = 0; j < counter.length; j++) {
sum += counter[j];
}
for (var code = START_CODE_A; code <= START_CODE_C; code++) {
var error = this._matchPattern(counter, CODE_PATTERN[code]);
if (error < bestMatch.error) {
bestMatch.code = code;
bestMatch.error = error;
}
}
if (bestMatch.error < epsilon) {
bestMatch.start = i - sum;
bestMatch.end = i;
bestMatch.correction.bar = this._calculateCorrection(CODE_PATTERN[bestMatch.code], counter, MODULE_INDICES.bar);
bestMatch.correction.space = this._calculateCorrection(CODE_PATTERN[bestMatch.code], counter, MODULE_INDICES.space);
return bestMatch;
}
for (var _j = 0; _j < 4; _j++) {
counter[_j] = counter[_j + 2];
}
counter[4] = 0;
counter[5] = 0;
counterPos--;
} else {
counterPos++;
}
counter[counterPos] = 1;
isWhite = isWhite ? 0 : 1;
}
}
return null;
}
}, {
key: "decode",
value: function decode() {
var result = new Array();
var startInfo = this._findStart();
var code = null;
var done = false;
var multiplier = 0;
var checksum = 0;
var codeset;
var rawResult = new Array();
var decodedCodes = new Array();
var shiftNext = false;
var unshift;
var removeLastCharacter = true;
if (startInfo === null) {
return null;
}
code = {
code: startInfo.code,
start: startInfo.start,
end: startInfo.end,
correction: {
bar: startInfo.correction.bar,
space: startInfo.correction.space
}
};
decodedCodes.push(code);
checksum = code.code;
switch (code.code) {
case START_CODE_A:
codeset = CODE_A;
break;
case START_CODE_B:
codeset = CODE_B;
break;
case START_CODE_C:
codeset = CODE_C;
break;
default:
return null;
}
while (!done) {
unshift = shiftNext;
shiftNext = false;
code = this._decodeCode(code.end, code.correction);
if (code !== null) {
if (code.code !== STOP_CODE) {
removeLastCharacter = true;
}
if (code.code !== STOP_CODE) {
rawResult.push(code.code);
multiplier++;
checksum += multiplier * code.code;
}
decodedCodes.push(code);
switch (codeset) {
case 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 !== STOP_CODE) {
removeLastCharacter = false;
}
switch (code.code) {
case CODE_SHIFT:
shiftNext = true;
codeset = CODE_B;
break;
case CODE_B:
codeset = CODE_B;
break;
case CODE_C:
codeset = CODE_C;
break;
case STOP_CODE:
done = true;
break;
}
}
break;
}
case CODE_B:
{
if (code.code < 96) {
result.push(String.fromCharCode(32 + code.code));
} else {
if (code.code !== STOP_CODE) {
removeLastCharacter = false;
}
switch (code.code) {
case CODE_SHIFT:
shiftNext = true;
codeset = CODE_A;
break;
case CODE_A:
codeset = CODE_A;
break;
case CODE_C:
codeset = CODE_C;
break;
case STOP_CODE:
done = true;
break;
}
}
break;
}
case CODE_C:
{
if (code.code < 100) {
result.push(code.code < 10 ? '0' + code.code : code.code);
} else {
if (code.code !== STOP_CODE) {
removeLastCharacter = false;
}
switch (code.code) {
case CODE_A:
codeset = CODE_A;
break;
case CODE_B:
codeset = CODE_B;
break;
case STOP_CODE:
done = true;
break;
}
}
break;
}
}
} else {
done = true;
}
if (unshift) {
codeset = codeset === CODE_A ? CODE_B : CODE_A;
}
}
if (code === null) {
return null;
}
code.end = this._nextUnset(this._row, code.end);
if (!this._verifyTrailingWhitespace(code)) {
return null;
}
checksum -= multiplier * rawResult[rawResult.length - 1];
if (checksum % 103 !== rawResult[rawResult.length - 1]) {
return null;
}
if (!result.length) {
return null;
} // remove last code from result (checksum)
if (removeLastCharacter) {
result.splice(result.length - 1, 1);
}
return {
code: result.join(''),
start: startInfo.start,
end: code.end,
codeset: codeset,
startInfo: startInfo,
decodedCodes: decodedCodes,
endInfo: code
};
}
}, {
key: "_verifyTrailingWhitespace",
value: function _verifyTrailingWhitespace(endInfo) {
var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;
if (trailingWhitespaceEnd < this._row.length) {
if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
return endInfo;
}
}
return null;
}
}, {
key: "_calculateCorrection",
value: function _calculateCorrection(expected, normalized, indices) {
var sumNormalized = 0;
var sumExpected = 0;
for (var length = indices.length; length--;) {
sumExpected += expected[indices[length]];
sumNormalized += normalized[indices[length]];
}
return sumExpected / sumNormalized;
}
}]);
return Code128Reader;
}(_barcode_reader__WEBPACK_IMPORTED_MODULE_5__["BarcodeReader"]);
/***/ }),
/***/ "./src/reader/code-39-reader.ts":
/*!**************************************!*\
!*** ./src/reader/code-39-reader.ts ***!
\**************************************/
/*! exports provided: Code39Reader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Code39Reader", function() { return Code39Reader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ "../../node_modules/@babel/runtime/helpers/toConsumableArray.js");
/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _barcode_reader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./barcode-reader */ "./src/reader/barcode-reader.ts");
var ASTERISK = 0x094;
var ALPHABETH_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%';
var ALPHABET = new Uint16Array(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_5___default()(ALPHABETH_STRING).map(function (_char) {
return _char.charCodeAt(0);
})); // const ALPHABET = [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];
var CHARACTER_ENCODINGS = new Uint16Array([0x034, 0x121, 0x061, 0x160, 0x031, 0x130, 0x070, 0x025, 0x124, 0x064, 0x109, 0x049, 0x148, 0x019, 0x118, 0x058, 0x00D, 0x10C, 0x04C, 0x01C, 0x103, 0x043, 0x142, 0x013, 0x112, 0x052, 0x007, 0x106, 0x046, 0x016, 0x181, 0x0C1, 0x1C0, 0x091, 0x190, 0x0D0, 0x085, 0x184, 0x0C4, 0x094, 0x0A8, 0x0A2, 0x08A, 0x02A]);
var Code39Reader =
/*#__PURE__*/
function (_BarcodeReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default()(Code39Reader, _BarcodeReader);
function Code39Reader() {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Code39Reader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(Code39Reader).call(this));
_this._format = 'code_39';
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Code39Reader, [{
key: "decode",
value: function decode() {
var start = this._findStart();
if (!start) {
return null;
}
var result = new Array();
var counters = new Uint16Array(9);
var decodedChar;
var lastStart;
var nextStart = this._nextSet(this._row, start.end);
do {
this._toCounters(nextStart, counters);
var pattern = this._toPattern(counters);
if (pattern < 0) {
return null;
}
decodedChar = this._patternToChar(pattern);
if (decodedChar === null) {
return null;
}
result.push(decodedChar);
lastStart = nextStart;
nextStart += counters.reduce(function (sum, item) {
return sum + item;
}, 0);
nextStart = this._nextSet(this._row, nextStart);
} while (decodedChar !== '*');
result.pop();
if (!result.length) {
return null;
}
if (!this._verifyTrailingWhitespace(lastStart, nextStart, counters)) {
return null;
}
return {
code: result.join(''),
start: start.start,
end: nextStart,
startInfo: start,
decodedCodes: result
};
}
}, {
key: "_patternToChar",
value: function _patternToChar(pattern) {
for (var i = 0; i < CHARACTER_ENCODINGS.length; i++) {
if (CHARACTER_ENCODINGS[i] === pattern) {
return String.fromCharCode(ALPHABET[i]);
}
}
return null;
}
}, {
key: "_verifyTrailingWhitespace",
value: function _verifyTrailingWhitespace(lastStart, nextStart, counters) {
var patternSize = counters.reduce(function (sum, item) {
return sum + item;
}, 0);
var trailingWhitespaceEnd = nextStart - lastStart - patternSize;
return trailingWhitespaceEnd * 3 >= patternSize;
}
}, {
key: "_findNextWidth",
value: function _findNextWidth(counters, current) {
var minWidth = Number.MAX_VALUE;
for (var i = 0; i < counters.length; i++) {
if (counters[i] < minWidth && counters[i] > current) {
minWidth = counters[i];
}
}
return minWidth;
}
}, {
key: "_toPattern",
value: function _toPattern(counters) {
var numCounters = counters.length;
var maxNarrowWidth = 0;
var numWideBars = numCounters;
var wideBarWidth = 0;
var pattern;
while (numWideBars > 3) {
maxNarrowWidth = this._findNextWidth(counters, maxNarrowWidth);
numWideBars = 0;
pattern = 0;
for (var i = 0; i < numCounters; i++) {
if (counters[i] > maxNarrowWidth) {
pattern |= 1 << numCounters - 1 - i;
numWideBars++;
wideBarWidth += counters[i];
}
}
if (numWideBars === 3) {
for (var _i = 0; _i < numCounters && numWideBars > 0; _i++) {
if (counters[_i] > maxNarrowWidth) {
numWideBars--;
if (counters[_i] * 2 >= wideBarWidth) {
return -1;
}
}
}
return pattern;
}
}
return -1;
}
}, {
key: "_findStart",
value: function _findStart() {
var offset = this._nextSet(this._row);
var patternStart = offset;
var counter = new Uint16Array(9);
var counterPos = 0;
var isWhite = 0;
var whiteSpaceMustStart;
for (var i = offset; i < this._row.length; i++) {
if (this._row[i] ^ isWhite) {
counter[counterPos]++;
} else {
if (counterPos === counter.length - 1) {
// find start pattern
if (this._toPattern(counter) === ASTERISK) {
whiteSpaceMustStart = Math.max(0, patternStart - (i - patternStart) / 4) | 0;
if (this._matchRange(whiteSpaceMustStart, patternStart, 0)) {
return {
start: patternStart,
end: i
};
}
}
patternStart += counter[0] + counter[1];
for (var j = 0; j < 7; j++) {
counter[j] = counter[j + 2];
}
counter[7] = 0;
counter[8] = 0;
counterPos--;
} else {
counterPos++;
}
counter[counterPos] = 1;
isWhite = isWhite ? 0 : 1;
}
}
return null;
}
}]);
return Code39Reader;
}(_barcode_reader__WEBPACK_IMPORTED_MODULE_6__["BarcodeReader"]);
/***/ }),
/***/ "./src/reader/code-39-vin-reader.ts":
/*!******************************************!*\
!*** ./src/reader/code-39-vin-reader.ts ***!
\******************************************/
/*! exports provided: Code39VINReader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Code39VINReader", function() { return Code39VINReader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/get */ "../../node_modules/@babel/runtime/helpers/get.js");
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _code_39_reader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./code-39-reader */ "./src/reader/code-39-reader.ts");
var Code39VINReader =
/*#__PURE__*/
function (_Code39Reader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default()(Code39VINReader, _Code39Reader);
function Code39VINReader() {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Code39VINReader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(Code39VINReader).call(this));
_this._format = 'code_39_vin';
return _this;
}
/**
* @borrows
* https://github.com/zxing/zxing/blob/master/core/src/main/java/com/google/zxing/client/result/VINResultParser.java
*/
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Code39VINReader, [{
key: "decode",
value: function decode() {
var result = _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_4___default()(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(Code39VINReader.prototype), "decode", this).call(this);
if (!result) {
return null;
}
var code = result.code;
if (!code) {
return null;
}
code = code.replace(/[IOQ]/g, '');
if (!/[A-Z0-9]{17}/.test(code)) {
if (true) {
console.log('Failed AZ09 pattern code:', code);
}
return null;
}
if (!this._checkChecksum(code)) {
return null;
}
result.code = code;
return result;
}
}, {
key: "_checkChecksum",
value: function _checkChecksum(code) {
// TODO
return !!code;
}
}]);
return Code39VINReader;
}(_code_39_reader__WEBPACK_IMPORTED_MODULE_6__["Code39Reader"]);
/***/ }),
/***/ "./src/reader/code-93-reader.ts":
/*!**************************************!*\
!*** ./src/reader/code-93-reader.ts ***!
\**************************************/
/*! exports provided: Code93Reader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Code93Reader", function() { return Code93Reader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ "../../node_modules/@babel/runtime/helpers/toConsumableArray.js");
/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _barcode_reader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./barcode-reader */ "./src/reader/barcode-reader.ts");
var ALPHABETH_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*';
var ALPHABET = new Uint16Array(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_5___default()(ALPHABETH_STRING).map(function (_char) {
return _char.charCodeAt(0);
}));
var CHARACTER_ENCODINGS = new Uint16Array([0x114, 0x148, 0x144, 0x142, 0x128, 0x124, 0x122, 0x150, 0x112, 0x10A, 0x1A8, 0x1A4, 0x1A2, 0x194, 0x192, 0x18A, 0x168, 0x164, 0x162, 0x134, 0x11A, 0x158, 0x14C, 0x146, 0x12C, 0x116, 0x1B4, 0x1B2, 0x1AC, 0x1A6, 0x196, 0x19A, 0x16C, 0x166, 0x136, 0x13A, 0x12E, 0x1D4, 0x1D2, 0x1CA, 0x16E, 0x176, 0x1AE, 0x126, 0x1DA, 0x1D6, 0x132, 0x15E]);
var ASTERISK = 0x15E;
var Code93Reader =
/*#__PURE__*/
function (_BarcodeReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default()(Code93Reader, _BarcodeReader);
function Code93Reader() {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Code93Reader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(Code93Reader).call(this));
_this._format = 'code_93';
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Code93Reader, [{
key: "decode",
value: function decode() {
var start = this._findStart();
if (!start) {
return null;
}
var result = new Array();
var counters = new Uint16Array(6);
var decodedChar;
var lastStart;
var nextStart = this._nextSet(this._row, start.end);
do {
this._toCounters(nextStart, counters);
var pattern = this._toPattern(counters);
if (pattern < 0) {
return null;
}
decodedChar = this._patternToChar(pattern);
if (decodedChar === null) {
return null;
}
result.push(decodedChar);
lastStart = nextStart;
nextStart += counters.reduce(function (sum, item) {
return sum + item;
}, 0);
nextStart = this._nextSet(this._row, nextStart);
} while (decodedChar !== '*');
result.pop();
if (!result.length) {
return null;
}
if (!this._verifyEnd(lastStart, nextStart)) {
return null;
}
if (!this._verifyChecksums(result)) {
return null;
}
result = result.slice(0, result.length - 2);
if ((result = this._decodeExtended(result)) === null) {
return null;
}
return {
code: result.join(''),
start: start.start,
end: nextStart,
startInfo: start,
decodedCodes: result
};
}
}, {
key: "_patternToChar",
value: function _patternToChar(pattern) {
for (var i = 0; i < CHARACTER_ENCODINGS.length; i++) {
if (CHARACTER_ENCODINGS[i] === pattern) {
return String.fromCharCode(ALPHABET[i]);
}
}
return null;
}
}, {
key: "_verifyEnd",
value: function _verifyEnd(lastStart, nextStart) {
if (lastStart === nextStart || !this._row[nextStart]) {
return false;
}
return true;
}
}, {
key: "_toPattern",
value: function _toPattern(counters) {
var numCounters = counters.length;
var pattern = 0;
var sum = 0;
for (var i = 0; i < numCounters; i++) {
sum += counters[i];
}
for (var _i = 0; _i < numCounters; _i++) {
var normalized = Math.round(counters[_i] * 9 / sum);
if (normalized < 1 || normalized > 4) {
return -1;
}
if ((_i & 1) === 0) {
for (var j = 0; j < normalized; j++) {
pattern = pattern << 1 | 1;
}
} else {
pattern <<= normalized;
}
}
return pattern;
}
}, {
key: "_findStart",
value: function _findStart() {
var counter = new Uint16Array(6);
var offset = this._nextSet(this._row);
var patternStart = offset;
var counterPos = 0;
var isWhite = 0;
var whiteSpaceMustStart;
for (var i = offset; i < this._row.length; i++) {
if (this._row[i] ^ isWhite) {
counter[counterPos]++;
} else {
if (counterPos === counter.length - 1) {
// find start pattern
if (this._toPattern(counter) === ASTERISK) {
whiteSpaceMustStart = Math.max(0, patternStart - (i - patternStart) / 4) | 0;
if (this._matchRange(whiteSpaceMustStart, patternStart, 0)) {
return {
start: patternStart,
end: i
};
}
}
patternStart += counter[0] + counter[1];
for (var j = 0; j < 4; j++) {
counter[j] = counter[j + 2];
}
counter[4] = 0;
counter[5] = 0;
counterPos--;
} else {
counterPos++;
}
counter[counterPos] = 1;
isWhite = isWhite ? 0 : 1;
}
}
return null;
}
}, {
key: "_decodeExtended",
value: function _decodeExtended(charArray) {
var length = charArray.length;
var result = new Array();
for (var i = 0; i < length; i++) {
var _char2 = charArray[i];
if (_char2 >= 'a' && _char2 <= 'd') {
if (i > length - 2) {
return null;
}
var nextChar = charArray[++i];
var nextCharCode = nextChar.charCodeAt(0);
var decodedChar = void 0;
switch (_char2) {
case 'a':
{
if (nextChar >= 'A' && nextChar <= 'Z') {
decodedChar = String.fromCharCode(nextCharCode - 64);
} else {
return null;
}
break;
}
case 'b':
{
if (nextChar >= 'A' && nextChar <= 'E') {
decodedChar = String.fromCharCode(nextCharCode - 38);
} else if (nextChar >= 'F' && nextChar <= 'J') {
decodedChar = String.fromCharCode(nextCharCode - 11);
} else if (nextChar >= 'K' && nextChar <= 'O') {
decodedChar = String.fromCharCode(nextCharCode + 16);
} else if (nextChar >= 'P' && nextChar <= 'S') {
decodedChar = String.fromCharCode(nextCharCode + 43);
} else if (nextChar >= 'T' && nextChar <= 'Z') {
decodedChar = String.fromCharCode(127);
} else {
return null;
}
break;
}
case 'c':
{
if (nextChar >= 'A' && nextChar <= 'O') {
decodedChar = String.fromCharCode(nextCharCode - 32);
} else if (nextChar === 'Z') {
decodedChar = ':';
} else {
return null;
}
break;
}
case 'd':
{
if (nextChar >= 'A' && nextChar <= 'Z') {
decodedChar = String.fromCharCode(nextCharCode + 32);
} else {
return null;
}
break;
}
}
result.push(decodedChar);
} else {
result.push(_char2);
}
}
return result;
}
}, {
key: "_verifyChecksums",
value: function _verifyChecksums(charArray) {
return this._matchCheckChar(charArray, charArray.length - 2, 20) && this._matchCheckChar(charArray, charArray.length - 1, 15);
}
}, {
key: "_matchCheckChar",
value: function _matchCheckChar(charArray, index, maxWeight) {
var arrayToCheck = charArray.slice(0, index);
var length = arrayToCheck.length;
var weightedSums = arrayToCheck.reduce(function (sum, _char3, i) {
var weight = (i * -1 + (length - 1)) % maxWeight + 1;
var value = ALPHABET.indexOf(_char3.charCodeAt(0));
return sum + weight * value;
}, 0);
var checkChar = ALPHABET[weightedSums % 47];
return checkChar === charArray[index].charCodeAt(0);
}
}]);
return Code93Reader;
}(_barcode_reader__WEBPACK_IMPORTED_MODULE_6__["BarcodeReader"]);
/***/ }),
/***/ "./src/reader/ean-2-reader.ts":
/*!************************************!*\
!*** ./src/reader/ean-2-reader.ts ***!
\************************************/
/*! exports provided: EAN2Reader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EAN2Reader", function() { return EAN2Reader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _ean_reader__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./ean-reader */ "./src/reader/ean-reader.ts");
var EAN2Reader =
/*#__PURE__*/
function (_EANReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default()(EAN2Reader, _EANReader);
function EAN2Reader(config, supplements) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, EAN2Reader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(EAN2Reader).call(this, config, supplements));
_this._format = 'ean_2';
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(EAN2Reader, [{
key: "decode",
value: function decode(row, start) {
var end = row.length;
var result = new Array();
var decodedCodes = new Array();
var offset = start;
var codeFrequency = 0;
var code;
this._row = row;
for (var i = 0; i < 2 && offset < end; i++) {
code = this._decodeCode(offset);
if (!code) {
return null;
}
decodedCodes.push(code);
result.push(code.code % 10);
if (code.code >= this.CODE_G_START) {
codeFrequency |= 1 << 1 - i;
}
if (i !== 1) {
offset = this._nextSet(this._row, code.end);
offset = this._nextUnset(this._row, offset);
}
}
if (result.length !== 2 || parseInt(result.join('')) % 4 !== codeFrequency) {
return null;
}
return {
code: result.join(''),
decodedCodes: decodedCodes,
end: code.end
};
}
}]);
return EAN2Reader;
}(_ean_reader__WEBPACK_IMPORTED_MODULE_5__["EANReader"]);
/***/ }),
/***/ "./src/reader/ean-5-reader.ts":
/*!************************************!*\
!*** ./src/reader/ean-5-reader.ts ***!
\************************************/
/*! exports provided: EAN5Reader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EAN5Reader", function() { return EAN5Reader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _ean_reader__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./ean-reader */ "./src/reader/ean-reader.ts");
var EAN5Reader =
/*#__PURE__*/
function (_EANReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default()(EAN5Reader, _EANReader);
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3___default()(EAN5Reader, [{
key: "CHECK_DIGIT_ENCODINGS",
get: function get() {
return [24, 20, 18, 17, 12, 6, 3, 10, 9, 5];
}
}]);
function EAN5Reader(config, supplements) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, EAN5Reader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_1___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2___default()(EAN5Reader).call(this, config, supplements));
_this._format = 'ean_5';
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_3___default()(EAN5Reader, [{
key: "decode",
value: function decode(row, start) {
var end = row.length;
var result = new Array();
var decodedCodes = new Array();
var codeFrequency = 0;
var offset = start;
var code;
this._row = row;
for (var i = 0; i < 5 && offset < end; i++) {
code = this._decodeCode(offset);
if (!code) {
return null;
}
decodedCodes.push(code);
result.push(code.code % 10);
if (code.code >= this.CODE_G_START) {
codeFrequency |= 1 << 4 - i;
}
if (i !== 4) {
offset = this._nextSet(this._row, code.end);
offset = this._nextUnset(this._row, offset);
}
}
if (result.length !== 5) {
return null;
}
if (this._extensionChecksum(result) !== this._determineCheckDigit(codeFrequency)) {
return null;
}
return {
code: result.join(''),
decodedCodes: decodedCodes,
end: code.end
};
}
}, {
key: "_determineCheckDigit",
value: function _determineCheckDigit(codeFrequency) {
for (var i = 0; i < 10; i++) {
if (codeFrequency === this.CHECK_DIGIT_ENCODINGS[i]) {
return i;
}
}
return null;
}
}, {
key: "_extensionChecksum",
value: function _extensionChecksum(result) {
var length = result.length;
var sum = 0;
for (var i = length - 2; i >= 0; i -= 2) {
sum += result[i];
}
sum *= 3;
for (var _i = length - 1; _i >= 0; _i -= 2) {
sum += result[_i];
}
sum *= 3;
return sum % 10;
}
}]);
return EAN5Reader;
}(_ean_reader__WEBPACK_IMPORTED_MODULE_5__["EANReader"]);
/***/ }),
/***/ "./src/reader/ean-8-reader.ts":
/*!************************************!*\
!*** ./src/reader/ean-8-reader.ts ***!
\************************************/
/*! exports provided: EAN8Reader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EAN8Reader", function() { return EAN8Reader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _ean_reader__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./ean-reader */ "./src/reader/ean-reader.ts");
var EAN8Reader =
/*#__PURE__*/
function (_EANReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_4___default()(EAN8Reader, _EANReader);
function EAN8Reader(config, supplements) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, EAN8Reader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(EAN8Reader).call(this, config, supplements));
_this._format = 'ean_8';
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(EAN8Reader, [{
key: "_decodePayload",
value: function _decodePayload(code, result, decodedCodes) {
for (var i = 0; i < 4; i++) {
code = this._decodeCode(code.end, this.CODE_G_START);
if (!code) {
return null;
}
result.push(code.code);
decodedCodes.push(code);
}
code = this._findPattern(this.MIDDLE_PATTERN, code.end, 1, false);
if (code === null) {
return null;
}
decodedCodes.push(code);
for (var _i = 0; _i < 4; _i++) {
code = this._decodeCode(code.end, this.CODE_G_START);
if (!code) {
return null;
}
decodedCodes.push(code);
result.push(code.code);
}
return code;
}
}]);
return EAN8Reader;
}(_ean_reader__WEBPACK_IMPORTED_MODULE_5__["EANReader"]);
/***/ }),
/***/ "./src/reader/ean-reader.ts":
/*!**********************************!*\
!*** ./src/reader/ean-reader.ts ***!
\**********************************/
/*! exports provided: EANReader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EANReader", function() { return EANReader; });
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _common_merge__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../common/merge */ "./src/common/merge.ts");
/* harmony import */ var _barcode_reader__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./barcode-reader */ "./src/reader/barcode-reader.ts");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var EXTENSION_START_PATTERN = [1, 1, 2];
var CODE_PATTERN = [[3, 2, 1, 1], [2, 2, 2, 1], [2, 1, 2, 2], [1, 4, 1, 1], [1, 1, 3, 2], [1, 2, 3, 1], [1, 1, 1, 4], [1, 3, 1, 2], [1, 2, 1, 3], [3, 1, 1, 2], [1, 1, 2, 3], [1, 2, 2, 2], [2, 2, 1, 2], [1, 1, 4, 1], [2, 3, 1, 1], [1, 3, 2, 1], [4, 1, 1, 1], [2, 1, 3, 1], [3, 1, 2, 1], [2, 1, 1, 3]];
var CODE_FREQUENCY = [0, 11, 13, 14, 19, 25, 28, 21, 22, 26];
var EANReader =
/*#__PURE__*/
function (_BarcodeReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default()(EANReader, _BarcodeReader);
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4___default()(EANReader, [{
key: "CODE_L_START",
get: function get() {
return 0;
}
}, {
key: "CODE_G_START",
get: function get() {
return 10;
}
}, {
key: "START_PATTERN",
get: function get() {
return [1, 1, 1];
}
}, {
key: "STOP_PATTERN",
get: function get() {
return [1, 1, 1];
}
}, {
key: "MIDDLE_PATTERN",
get: function get() {
return [1, 1, 1, 1, 1];
}
}]);
function EANReader(config, supplements) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1___default()(this, EANReader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(EANReader).call(this, Object(_common_merge__WEBPACK_IMPORTED_MODULE_6__["merge"])({
supplements: [] // Allowed extensions to be decoded (2 and/or 5)
}, config), supplements));
_this._format = 'ean_13';
_this._singleCodeError = 0.70;
_this._averageCodeError = 0.48;
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4___default()(EANReader, [{
key: "_decodeCode",
value: function _decodeCode(start, coderange) {
var counter = [0, 0, 0, 0];
var offset = start;
var bestMatch = {
error: Number.MAX_VALUE,
code: -1,
start: start,
end: start
};
var epsilon = this.AVERAGE_CODE_ERROR;
var isWhite = this._row[offset] ? 0 : 1;
var counterPos = 0;
if (!coderange) {
coderange = CODE_PATTERN.length;
}
for (var i = offset; i < this._row.length; i++) {
if (this._row[i] ^ isWhite) {
counter[counterPos]++;
} else {
if (counterPos === counter.length - 1) {
for (var code = 0; code < coderange; code++) {
var error = this._matchPattern(counter, CODE_PATTERN[code]);
if (error < bestMatch.error) {
bestMatch.code = code;
bestMatch.error = error;
}
}
bestMatch.end = i;
if (bestMatch.error > epsilon) {
return null;
}
return bestMatch;
} else {
counterPos++;
}
counter[counterPos] = 1;
isWhite = isWhite ? 0 : 1;
}
}
return null;
}
}, {
key: "_findStart",
value: function _findStart() {
var offset = this._nextSet(this._row);
var startInfo;
while (!startInfo) {
startInfo = this._findPattern(this.START_PATTERN, offset, 0, true);
if (!startInfo) {
return null;
}
var leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);
if (leadingWhitespaceStart >= 0) {
if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
return startInfo;
}
}
offset = startInfo.end;
startInfo = null;
}
return null;
}
}, {
key: "_verifyTrailingWhitespace",
value: function _verifyTrailingWhitespace(endInfo) {
var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);
if (trailingWhitespaceEnd < this._row.length) {
if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
return endInfo;
}
}
return null;
}
}, {
key: "_findEnd",
value: function _findEnd(offset, isWhite) {
var endInfo = this._findPattern(this.STOP_PATTERN, offset, isWhite, false);
return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;
}
}, {
key: "_calculateFirstDigit",
value: function _calculateFirstDigit(codeFrequency) {
for (var i = 0; i < CODE_FREQUENCY.length; i++) {
if (codeFrequency === CODE_FREQUENCY[i]) {
return i;
}
}
return null;
}
}, {
key: "_decodePayload",
value: function _decodePayload(code, result, decodedCodes) {
var codeFrequency = 0x0;
for (var i = 0; i < 6; i++) {
code = this._decodeCode(code.end);
if (!code) {
return null;
}
if (code.code >= this.CODE_G_START) {
code.code -= this.CODE_G_START;
codeFrequency |= 1 << 5 - i;
} else {
codeFrequency |= 0 << 5 - i;
}
result.push(code.code);
decodedCodes.push(code);
}
var firstDigit = this._calculateFirstDigit(codeFrequency);
if (firstDigit === null) {
return null;
}
result.unshift(firstDigit);
code = this._findPattern(this.MIDDLE_PATTERN, code.end, 1, false);
if (code === null) {
return null;
}
decodedCodes.push(code);
for (var _i = 0; _i < 6; _i++) {
code = this._decodeCode(code.end, this.CODE_G_START);
if (!code) {
return null;
}
decodedCodes.push(code);
result.push(code.code);
}
return code;
}
}, {
key: "decode",
value: function decode() {
var result = new Array();
var decodedCodes = new Array();
var resultInfo = {};
var startInfo = this._findStart();
if (!startInfo) {
return null;
}
var code = {
code: startInfo.code,
start: startInfo.start,
end: startInfo.end
};
decodedCodes.push(code);
code = this._decodePayload(code, result, decodedCodes);
if (!code) {
return null;
}
code = this._findEnd(code.end, 0);
if (!code) {
return null;
}
decodedCodes.push(code); // Checksum
if (!this._checksum(result)) {
return null;
}
if (this.supplements.length > 0) {
var supplement = this._decodeExtensions(code.end);
if (!supplement) {
return null;
}
var lastCode = supplement.decodedCodes[supplement.decodedCodes.length - 1];
var endInfo = {
start: lastCode.start + ((lastCode.end - lastCode.start) / 2 | 0),
end: lastCode.end
};
if (!this._verifyTrailingWhitespace(endInfo)) {
return null;
}
resultInfo = {
supplement: supplement,
code: result.join('') + supplement.code
};
}
return _objectSpread({
code: result.join(''),
start: startInfo.start,
end: code.end,
startInfo: startInfo,
decodedCodes: decodedCodes
}, resultInfo);
}
}, {
key: "_decodeExtensions",
value: function _decodeExtensions(offset) {
var start = this._nextSet(this._row, offset);
var startInfo = this._findPattern(EXTENSION_START_PATTERN, start, 0, false);
if (startInfo === null) {
return null;
}
for (var i = 0; i < this.supplements.length; i++) {
var result = this.supplements[i].decode(this._row, startInfo.end);
if (result !== null) {
return {
code: result.code,
start: start,
startInfo: startInfo,
end: result.end,
decodedCodes: result.decodedCodes
};
}
}
return null;
}
}, {
key: "_checksum",
value: function _checksum(result) {
var sum = 0;
for (var i = result.length - 2; i >= 0; i -= 2) {
sum += result[i];
}
sum *= 3;
for (var _i2 = result.length - 1; _i2 >= 0; _i2 -= 2) {
sum += result[_i2];
}
return sum % 10 === 0;
}
}]);
return EANReader;
}(_barcode_reader__WEBPACK_IMPORTED_MODULE_7__["BarcodeReader"]);
/***/ }),
/***/ "./src/reader/i2of5-reader.ts":
/*!************************************!*\
!*** ./src/reader/i2of5-reader.ts ***!
\************************************/
/*! exports provided: I2of5Reader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "I2of5Reader", function() { return I2of5Reader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/assertThisInitialized */ "../../node_modules/@babel/runtime/helpers/assertThisInitialized.js");
/* harmony import */ var _babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/get */ "../../node_modules/@babel/runtime/helpers/get.js");
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6__);
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "../../node_modules/@babel/runtime/helpers/defineProperty.js");
/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7__);
/* harmony import */ var _common_merge__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../common/merge */ "./src/common/merge.ts");
/* harmony import */ var _barcode_reader__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./barcode-reader */ "./src/reader/barcode-reader.ts");
var N = 1;
var W = 3;
var START_PATTERN = [N, N, N, N];
var STOP_PATTERN = [N, N, W];
var CODE_PATTERN = [[N, N, W, W, N], [W, N, N, N, W], [N, W, N, N, W], [W, W, N, N, N], [N, N, W, N, W], [W, N, W, N, N], [N, W, W, N, N], [N, N, N, W, W], [W, N, N, W, N], [N, W, N, W, N]];
var MAX_CORRECTION_FACTOR = 5;
var I2of5Reader =
/*#__PURE__*/
function (_BarcodeReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_6___default()(I2of5Reader, _BarcodeReader);
function I2of5Reader(config) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, I2of5Reader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default()(I2of5Reader).call(this, Object(_common_merge__WEBPACK_IMPORTED_MODULE_8__["merge"])({
normalizeBarSpaceWidth: false // Normalize the width difference between bars and spaces
}, config)));
_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_7___default()(_babel_runtime_helpers_assertThisInitialized__WEBPACK_IMPORTED_MODULE_3___default()(_this), "_barSpaceRatio", void 0);
_this._barSpaceRatio = [1, 1];
_this._format = 'i2of5';
if (_this.config.normalizeBarSpaceWidth) {
_this._singleCodeError = 0.38;
_this._averageCodeError = 0.09;
} else {
_this._singleCodeError = 0.78;
_this._averageCodeError = 0.38;
}
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(I2of5Reader, [{
key: "decode",
value: function decode() {
var startInfo = this._findStart();
if (!startInfo) {
return null;
}
var endInfo = this._findEnd();
if (!endInfo) {
return null;
}
var counters = this._fillCounters(startInfo.end, endInfo.start, 0);
if (counters.length % 10 !== 0) {
return null;
}
var result = new Array();
var decodedCodes = new Array();
decodedCodes.push(startInfo);
var code = this._decodePayload(counters, result, decodedCodes);
if (!code || 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
};
}
}, {
key: "_matchPattern",
value: function _matchPattern(counter, code) {
if (this.config.normalizeBarSpaceWidth) {
var counterSum = [0, 0];
var codeSum = [0, 0];
var correction = [0, 0];
var correctionRatio = MAX_CORRECTION_FACTOR;
var correctionRatioInverse = 1 / correctionRatio;
for (var i = 0; i < counter.length; i++) {
counterSum[i % 2] += counter[i];
codeSum[i % 2] += code[i];
}
correction[0] = codeSum[0] / counterSum[0];
correction[1] = codeSum[1] / counterSum[1];
correction[0] = Math.max(Math.min(correction[0], correctionRatio), correctionRatioInverse);
correction[1] = Math.max(Math.min(correction[1], correctionRatio), correctionRatioInverse);
this._barSpaceRatio = correction;
for (var _i = 0; _i < counter.length; _i++) {
counter[_i] *= this._barSpaceRatio[_i % 2];
}
}
return _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_5___default()(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_4___default()(I2of5Reader.prototype), "_matchPattern", this).call(this, counter, code);
}
}, {
key: "_findStart",
value: function _findStart() {
var offset = this._nextSet(this._row);
var startInfo;
while (!startInfo) {
startInfo = this._findPattern(START_PATTERN, offset, 0, true);
if (!startInfo) {
return null;
}
var narrowBarWidth = startInfo.end - startInfo.start >> 2;
var leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10;
if (leadingWhitespaceStart >= 0) {
if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
return startInfo;
}
}
offset = startInfo.end;
startInfo = null;
}
return null;
}
}, {
key: "_verifyTrailingWhitespace",
value: function _verifyTrailingWhitespace(endInfo) {
var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;
if (trailingWhitespaceEnd < this._row.length) {
if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
return endInfo;
}
}
return null;
}
}, {
key: "_findEnd",
value: function _findEnd() {
this._row.reverse();
var endInfo = this._findPattern(STOP_PATTERN, undefined, 0, false);
this._row.reverse();
if (endInfo === null) {
return null;
} // reverse numbers
var start = endInfo.start;
endInfo.start = this._row.length - endInfo.end;
endInfo.end = this._row.length - start;
return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;
}
}, {
key: "_decodeCode",
value: function _decodeCode(counter) {
var bestMatch = {
error: Number.MAX_VALUE,
code: -1,
start: 0,
end: 0
};
for (var code = 0; code < CODE_PATTERN.length; code++) {
var error = this._matchPattern(counter, CODE_PATTERN[code]);
if (error < bestMatch.error) {
bestMatch.code = code;
bestMatch.error = error;
}
}
return bestMatch.error < this.AVERAGE_CODE_ERROR ? bestMatch : null;
}
}, {
key: "_decodePayload",
value: function _decodePayload(counters, result, decodedCodes) {
var counterLength = counters.length;
var counter0 = [0, 0, 0, 0, 0];
var counter1 = [0, 0, 0, 0, 0];
var code0;
var code1;
var pos = 0;
while (pos < counterLength) {
for (var i = 0; i < 5; i++) {
counter0[i] = counters[pos] * this._barSpaceRatio[0];
counter1[i] = counters[pos + 1] * this._barSpaceRatio[1];
pos += 2;
}
code0 = this._decodeCode(counter0);
if (!code0) {
return null;
}
code1 = this._decodeCode(counter1);
if (!code1) {
return null;
}
result.push(code0.code, code1.code);
decodedCodes.push(code0, code1);
}
return [code0, code1];
}
}]);
return I2of5Reader;
}(_barcode_reader__WEBPACK_IMPORTED_MODULE_9__["BarcodeReader"]);
/***/ }),
/***/ "./src/reader/index.ts":
/*!*****************************!*\
!*** ./src/reader/index.ts ***!
\*****************************/
/*! exports provided: Readers */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Readers", function() { return Readers; });
/* harmony import */ var _code_128_reader__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./code-128-reader */ "./src/reader/code-128-reader.ts");
/* harmony import */ var _code_39_reader__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./code-39-reader */ "./src/reader/code-39-reader.ts");
/* harmony import */ var _code_39_vin_reader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./code-39-vin-reader */ "./src/reader/code-39-vin-reader.ts");
/* harmony import */ var _codabar_reader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./codabar-reader */ "./src/reader/codabar-reader.ts");
/* harmony import */ var _ean_reader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./ean-reader */ "./src/reader/ean-reader.ts");
/* harmony import */ var _ean_8_reader__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./ean-8-reader */ "./src/reader/ean-8-reader.ts");
/* harmony import */ var _ean_2_reader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ean-2-reader */ "./src/reader/ean-2-reader.ts");
/* harmony import */ var _ean_5_reader__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./ean-5-reader */ "./src/reader/ean-5-reader.ts");
/* harmony import */ var _upc_reader__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./upc-reader */ "./src/reader/upc-reader.ts");
/* harmony import */ var _upc_e_reader__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./upc-e-reader */ "./src/reader/upc-e-reader.ts");
/* harmony import */ var _i2of5_reader__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./i2of5-reader */ "./src/reader/i2of5-reader.ts");
/* harmony import */ var _2of5_reader__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./2of5-reader */ "./src/reader/2of5-reader.ts");
/* harmony import */ var _code_93_reader__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./code-93-reader */ "./src/reader/code-93-reader.ts");
var Readers = {
code_128_reader: _code_128_reader__WEBPACK_IMPORTED_MODULE_0__["Code128Reader"],
ean_reader: _ean_reader__WEBPACK_IMPORTED_MODULE_4__["EANReader"],
ean_5_reader: _ean_5_reader__WEBPACK_IMPORTED_MODULE_7__["EAN5Reader"],
ean_2_reader: _ean_2_reader__WEBPACK_IMPORTED_MODULE_6__["EAN2Reader"],
ean_8_reader: _ean_8_reader__WEBPACK_IMPORTED_MODULE_5__["EAN8Reader"],
code_39_reader: _code_39_reader__WEBPACK_IMPORTED_MODULE_1__["Code39Reader"],
code_39_vin_reader: _code_39_vin_reader__WEBPACK_IMPORTED_MODULE_2__["Code39VINReader"],
codabar_reader: _codabar_reader__WEBPACK_IMPORTED_MODULE_3__["CodabarReader"],
upc_reader: _upc_reader__WEBPACK_IMPORTED_MODULE_8__["UPCReader"],
upc_e_reader: _upc_e_reader__WEBPACK_IMPORTED_MODULE_9__["UPCEReader"],
i2of5_reader: _i2of5_reader__WEBPACK_IMPORTED_MODULE_10__["I2of5Reader"],
'2of5_reader': _2of5_reader__WEBPACK_IMPORTED_MODULE_11__["TwoOfFiveReader"],
code_93_reader: _code_93_reader__WEBPACK_IMPORTED_MODULE_12__["Code93Reader"]
};
/***/ }),
/***/ "./src/reader/upc-e-reader.ts":
/*!************************************!*\
!*** ./src/reader/upc-e-reader.ts ***!
\************************************/
/*! exports provided: UPCEReader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UPCEReader", function() { return UPCEReader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/get */ "../../node_modules/@babel/runtime/helpers/get.js");
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _ean_reader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ean-reader */ "./src/reader/ean-reader.ts");
var CODE_FREQUENCY = [[56, 52, 50, 49, 44, 38, 35, 42, 41, 37], [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]];
var UPCEReader =
/*#__PURE__*/
function (_EANReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default()(UPCEReader, _EANReader);
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4___default()(UPCEReader, [{
key: "STOP_PATTERN",
get: function get() {
return [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7];
}
}]);
function UPCEReader(config, supplements) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, UPCEReader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_1___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2___default()(UPCEReader).call(this, config, supplements));
_this._format = 'upc_e';
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_4___default()(UPCEReader, [{
key: "_decodePayload",
value: function _decodePayload(code, result, decodedCodes) {
var codeFrequency = 0x0;
for (var i = 0; i < 6; i++) {
code = this._decodeCode(code.end);
if (!code) {
return null;
}
if (code.code >= this.CODE_G_START) {
code.code = code.code - this.CODE_G_START;
codeFrequency |= 1 << 5 - i;
}
result.push(code.code);
decodedCodes.push(code);
}
if (!this._determineParity(codeFrequency, result)) {
return null;
}
return code;
}
}, {
key: "_determineParity",
value: function _determineParity(codeFrequency, result) {
for (var nrSystem = 0; nrSystem < CODE_FREQUENCY.length; nrSystem++) {
for (var i = 0; i < CODE_FREQUENCY[nrSystem].length; i++) {
if (codeFrequency === CODE_FREQUENCY[nrSystem][i]) {
result.unshift(nrSystem);
result.push(i);
return true;
}
}
}
return false;
}
}, {
key: "_convertToUPCA",
value: function _convertToUPCA(result) {
var lastDigit = result[result.length - 2];
var upca = [result[0]];
if (lastDigit <= 2) {
upca = upca.concat(result.slice(1, 3)).concat([lastDigit, 0, 0, 0, 0]).concat(result.slice(3, 6));
} else if (lastDigit === 3) {
upca = upca.concat(result.slice(1, 4)).concat([0, 0, 0, 0, 0]).concat(result.slice(4, 6));
} else if (lastDigit === 4) {
upca = upca.concat(result.slice(1, 5)).concat([0, 0, 0, 0, 0, result[5]]);
} else {
upca = upca.concat(result.slice(1, 6)).concat([0, 0, 0, 0, lastDigit]);
}
upca.push(result[result.length - 1]);
return upca;
}
}, {
key: "_checksum",
value: function _checksum(result) {
return _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_3___default()(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2___default()(UPCEReader.prototype), "_checksum", this).call(this, this._convertToUPCA(result));
}
}, {
key: "_findEnd",
value: function _findEnd(offset, isWhite) {
isWhite = 1;
return _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_3___default()(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_2___default()(UPCEReader.prototype), "_findEnd", this).call(this, offset, isWhite);
}
}, {
key: "_verifyTrailingWhitespace",
value: function _verifyTrailingWhitespace(endInfo) {
var trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;
if (trailingWhitespaceEnd < this._row.length) {
if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
return endInfo;
}
}
return null;
}
}]);
return UPCEReader;
}(_ean_reader__WEBPACK_IMPORTED_MODULE_6__["EANReader"]);
/***/ }),
/***/ "./src/reader/upc-reader.ts":
/*!**********************************!*\
!*** ./src/reader/upc-reader.ts ***!
\**********************************/
/*! exports provided: UPCReader */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UPCReader", function() { return UPCReader; });
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "../../node_modules/@babel/runtime/helpers/classCallCheck.js");
/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "../../node_modules/@babel/runtime/helpers/createClass.js");
/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/possibleConstructorReturn */ "../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js");
/* harmony import */ var _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @babel/runtime/helpers/getPrototypeOf */ "../../node_modules/@babel/runtime/helpers/getPrototypeOf.js");
/* harmony import */ var _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @babel/runtime/helpers/get */ "../../node_modules/@babel/runtime/helpers/get.js");
/* harmony import */ var _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @babel/runtime/helpers/inherits */ "../../node_modules/@babel/runtime/helpers/inherits.js");
/* harmony import */ var _babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _ean_reader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ean-reader */ "./src/reader/ean-reader.ts");
var UPCReader =
/*#__PURE__*/
function (_EANReader) {
_babel_runtime_helpers_inherits__WEBPACK_IMPORTED_MODULE_5___default()(UPCReader, _EANReader);
function UPCReader(config, supplements) {
var _this;
_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, UPCReader);
_this = _babel_runtime_helpers_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2___default()(this, _babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(UPCReader).call(this, config, supplements));
_this._format = 'upc_a';
return _this;
}
_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(UPCReader, [{
key: "decode",
value: function decode() {
var result = _babel_runtime_helpers_get__WEBPACK_IMPORTED_MODULE_4___default()(_babel_runtime_helpers_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3___default()(UPCReader.prototype), "decode", this).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;
}
}]);
return UPCReader;
}(_ean_reader__WEBPACK_IMPORTED_MODULE_6__["EANReader"]);
/***/ })
/******/ })
});
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://Quagga/webpack/myModuleDefinition","webpack://Quagga/webpack/bootstrap","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/assertThisInitialized.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/asyncToGenerator.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/classCallCheck.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/createClass.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/defineProperty.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/get.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/getPrototypeOf.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/inherits.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/iterableToArray.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/nonIterableSpread.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/setPrototypeOf.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/superPropBase.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/toConsumableArray.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/helpers/typeof.js","webpack://Quagga//Users/adomratchev/node_modules/@babel/runtime/regenerator/index.js","webpack://Quagga//Users/adomratchev/node_modules/regenerator-runtime/runtime-module.js","webpack://Quagga//Users/adomratchev/node_modules/regenerator-runtime/runtime.js","webpack://Quagga/(webpack)/buildin/global.js","webpack://Quagga/./src/analytics/result-collector.ts","webpack://Quagga/./src/common/cluster.ts","webpack://Quagga/./src/common/events.ts","webpack://Quagga/./src/common/hsv2rgb.ts","webpack://Quagga/./src/common/image-debug.ts","webpack://Quagga/./src/common/image-wrapper.ts","webpack://Quagga/./src/common/media-devices.ts","webpack://Quagga/./src/common/merge.ts","webpack://Quagga/./src/config/config.dev.ts","webpack://Quagga/./src/decoder/barcode-decoder.ts","webpack://Quagga/./src/decoder/bresenham.ts","webpack://Quagga/./src/input/camera-access.ts","webpack://Quagga/./src/input/exif-helper.ts","webpack://Quagga/./src/input/frame-grabber.ts","webpack://Quagga/./src/input/image-loader.ts","webpack://Quagga/./src/input/image-stream.ts","webpack://Quagga/./src/input/input-stream-utils.ts","webpack://Quagga/./src/input/input-stream.ts","webpack://Quagga/./src/input/live-stream.ts","webpack://Quagga/./src/input/video-stream.ts","webpack://Quagga/./src/locator/barcode-locator-utils.ts","webpack://Quagga/./src/locator/barcode-locator.ts","webpack://Quagga/./src/locator/rasterizer.ts","webpack://Quagga/./src/locator/skeletonizer.js","webpack://Quagga/./src/locator/tracer.ts","webpack://Quagga/./src/quagga.ts","webpack://Quagga/./src/reader/2of5-reader.ts","webpack://Quagga/./src/reader/barcode-reader.ts","webpack://Quagga/./src/reader/codabar-reader.ts","webpack://Quagga/./src/reader/code-128-reader.ts","webpack://Quagga/./src/reader/code-39-reader.ts","webpack://Quagga/./src/reader/code-39-vin-reader.ts","webpack://Quagga/./src/reader/code-93-reader.ts","webpack://Quagga/./src/reader/ean-2-reader.ts","webpack://Quagga/./src/reader/ean-5-reader.ts","webpack://Quagga/./src/reader/ean-8-reader.ts","webpack://Quagga/./src/reader/ean-reader.ts","webpack://Quagga/./src/reader/i2of5-reader.ts","webpack://Quagga/./src/reader/index.ts","webpack://Quagga/./src/reader/upc-e-reader.ts","webpack://Quagga/./src/reader/upc-reader.ts"],"names":["ResultCollector","config","_results","Array","_config","_capacity","capacity","_capture","capture","_canvas","document","createElement","_context","getContext","data","imageWidth","imageHeight","codeResult","_contains","_passesFilter","result","width","height","ImageDebug","drawImage","frame","toDataURL","push","blacklist","some","item","Object","keys","every","key","filter","Cluster","moments","threshold","clusters","forEach","moment","matchingCluster","find","cluster","fits","add","_threshold","_moments","_center","rad","x","y","point","reduce","sum","p","length","Math","cos","sin","similarity","abs","events","Events","event","callback","async","subscription","getEvent","subscriptions","type","eventItem","once","publishSubscription","subscribe","eventName","setTimeout","hsv2rgb","hsv","rgb","h","s","v","c","m","r","g","b","drawPath","path","context","color","lineWidth","strokeStyle","fillStyle","beginPath","moveTo","slice","lineTo","closePath","stroke","imageData","canvasData","getImageData","imageIndex","canvasIndex","value","putImageData","ImageWrapper","size","arrayType","initialize","Uint8Array","fill","border","imageWrapper","fromX","fromY","sizeY","sizeX","i","labelCount","labelSum","m00","m01","m10","m11","m02","m20","theta","ysq","val","label","PI","PI_4","isNaN","x_","y_","mu11","mu02","mu20","tmp","atan","scale","current","pixel","get","whiteRgb","blackRgb","enumerateDevices","navigator","mediaDevices","Promise","reject","Error","getUserMedia","constraints","merge","isObject","obj","objects","prev","pVal","oVal","isArray","inputStream","name","facingMode","area","top","right","left","bottom","singleChannel","locate","numOfWorkers","decoder","readers","debug","drawBoundingBox","showFrequency","drawScanline","showPattern","locator","halfSample","patchSize","showCanvas","showPatches","showFoundPatches","showSkeleton","showLabels","showPatchLabels","showRemainingPatchLabels","boxFromPatches","showTransformed","showTransformedBox","showBB","BarcodeDecoder","inputImageWrapper","_inputImageWrapper","_barcodeReaders","process","debugDiv","querySelector","_frequencyCanvas","className","appendChild","style","display","_patternCanvas","overlayCanvas","_overlayContext","_initReaders","boxes","barcode","multiple","barcodes","map","box","decodeFromBoundingBox","_drawPath","line","_getLine","angle","atan2","_getExtendedLine","_tryDecode","_tryDecodeBruteForce","pattern","barcodeLine","readerConfig","reader","configuration","supplements","format","console","log","supplement","Readers","FORMAT","JSON","stringify","extendLine","amount","extension","lineLength","sqrt","extensionLength","inImageWithBorder","Bresenham","getBarcodeLine","_printFrequency","toBinaryLine","_printPattern","decodePattern","lineAngle","sideLength","slices","xdir","ydir","dir","fillRect","Slope","p1","p2","x0","y0","x1","y1","steep","min","max","read","a","deltax","deltay","error","ystep","center","extrema","rThreshold","currentDir","Up","Down","pos","slope","slope2","j","_stream","CameraAccess","request","video","videoConstraints","normalizedConstraints","pickConstraints","srcObject","setAttribute","resolve","addEventListener","play","then","_waitForVideo","bind","release","tracks","getVideoTracks","stop","enumerateVideoDevices","devices","kind","getActiveStreamLabel","track","getActiveTrack","aspectRatio","deviceId","minAspectRatio","facing","audio","videoWidth","videoHeight","attempts","checkVideo","window","ExifTags","AvailableTags","findTagsInObjectURL","src","tags","test","objectURLToBlob","buffer","findTagsInBuffer","file","selectedTags","dataView","DataView","byteLength","exifTags","selectedTag","exifTag","tag","offset","getUint8","marker","readEXIFData","getUint16","url","fetch","response","ok","arrayBuffer","status","start","split","char","index","charCodeAt","tiffOffset","bigEnd","firstIFDOffset","getUint32","readTags","dirStart","strings","entries","entryOffset","readTagValue","numValues","undefined","QUATER_CIRCLE","FrameGrabber","canvas","_inputStream","_streamConfig","_canvasWidth","canvasWidth","_canvasHeight","canvasHeight","_width","_height","_topLeft","topLeft","_data","videoSize","realWidth","realHeight","canvasSize","getFrame","_adjustCanvasSize","drawable","drawAngle","HTMLVideoElement","image","orientation","halfWidth","halfHeight","translate","rotate","_grayAndHalfSampleFromCanvasData","_computeGray","warn","endIndex","outWidth","topRowIndex","bottomRowIndex","outImageIndex","top4","bottom4","imageDataLength","ImageLoader","baseUri","sequence","loaded","loadedImage","notLoadedImages","splice","imageSrcs","imageName","substr","lastIndexOf","loadedImages","firstImage","Image","onload","ImageStream","_baseUrl","_ended","_frameIndex","_images","_loaded","_offset","_paused","_size","trigger","load","images","_calculatedWidth","_calculatedHeight","_loadImages","time","InputStream","_computeDivisors","n","divisors","largeDivisors","divisor","unshift","concat","_computeCommonDivisors","largeDivisor","calculatePatchSize","wideSide","nrOfPatchesList","nrOfPatchesMap","small","medium","large","nrOfPatchesIndex","nrOfPatches","desiredPatchSize","findPatchSizeForDivisors","found","optimalPatchSize","checkImageConstraints","shift","inputStreamConfig","computeImageArea","setCanvasSize","_parseCssDimensionValues","dimension","parseFloat","unit","indexOf","_dimensionsConverters","inputWidth","inputHeight","parsedArea","parsed","calculated","_eventNames","_eventHandlers","Map","listener","_options","has","set","clear","argArray","handlers","handler","apply","LiveStream","VideoStream","_video","pause","options","_initSize","ended","currentTime","invert","matrix","a0","a1","a2","a3","determinant","Float32Array","transformWithMatrix","_computeHistogram","bitsPerPixel","bitShift","bucketCount","histogram","Int32Array","_determineOtsuThreshold","hist","vet","px","init","end","mx","k","p12","m1","m2","m12","maxIndex","array","otsuThreshold","targetWrapper","targetData","outImageWrapper","outImage","outImgIndex","MomentSimilarityThreshold","BarcodeLocator","_numPatches","_initBuffers","_initCanvas","_currentImageWrapper","_binarizeImage","patchesFound","_findPatches","maxLabel","_rasterizeAngularSimilarity","topLabels","_findBiggestConnectedAreas","_findBoxes","_patchSize","_binaryImageWrapper","_labelImageWrapper","skeletonImageData","ArrayBuffer","_subImageWrapper","_skelImageWrapper","_skeletonizer","skeletonizer","self","global","_patchLabelGrid","_patchGrid","_imageToPatchGrid","useWorker","_binaryContext","patches","averageRad","_drawRect","inverseMatrix","minX","minY","maxX","maxY","vertex","zeroBorder","show","_skeletonize","rasterizer","Rasterizer","rasterResult","rasterize","overlay","count","patch","_describePatch","labelHist","sort","_boxFromPatches","join","clusterize","topCluster","subImageAsCopy","skeletonize","minComponentWeight","ceil","eligibleMoments","matchingMoments","_similarMoments","currentIndex","currentPatch","SearchDirections","direction","Number","MAX_VALUE","_trace","_notYetProcessed","strokeRect","EdgeLabel","ContourDirection","labelWrapper","_imageData","_labelData","_tracer","Tracer","depthLabel","colorMap","cc","sc","connectedCount","cy","labelIndex","bc","cx","lc","contourTracing","Outside","CW","firstVertex","nextPeer","insideContours","previousPeer","Inside","CCW","firstContour","pq","iq","q","Unknown","next","Skeletonizer","stdlib","foreign","imul","erode","inImagePtr","outImagePtr","u","yStart1","yStart2","xStart1","xStart2","subtract","aImagePtr","bImagePtr","bitwiseOr","countNonZero","imagePtr","dilate","memcpy","srcImagePtr","dstImagePtr","subImagePtr","erodedImagePtr","tempImagePtr","skelImagePtr","done","edgeLabel","sy","sx","Fv","trace","Cv","ldir","P","_frameGrabber","_stopped","_canvasContainer","ctx","dom","_locator","_boxSize","_decoder","_workerPool","_onUIThread","_resultCollector","cb","defaultConfig","_initializeData","_initInputStream","_startContinuousUpdate","_update","_adjustWorkerPool","clearEventHandlers","decodeSingle","resultCallback","call","onDetected","offDetected","unsubscribe","onProcessed","offProcessed","setReaders","worker","postMessage","cmd","registerResultCollector","resultCollector","addResult","viewport","_getViewPort","err","_canRecord","target","HTMLElement","selector","clearFix","_transform","polygon","_transformResult","_addResult","_hasCodeResult","_publishResult","resultToPublish","publish","_locateAndDecode","decodeFromBoundingBoxes","availableWorker","busy","grab","delay","frequency","timestamp","requestAnimationFrame","performance","now","_initWorker","blobURL","_generateWorkerBlob","workerThread","Worker","onmessage","URL","revokeObjectURL","message","_workerInterface","factory","Quagga","factorySource","__factorySource__","blob","Blob","toString","createObjectURL","increaseBy","terminate","N","W","START_PATTERN","STOP_PATTERN","CODE_PATTERN","startPatternLength","TwoOfFiveReader","_barSpaceRatio","_format","_singleCodeError","_averageCodeError","startInfo","_findStart","endInfo","_findEnd","counters","_fillCounters","decodedCodes","code","_decodePayload","_nextSet","_row","narrowBarWidth","_findPattern","leadingWhitespaceStart","_matchRange","trailingWhitespaceEnd","reverse","_verifyTrailingWhitespace","counter","bestMatch","_matchPattern","AVERAGE_CODE_ERROR","counterLength","_decodeCode","BarcodeReader","BarcodeDirection","StartNotFoundException","CodeNotFoundException","PatternNotFoundException","isWhite","tryHarder","epsilon","counterPos","maxSingleError","modulo","SINGLE_CODE_ERROR","barWidth","scaled","singleError","correction","indices","decode","Reverse","Forward","numCounters","ALPHABETH_STRING","ALPHABET","CHARACTER_ENCODINGS","START_END","MIN_ENCODED_CHARS","MAX_ACCEPTABLE","PADDING","CodabarReader","_counters","_nextUnset","nextStart","startCounter","_toPattern","decodedChar","_patternToChar","_verifyWhitespace","_validateResult","_sumCounters","endCounter","_calculatePatternLength","categorization","space","narrow","counts","wide","bar","_charToPattern","cat","floor","charCode","_thresholdResultPattern","String","fromCharCode","barThreshold","_computeAlternatingThreshold","spaceThreshold","bitmask","CODE_SHIFT","CODE_C","CODE_B","CODE_A","START_CODE_A","START_CODE_B","START_CODE_C","STOP_CODE","MODULE_INDICES","Code128Reader","_correct","expected","_calculateCorrection","_correctBars","multiplier","checksum","codeset","rawResult","shiftNext","removeLastCharacter","normalized","sumNormalized","sumExpected","ASTERISK","Uint16Array","Code39Reader","lastStart","_toCounters","pop","patternSize","minWidth","maxNarrowWidth","numWideBars","wideBarWidth","_findNextWidth","patternStart","whiteSpaceMustStart","Code39VINReader","replace","_checkChecksum","Code93Reader","_verifyEnd","_verifyChecksums","_decodeExtended","round","charArray","nextChar","nextCharCode","_matchCheckChar","maxWeight","arrayToCheck","weightedSums","weight","checkChar","EAN2Reader","row","codeFrequency","CODE_G_START","parseInt","EANReader","EAN5Reader","_extensionChecksum","_determineCheckDigit","CHECK_DIGIT_ENCODINGS","EAN8Reader","MIDDLE_PATTERN","EXTENSION_START_PATTERN","CODE_FREQUENCY","coderange","firstDigit","_calculateFirstDigit","resultInfo","_checksum","_decodeExtensions","lastCode","MAX_CORRECTION_FACTOR","I2of5Reader","normalizeBarSpaceWidth","counterSum","codeSum","correctionRatio","correctionRatioInverse","counter0","counter1","code0","code1","code_128_reader","ean_reader","ean_5_reader","ean_2_reader","ean_8_reader","code_39_reader","code_39_vin_reader","codabar_reader","upc_reader","UPCReader","upc_e_reader","UPCEReader","i2of5_reader","code_93_reader","_determineParity","nrSystem","lastDigit","upca","_convertToUPCA","charAt","substring"],"mappings":";;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA,CAAC;AACD,W;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;AClFA;AACA;AACA,iDAAiD,gBAAgB;AACjE;AACA;;AAEA;AACA;AACA;;AAEA,oC;;;;;;;;;;;ACVA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,wC;;;;;;;;;;;ACRA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,KAAK;AACL;AACA;;AAEA,mC;;;;;;;;;;;ACpCA;AACA;AACA;AACA;AACA;;AAEA,iC;;;;;;;;;;;ACNA;AACA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,8B;;;;;;;;;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;;AAEA;AACA;;AAEA,iC;;;;;;;;;;;ACfA,qBAAqB,mBAAO,CAAC,qFAAkB;;AAE/C,oBAAoB,mBAAO,CAAC,mFAAiB;;AAE7C;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,sB;;;;;;;;;;;ACxBA;AACA;AACA;AACA;AACA;AACA;;AAEA,iC;;;;;;;;;;;ACPA,qBAAqB,mBAAO,CAAC,qFAAkB;;AAE/C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA,2B;;;;;;;;;;;ACjBA;AACA;AACA;;AAEA,kC;;;;;;;;;;;ACJA;AACA;AACA;;AAEA,oC;;;;;;;;;;;ACJA,cAAc,mBAAO,CAAC,8EAAmB;;AAEzC,4BAA4B,mBAAO,CAAC,mGAAyB;;AAE7D;AACA;AACA;AACA;;AAEA;AACA;;AAEA,4C;;;;;;;;;;;ACZA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,iC;;;;;;;;;;;ACTA,qBAAqB,mBAAO,CAAC,qFAAkB;;AAE/C;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,gC;;;;;;;;;;;ACXA,wBAAwB,mBAAO,CAAC,2FAAqB;;AAErD,sBAAsB,mBAAO,CAAC,uFAAmB;;AAEjD,wBAAwB,mBAAO,CAAC,2FAAqB;;AAErD;AACA;AACA;;AAEA,oC;;;;;;;;;;;ACVA,wBAAwB,2EAA2E,oCAAoC,mBAAmB,GAAG,EAAE,OAAO,oCAAoC,8HAA8H,GAAG,EAAE,sBAAsB;;AAEnW;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;;AAEA,yB;;;;;;;;;;;AChBA,iBAAiB,mBAAO,CAAC,qFAAqB;;;;;;;;;;;;ACA9C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,iBAAiB,mBAAO,CAAC,oEAAW;;AAEpC;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;;;;;;;;;;;ACpCA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd,KAAK;AACL,cAAc;AACd;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,yDAAyD;AACzD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA,WAAW;AACX;;AAEA;AACA;AACA,wCAAwC,WAAW;AACnD;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,SAAS;AACT;AACA;AACA;AACA;;AAEA;;AAEA,SAAS;AACT;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,oCAAoC,cAAc;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,iCAAiC,kBAAkB;AACnD;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,iBAAiB;;AAEjB;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,wBAAwB,iBAAiB;AACzC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,YAAY;AACZ;AACA;;AAEA;AACA,YAAY;AACZ;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,8CAA8C,QAAQ;AACtD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA,WAAW;AACX;AACA;AACA;;AAEA,WAAW;AACX;AACA;AACA;;AAEA,WAAW;AACX;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA,KAAK;;AAEL;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;;;;;;;;;;;AChtBA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;;AAEA;AACA;AACA,4CAA4C;;AAE5C;;;;;;;;;;;;;;;;;;;;;;;;;ACnBA;AAWO,IAAMA,eAAb;AAAA;AAAA;AAQI,2BAAYC,MAAZ,E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","file":"quagga.js","sourcesContent":["\n(function webpackUniversalModuleDefinition(root, factory) {\n    if (typeof exports === 'object' && typeof module === 'object') {\n        module.exports = factory(factory.toString()).default;\n    } else if (typeof exports === 'object') {\n        exports[\"Quagga\"] = factory(factory.toString()).default;\n    } else {\n        root[\"Quagga\"] = factory(factory.toString()).default;\n    }\n})(this, function(__factorySource__) {\n    return "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/quagga.ts\");\n","function _arrayWithoutHoles(arr) {\n  if (Array.isArray(arr)) {\n    for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) {\n      arr2[i] = arr[i];\n    }\n\n    return arr2;\n  }\n}\n\nmodule.exports = _arrayWithoutHoles;","function _assertThisInitialized(self) {\n  if (self === void 0) {\n    throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n  }\n\n  return self;\n}\n\nmodule.exports = _assertThisInitialized;","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n  try {\n    var info = gen[key](arg);\n    var value = info.value;\n  } catch (error) {\n    reject(error);\n    return;\n  }\n\n  if (info.done) {\n    resolve(value);\n  } else {\n    Promise.resolve(value).then(_next, _throw);\n  }\n}\n\nfunction _asyncToGenerator(fn) {\n  return function () {\n    var self = this,\n        args = arguments;\n    return new Promise(function (resolve, reject) {\n      var gen = fn.apply(self, args);\n\n      function _next(value) {\n        asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n      }\n\n      function _throw(err) {\n        asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n      }\n\n      _next(undefined);\n    });\n  };\n}\n\nmodule.exports = _asyncToGenerator;","function _classCallCheck(instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n}\n\nmodule.exports = _classCallCheck;","function _defineProperties(target, props) {\n  for (var i = 0; i < props.length; i++) {\n    var descriptor = props[i];\n    descriptor.enumerable = descriptor.enumerable || false;\n    descriptor.configurable = true;\n    if (\"value\" in descriptor) descriptor.writable = true;\n    Object.defineProperty(target, descriptor.key, descriptor);\n  }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n  if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n  if (staticProps) _defineProperties(Constructor, staticProps);\n  return Constructor;\n}\n\nmodule.exports = _createClass;","function _defineProperty(obj, key, value) {\n  if (key in obj) {\n    Object.defineProperty(obj, key, {\n      value: value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n}\n\nmodule.exports = _defineProperty;","var getPrototypeOf = require(\"./getPrototypeOf\");\n\nvar superPropBase = require(\"./superPropBase\");\n\nfunction _get(target, property, receiver) {\n  if (typeof Reflect !== \"undefined\" && Reflect.get) {\n    module.exports = _get = Reflect.get;\n  } else {\n    module.exports = _get = function _get(target, property, receiver) {\n      var base = superPropBase(target, property);\n      if (!base) return;\n      var desc = Object.getOwnPropertyDescriptor(base, property);\n\n      if (desc.get) {\n        return desc.get.call(receiver);\n      }\n\n      return desc.value;\n    };\n  }\n\n  return _get(target, property, receiver || target);\n}\n\nmodule.exports = _get;","function _getPrototypeOf(o) {\n  module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n    return o.__proto__ || Object.getPrototypeOf(o);\n  };\n  return _getPrototypeOf(o);\n}\n\nmodule.exports = _getPrototypeOf;","var setPrototypeOf = require(\"./setPrototypeOf\");\n\nfunction _inherits(subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function\");\n  }\n\n  subClass.prototype = Object.create(superClass && superClass.prototype, {\n    constructor: {\n      value: subClass,\n      writable: true,\n      configurable: true\n    }\n  });\n  if (superClass) setPrototypeOf(subClass, superClass);\n}\n\nmodule.exports = _inherits;","function _iterableToArray(iter) {\n  if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}\n\nmodule.exports = _iterableToArray;","function _nonIterableSpread() {\n  throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}\n\nmodule.exports = _nonIterableSpread;","var _typeof = require(\"../helpers/typeof\");\n\nvar assertThisInitialized = require(\"./assertThisInitialized\");\n\nfunction _possibleConstructorReturn(self, call) {\n  if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n    return call;\n  }\n\n  return assertThisInitialized(self);\n}\n\nmodule.exports = _possibleConstructorReturn;","function _setPrototypeOf(o, p) {\n  module.exports = _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n    o.__proto__ = p;\n    return o;\n  };\n\n  return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf;","var getPrototypeOf = require(\"./getPrototypeOf\");\n\nfunction _superPropBase(object, property) {\n  while (!Object.prototype.hasOwnProperty.call(object, property)) {\n    object = getPrototypeOf(object);\n    if (object === null) break;\n  }\n\n  return object;\n}\n\nmodule.exports = _superPropBase;","var arrayWithoutHoles = require(\"./arrayWithoutHoles\");\n\nvar iterableToArray = require(\"./iterableToArray\");\n\nvar nonIterableSpread = require(\"./nonIterableSpread\");\n\nfunction _toConsumableArray(arr) {\n  return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();\n}\n\nmodule.exports = _toConsumableArray;","function _typeof2(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof2(obj); }\n\nfunction _typeof(obj) {\n  if (typeof Symbol === \"function\" && _typeof2(Symbol.iterator) === \"symbol\") {\n    module.exports = _typeof = function _typeof(obj) {\n      return _typeof2(obj);\n    };\n  } else {\n    module.exports = _typeof = function _typeof(obj) {\n      return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : _typeof2(obj);\n    };\n  }\n\n  return _typeof(obj);\n}\n\nmodule.exports = _typeof;","module.exports = require(\"regenerator-runtime\");\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n// This method of obtaining a reference to the global object needs to be\n// kept identical to the way it is obtained in runtime.js\nvar g = (function() {\n  return this || (typeof self === \"object\" && self);\n})() || Function(\"return this\")();\n\n// Use `getOwnPropertyNames` because not all browsers support calling\n// `hasOwnProperty` on the global `self` object in a worker. See #183.\nvar hadRuntime = g.regeneratorRuntime &&\n  Object.getOwnPropertyNames(g).indexOf(\"regeneratorRuntime\") >= 0;\n\n// Save the old regeneratorRuntime in case it needs to be restored later.\nvar oldRuntime = hadRuntime && g.regeneratorRuntime;\n\n// Force reevalutation of runtime.js.\ng.regeneratorRuntime = undefined;\n\nmodule.exports = require(\"./runtime\");\n\nif (hadRuntime) {\n  // Restore the original runtime.\n  g.regeneratorRuntime = oldRuntime;\n} else {\n  // Remove the global property added by runtime.js.\n  try {\n    delete g.regeneratorRuntime;\n  } catch(e) {\n    g.regeneratorRuntime = undefined;\n  }\n}\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n!(function(global) {\n  \"use strict\";\n\n  var Op = Object.prototype;\n  var hasOwn = Op.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n  var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n  var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n  var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n  var inModule = typeof module === \"object\";\n  var runtime = global.regeneratorRuntime;\n  if (runtime) {\n    if (inModule) {\n      // If regeneratorRuntime is defined globally and we're in a module,\n      // make the exports object identical to regeneratorRuntime.\n      module.exports = runtime;\n    }\n    // Don't bother evaluating the rest of this file if the runtime was\n    // already defined globally.\n    return;\n  }\n\n  // Define the runtime globally (as expected by generated code) as either\n  // module.exports (if we're in a module) or a new, empty object.\n  runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n    var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n    var generator = Object.create(protoGenerator.prototype);\n    var context = new Context(tryLocsList || []);\n\n    // The ._invoke method unifies the implementations of the .next,\n    // .throw, and .return methods.\n    generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n    return generator;\n  }\n  runtime.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function Generator() {}\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  // This is a polyfill for %IteratorPrototype% for environments that\n  // don't natively support it.\n  var IteratorPrototype = {};\n  IteratorPrototype[iteratorSymbol] = function () {\n    return this;\n  };\n\n  var getProto = Object.getPrototypeOf;\n  var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n  if (NativeIteratorPrototype &&\n      NativeIteratorPrototype !== Op &&\n      hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n    // This environment has a native %IteratorPrototype%; use it instead\n    // of the polyfill.\n    IteratorPrototype = NativeIteratorPrototype;\n  }\n\n  var Gp = GeneratorFunctionPrototype.prototype =\n    Generator.prototype = Object.create(IteratorPrototype);\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunctionPrototype[toStringTagSymbol] =\n    GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function(method) {\n      prototype[method] = function(arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  runtime.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  runtime.mark = function(genFun) {\n    if (Object.setPrototypeOf) {\n      Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n    } else {\n      genFun.__proto__ = GeneratorFunctionPrototype;\n      if (!(toStringTagSymbol in genFun)) {\n        genFun[toStringTagSymbol] = \"GeneratorFunction\";\n      }\n    }\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n  // meant to be awaited.\n  runtime.awrap = function(arg) {\n    return { __await: arg };\n  };\n\n  function AsyncIterator(generator) {\n    function invoke(method, arg, resolve, reject) {\n      var record = tryCatch(generator[method], generator, arg);\n      if (record.type === \"throw\") {\n        reject(record.arg);\n      } else {\n        var result = record.arg;\n        var value = result.value;\n        if (value &&\n            typeof value === \"object\" &&\n            hasOwn.call(value, \"__await\")) {\n          return Promise.resolve(value.__await).then(function(value) {\n            invoke(\"next\", value, resolve, reject);\n          }, function(err) {\n            invoke(\"throw\", err, resolve, reject);\n          });\n        }\n\n        return Promise.resolve(value).then(function(unwrapped) {\n          // When a yielded Promise is resolved, its final value becomes\n          // the .value of the Promise<{value,done}> result for the\n          // current iteration.\n          result.value = unwrapped;\n          resolve(result);\n        }, function(error) {\n          // If a rejected Promise was yielded, throw the rejection back\n          // into the async generator function so it can be handled there.\n          return invoke(\"throw\", error, resolve, reject);\n        });\n      }\n    }\n\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      function callInvokeWithMethodAndArg() {\n        return new Promise(function(resolve, reject) {\n          invoke(method, arg, resolve, reject);\n        });\n      }\n\n      return previousPromise =\n        // If enqueue has been called before, then we want to wait until\n        // all previous Promises have been resolved before calling invoke,\n        // so that results are always delivered in the correct order. If\n        // enqueue has not been called before, then it is important to\n        // call invoke immediately, without waiting on a callback to fire,\n        // so that the async generator function has the opportunity to do\n        // any necessary setup in a predictable way. This predictability\n        // is why the Promise constructor synchronously invokes its\n        // executor callback, and why async functions synchronously\n        // execute code before the first await. Since we implement simple\n        // async functions in terms of async generators, it is especially\n        // important to get this right, even though it requires care.\n        previousPromise ? previousPromise.then(\n          callInvokeWithMethodAndArg,\n          // Avoid propagating failures to Promises returned by later\n          // invocations of the iterator.\n          callInvokeWithMethodAndArg\n        ) : callInvokeWithMethodAndArg();\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n  AsyncIterator.prototype[asyncIteratorSymbol] = function () {\n    return this;\n  };\n  runtime.AsyncIterator = AsyncIterator;\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  runtime.async = function(innerFn, outerFn, self, tryLocsList) {\n    var iter = new AsyncIterator(\n      wrap(innerFn, outerFn, self, tryLocsList)\n    );\n\n    return runtime.isGeneratorFunction(outerFn)\n      ? iter // If outerFn is a generator, return the full iterator.\n      : iter.next().then(function(result) {\n          return result.done ? result.value : iter.next();\n        });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      context.method = method;\n      context.arg = arg;\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var delegateResult = maybeInvokeDelegate(delegate, context);\n          if (delegateResult) {\n            if (delegateResult === ContinueSentinel) continue;\n            return delegateResult;\n          }\n        }\n\n        if (context.method === \"next\") {\n          // Setting context._sent for legacy support of Babel's\n          // function.sent implementation.\n          context.sent = context._sent = context.arg;\n\n        } else if (context.method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw context.arg;\n          }\n\n          context.dispatchException(context.arg);\n\n        } else if (context.method === \"return\") {\n          context.abrupt(\"return\", context.arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          if (record.arg === ContinueSentinel) {\n            continue;\n          }\n\n          return {\n            value: record.arg,\n            done: context.done\n          };\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(context.arg) call above.\n          context.method = \"throw\";\n          context.arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Call delegate.iterator[context.method](context.arg) and handle the\n  // result, either by returning a { value, done } result from the\n  // delegate iterator, or by modifying context.method and context.arg,\n  // setting context.delegate to null, and returning the ContinueSentinel.\n  function maybeInvokeDelegate(delegate, context) {\n    var method = delegate.iterator[context.method];\n    if (method === undefined) {\n      // A .throw or .return when the delegate iterator has no .throw\n      // method always terminates the yield* loop.\n      context.delegate = null;\n\n      if (context.method === \"throw\") {\n        if (delegate.iterator.return) {\n          // If the delegate iterator has a return method, give it a\n          // chance to clean up.\n          context.method = \"return\";\n          context.arg = undefined;\n          maybeInvokeDelegate(delegate, context);\n\n          if (context.method === \"throw\") {\n            // If maybeInvokeDelegate(context) changed context.method from\n            // \"return\" to \"throw\", let that override the TypeError below.\n            return ContinueSentinel;\n          }\n        }\n\n        context.method = \"throw\";\n        context.arg = new TypeError(\n          \"The iterator does not provide a 'throw' method\");\n      }\n\n      return ContinueSentinel;\n    }\n\n    var record = tryCatch(method, delegate.iterator, context.arg);\n\n    if (record.type === \"throw\") {\n      context.method = \"throw\";\n      context.arg = record.arg;\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    var info = record.arg;\n\n    if (! info) {\n      context.method = \"throw\";\n      context.arg = new TypeError(\"iterator result is not an object\");\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    if (info.done) {\n      // Assign the result of the finished delegate to the temporary\n      // variable specified by delegate.resultName (see delegateYield).\n      context[delegate.resultName] = info.value;\n\n      // Resume execution at the desired location (see delegateYield).\n      context.next = delegate.nextLoc;\n\n      // If context.method was \"throw\" but the delegate handled the\n      // exception, let the outer generator proceed normally. If\n      // context.method was \"next\", forget context.arg since it has been\n      // \"consumed\" by the delegate iterator. If context.method was\n      // \"return\", allow the original .return call to continue in the\n      // outer generator.\n      if (context.method !== \"return\") {\n        context.method = \"next\";\n        context.arg = undefined;\n      }\n\n    } else {\n      // Re-yield the result returned by the delegate method.\n      return info;\n    }\n\n    // The delegate iterator is finished, so forget it and continue with\n    // the outer generator.\n    context.delegate = null;\n    return ContinueSentinel;\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\n\n  Gp[toStringTagSymbol] = \"Generator\";\n\n  // A Generator should always return itself as the iterator object when the\n  // @@iterator function is called on it. Some browsers' implementations of the\n  // iterator prototype chain incorrectly implement this, causing the Generator\n  // object to not be returned from this call. This ensures that doesn't happen.\n  // See https://github.com/facebook/regenerator/issues/274 for more details.\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset(true);\n  }\n\n  runtime.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  runtime.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function(skipTempReset) {\n      this.prev = 0;\n      this.next = 0;\n      // Resetting context._sent for legacy support of Babel's\n      // function.sent implementation.\n      this.sent = this._sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.method = \"next\";\n      this.arg = undefined;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" &&\n              hasOwn.call(this, name) &&\n              !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n\n        if (caught) {\n          // If the dispatched exception was caught by a catch block,\n          // then let that catch block handle the exception normally.\n          context.method = \"next\";\n          context.arg = undefined;\n        }\n\n        return !! caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg <= finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.method = \"next\";\n        this.next = finallyEntry.finallyLoc;\n        return ContinueSentinel;\n      }\n\n      return this.complete(record);\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = this.arg = record.arg;\n        this.method = \"return\";\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      if (this.method === \"next\") {\n        // Deliberately forget the last sent value so that we don't\n        // accidentally pass it on to the delegate.\n        this.arg = undefined;\n      }\n\n      return ContinueSentinel;\n    }\n  };\n})(\n  // In sloppy mode, unbound `this` refers to the global object, fallback to\n  // Function constructor if we're in global strict mode. That is sadly a form\n  // of indirect eval which violates Content Security Policy.\n  (function() {\n    return this || (typeof self === \"object\" && self);\n  })() || Function(\"return this\")()\n);\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","import { ImageDebug } from '../common/image-debug';\nimport { QuaggaBarcode } from '../decoder/barcode-decoder';\nimport { Barcode } from '../reader/barcode-reader';\n\nexport interface ResultCollectorConfig {\n    capacity?: number;\n    capture?: boolean;\n    blacklist?: Array<Barcode>;\n    filter?: (item: Barcode) => boolean;\n}\n\nexport class ResultCollector {\n    private _canvas: HTMLCanvasElement;\n    private _context: CanvasRenderingContext2D;\n    private _config: ResultCollectorConfig;\n    private _capacity: number;\n    private _capture: boolean;\n    private _results: Array<QuaggaBarcode>;\n\n    constructor(config: ResultCollectorConfig) {\n        this._results = new Array<QuaggaBarcode>();\n        this._config = config;\n        this._capacity = config.capacity || 20;\n        this._capture = config.capture === true;\n\n        if (this._capture) {\n            this._canvas = document.createElement('canvas');\n            this._context = this._canvas.getContext('2d');\n        }\n    }\n\n    addResult(data: Uint8Array, imageWidth: number, imageHeight: number, codeResult: Barcode): void {\n        if (codeResult && this._capacity && !this._contains(codeResult) && this._passesFilter(codeResult)) {\n            const result: QuaggaBarcode = { codeResult };\n\n            this._capacity--;\n\n            if (this._capture) {\n                this._canvas.width = imageWidth;\n                this._canvas.height = imageHeight;\n\n                ImageDebug.drawImage(data, imageWidth, imageHeight, this._context);\n\n                result.frame = this._canvas.toDataURL();\n            }\n\n            this._results.push(result);\n        }\n    }\n\n    getResults(): Array<QuaggaBarcode> {\n        return this._results;\n    }\n\n    private _contains(codeResult: Barcode): boolean {\n        return this._config.blacklist &&\n            this._config.blacklist.some(item => Object.keys(item).every(key => item[key] === codeResult[key]));\n    }\n\n    private _passesFilter(codeResult: Barcode): boolean {\n        return typeof this._config.filter !== 'function' || this._config.filter(codeResult);\n    }\n}\n","import { Moment } from './moment';\n\n\n/**\n * Creates a cluster for grouping similar orientations of moments\n */\nexport class Cluster {\n    private _threshold: number;\n    private _moments: Array<Moment>;\n    private _center: Moment;\n\n    static clusterize(moments: Array<Moment>, threshold: number): Array<Cluster> {\n        const clusters = new Array<Cluster>();\n\n        moments.forEach(moment => {\n            const matchingCluster = clusters.find(cluster => cluster.fits(moment));\n\n            if (matchingCluster) {\n                matchingCluster.add(moment);\n            } else {\n                clusters.push(new Cluster(threshold, moment));\n            }\n        });\n\n        return clusters;\n    }\n\n    constructor(threshold: number, moment: Moment) {\n        this._threshold = threshold;\n        this._moments = new Array<Moment>();\n        this._center = {\n            rad: 0,\n            x: 0,\n            y: 0\n        };\n\n        if (moment) {\n            this.add(moment);\n        }\n    }\n\n    add(point: Moment) {\n        this._moments.push(point);\n\n        // Update center\n        this._center.rad = this._moments.reduce((sum, p) => sum + p.rad, 0) / this._moments.length;\n        this._center.x = Math.cos(this._center.rad);\n        this._center.y = Math.sin(this._center.rad);\n    }\n\n    fits(moment: Moment): boolean {\n        // check cosine similarity to center-angle\n        const similarity = Math.abs(moment.x * this._center.x + moment.y * this._center.y);\n        return similarity > this._threshold;\n    }\n\n    get moments() {\n        return this._moments;\n    }\n}\n","export interface EventCallback {\n    (data: any): void;\n}\n\nexport interface EventSubscription {\n    callback: EventCallback;\n    async?: boolean;\n    once?: boolean;\n}\n\ninterface EventItem {\n    subscriptions: Array<EventSubscription>\n}\n\nlet events: { [name: string]: EventItem } = {};\n\nexport class Events {\n    static subscribe(event: string, callback: EventSubscription | EventCallback, async?: boolean) {\n        let subscription: EventSubscription;\n\n        if (typeof callback === 'function') {\n            subscription = {\n                callback,\n                async\n            };\n        } else {\n            subscription = callback;\n            if (!subscription.callback) {\n                throw 'Callback was not specified on options';\n            }\n        }\n\n        getEvent(event).subscriptions.push(subscription);\n    }\n\n    static publish(type: string, data?: any) {\n        const eventItem = getEvent(type);\n        const subscriptions = eventItem.subscriptions;\n\n        // Publish one-time subscriptions\n        subscriptions.filter(({ once }) => !!once).forEach(subscription => publishSubscription(subscription, data));\n\n        // remove them from the subscription\n        eventItem.subscriptions = subscriptions.filter(({ once }) => !once);\n\n        // publish the rest\n        eventItem.subscriptions.forEach(subscription => publishSubscription(subscription, data));\n    }\n\n    static once(event: string, callback: EventCallback, async?: boolean): void {\n        Events.subscribe(event, { callback, async, once: true });\n    }\n\n    static unsubscribe(eventName?: string, callback?: EventCallback) {\n        if (eventName) {\n            const event = getEvent(eventName);\n            if (event && callback) {\n                event.subscriptions = event.subscriptions.filter(subscription => subscription.callback !== callback);\n            } else {\n                event.subscriptions = [];\n            }\n        } else {\n            events = {};\n        }\n    }\n}\n\nfunction getEvent(eventName: string): EventItem {\n    if (!events[eventName]) {\n        events[eventName] = {\n            subscriptions: []\n        };\n    }\n    return events[eventName];\n}\n\nfunction publishSubscription(subscription: EventSubscription, data: any): void {\n    if (subscription.async) {\n        setTimeout(function () {\n            subscription.callback(data);\n        }, 4);\n    } else {\n        subscription.callback(data);\n    }\n}\n","export type HSV = [number, number, number];\n\nexport type RGB = [number, number, number];\n\nexport function hsv2rgb(hsv: HSV, rgb?: RGB): RGB {\n    const h = hsv[0];\n    const s = hsv[1];\n    const v = hsv[2];\n    const c = v * s;\n    const x = c * (1 - Math.abs((h / 60) % 2 - 1));\n    const m = v - c;\n    let r = 0;\n    let g = 0;\n    let b = 0;\n\n    if (h < 60) {\n        r = c;\n        g = x;\n    } else if (h < 120) {\n        r = x;\n        g = c;\n    } else if (h < 180) {\n        g = c;\n        b = x;\n    } else if (h < 240) {\n        g = x;\n        b = c;\n    } else if (h < 300) {\n        r = x;\n        b = c;\n    } else if (h < 360) {\n        r = c;\n        b = x;\n    }\n\n    rgb = rgb || [0, 0, 0];\n\n    rgb[0] = (r + m) * 255 | 0;\n    rgb[1] = (g + m) * 255 | 0;\n    rgb[2] = (b + m) * 255 | 0;\n\n    return rgb;\n}\n","import { Point } from './point';\n\nexport const ImageDebug = {\n    drawPath(path: Array<Point>, context: CanvasRenderingContext2D, color: string, lineWidth: number): void {\n        if (path && path.length > 1) {\n            context.strokeStyle = color;\n            context.fillStyle = color;\n            context.lineWidth = lineWidth;\n            context.beginPath();\n            context.moveTo(path[0].x, path[0].y);\n            path.slice(1).forEach(({ x, y }) => context.lineTo(x, y));\n            context.closePath();\n            context.stroke();\n        }\n    },\n\n    drawImage(imageData: Uint8Array, width: number, height: number, context: CanvasRenderingContext2D): boolean {\n        const canvasData = context.getImageData(0, 0, width, height);\n        const data = canvasData.data;\n        let imageIndex = imageData.length | 0;\n        let canvasIndex = data.length | 0;\n\n        if (canvasIndex / imageIndex !== 4) {\n            return false;\n        }\n\n        while (imageIndex--) {\n            const value = imageData[imageIndex];\n            data[--canvasIndex] = 255;\n            data[--canvasIndex] = value;\n            data[--canvasIndex] = value;\n            data[--canvasIndex] = value;\n        }\n\n        context.putImageData(canvasData, 0, 0);\n\n        return true;\n    }\n}\n","import { Moment } from './moment';\nimport { Point } from './point';\nimport { HSV, hsv2rgb, RGB } from './hsv2rgb';\n\ntype ArrayType = Array<number> | Uint8Array | Int32Array;\n\n/**\n * Represents a basic image combining the data and size.\n * In addition, some methods for manipulation are contained.\n */\nexport class ImageWrapper<T extends ArrayType = Uint8Array> {\n    data: T | Uint8Array;\n    size: Point;\n\n    /**\n     * @param size The size of the image in pixel\n     * @param data If given, a flat array containing the pixel data\n     * @param arrayType If given, the desired DataType of the Array (may be typed/non-typed)\n     * @param initialize Indicating if the array should be initialized on creation.\n     */\n    constructor(size: Point, data?: T, arrayType?: { new(_: number): T | Uint8Array }, initialize?: boolean) {\n        if (!data) {\n            this.data = new (arrayType || Uint8Array)(size.x * size.y);\n\n            if (initialize) {\n                this.data.fill(0);\n            }\n        } else {\n            this.data = data;\n        }\n\n        this.size = size;\n    }\n\n    /**\n     * Tests if a position is within the image with a given offset\n     * @param point The location to test\n     * @param border The padding value in pixels\n     * @returns true if location inside the image's border, false otherwise\n     * @see cvd/image.h\n     */\n    inImageWithBorder(point: Point, border: number): boolean {\n        return (point.x >= border)\n            && (point.y >= border)\n            && (point.x < (this.size.x - border))\n            && (point.y < (this.size.y - border));\n    }\n\n    /**\n     * Creates an {ImageWrapper) and copies the needed underlying image-data area\n     * @param imageWrapper The target {ImageWrapper} where the data should be copied\n     * @param fromX The horizontal position where to copy from\n     * @param fromY The vertical position where to copy from\n    */\n    subImageAsCopy(imageWrapper: ImageWrapper, fromX: number, fromY: number): void {\n        const sizeY = imageWrapper.size.y;\n        const sizeX = imageWrapper.size.x;\n\n        for (let x = 0; x < sizeX; x++) {\n            for (let y = 0; y < sizeY; y++) {\n                imageWrapper.data[y * sizeX + x] = this.data[(fromY + y) * this.size.x + fromX + x];\n            }\n        }\n    }\n\n    /**\n     * Retrieves a given pixel position from the image\n     * @param x The x-position\n     * @param y The y-position\n     * @returns The grayscale value at the pixel-position\n     */\n    get(x: number, y: number): number {\n        return this.data[y * this.size.x + x];\n    }\n\n    /**\n     * Sets a given pixel position in the image\n     * @param x The x-position\n     * @param y The y-position\n     * @param value The grayscale value to set\n     * @returns The Image itself (for possible chaining)\n     */\n    set(x: number, y: number, value: number): ImageWrapper<T> {\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     */\n    zeroBorder(): void {\n        const width = this.size.x;\n        const height = this.size.y;\n        const data = this.data;\n\n        for (let i = 0; i < width; i++) {\n            data[i] = data[(height - 1) * width + i] = 0;\n        }\n\n        for (let 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     */\n    invert(): void {\n        const data = this.data;\n\n        for (let i = data.length; i--;) {\n            data[i] = data[i] ? 0 : 1;\n        }\n    }\n\n    moments(labelCount: number): Array<Moment> {\n        const height = this.size.y;\n        const width = this.size.x;\n        const labelSum = new Array<Moment>();\n        const result = new Array<Moment>();\n\n        if (labelCount <= 0) {\n            return result;\n        }\n\n        for (let 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 (let y = 0; y < height; y++) {\n            const ysq = y * y;\n            for (let x = 0; x < width; x++) {\n                const val = this.data[y * width + x];\n                if (val > 0) {\n                    const 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        const PI = Math.PI;\n        const PI_4 = PI / 4;\n\n        for (let i = 0; i < labelCount; i++) {\n            const label = labelSum[i];\n            if (!isNaN(label.m00) && label.m00 !== 0) {\n                const x_ = label.m10 / label.m00;\n                const y_ = label.m01 / label.m00;\n                const mu11 = label.m11 / label.m00 - x_ * y_;\n                const mu02 = label.m02 / label.m00 - y_ * y_;\n                const mu20 = label.m20 / label.m00 - x_ * x_;\n                const tmp = 0.5 * Math.atan((mu02 - mu20) / (2 * mu11)) + (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.x = Math.cos(tmp);\n                label.y = 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 context The rendering context to write to\n     * @param scale Scale which is applied to each pixel-value\n     */\n    show(context: CanvasRenderingContext2D, scale: number): void {\n        const height = this.size.y;\n        const width = this.size.x;\n        // const context = canvas.getContext('2d');\n        // canvas.height = height;\n        // canvas.width = width;\n        const frame = context.getImageData(0, 0, width, height);\n        const data = frame.data;\n        let current = 0;\n\n        if (!scale) {\n            scale = 1.0;\n        }\n\n        for (let y = 0; y < height; y++) {\n            for (let x = 0; x < width; x++) {\n                const pixel = y * width + 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\n        //frame.data = data;\n        context.putImageData(frame, 0, 0);\n    }\n\n    /**\n     * Displays the part of the image in a given canvas\n     * @param context The rendering context to write to\n     * @param scale Scale which is applied to each pixel-value\n     * @param fromX The horizontal position where to overlay from\n     * @param fromY The vertical position where to overlay from\n     */\n    overlay(context: CanvasRenderingContext2D, scale: number, fromX: number, fromY: number): void {\n        const hsv: HSV = [0, 1, 1];\n        const whiteRgb: RGB = [255, 255, 255];\n        const blackRgb: RGB = [0, 0, 0];\n        const frame = context.getImageData(fromX, fromY, this.size.x, this.size.y);\n        const data = frame.data;\n\n        if (!scale || scale < 0 || scale > 360) {\n            scale = 360;\n        }\n\n        for (let length = this.data.length; length--;) {\n            hsv[0] = this.data[length] * scale;\n            const rgb: RGB = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : hsv2rgb(hsv);\n            data[length * 4 + 0] = rgb[0];\n            data[length * 4 + 1] = rgb[1];\n            data[length * 4 + 2] = rgb[2];\n            data[length * 4 + 3] = 255;\n        }\n\n        context.putImageData(frame, fromX, fromY);\n    }\n}\n","\nexport function enumerateDevices(): Promise<Array<MediaDeviceInfo>> {\n    if (navigator.mediaDevices && typeof navigator.mediaDevices.enumerateDevices === 'function') {\n        return navigator.mediaDevices.enumerateDevices();\n    }\n    return Promise.reject(new Error('enumerateDevices is not defined'));\n}\n\nexport function getUserMedia(constraints: MediaStreamConstraints): Promise<MediaStream> {\n    if (navigator.mediaDevices && typeof navigator.mediaDevices.getUserMedia === 'function') {\n        return navigator.mediaDevices.getUserMedia(constraints);\n    }\n    return Promise.reject(new Error('getUserMedia is not defined'));\n}\n","/**\n * Performs a deep merge of objects and returns new object.\n * Does not modify objects (immutable).\n * @see https://stackoverflow.com/a/48218209\n *\n * @param objects - Objects to merge\n * @returns New object with merged key/values\n */\nexport function merge(...objects: ReadonlyArray<any>): object {\n    const isObject = (obj: unknown) => obj && typeof obj === 'object';\n\n    return objects.reduce((prev, obj) => {\n        if (obj) {\n            Object.keys(obj).forEach(key => {\n                const pVal = prev[key];\n                const oVal = obj[key];\n\n                if (Array.isArray(pVal) && Array.isArray(oVal)) {\n                    // prev[key] = pVal.concat(...oVal);\n                    prev[key] = oVal;\n                } else if (isObject(pVal) && isObject(oVal)) {\n                    prev[key] = merge(pVal, oVal);\n                } else {\n                    prev[key] = oVal;\n                }\n            });\n        }\n\n        return prev;\n    }, {});\n}","import { QuaggaConfig } from './config';\n\nexport const config: QuaggaConfig = {\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","import { Box } from '../common/box';\nimport { ImageWrapper } from '../common/image-wrapper';\nimport { Point } from '../common/point';\nimport { Readers } from '../reader/index';\nimport { Barcode, BarcodeReader, BarcodeReaderConfig, BarcodeReaderDeclaration, BarcodeReaderType } from '../reader/barcode-reader';\nimport { BarcodeLine, Bresenham } from './bresenham';\nimport { ImageDebug } from '../common/image-debug';\n\nexport interface BarcodeDecoderConfig {\n    debug?: {\n        drawBoundingBox?: boolean;\n        drawScanline?: boolean;\n        showFrequency?: boolean;\n        showPattern?: boolean;\n    };\n    multiple?: boolean;\n    readers?: Array<BarcodeReaderDeclaration>;\n}\n\ntype Line = [Point, Point];\n\nexport interface QuaggaBarcode {\n    angle?: number;\n    barcodes?: Array<QuaggaBarcode>; // TOOD: deal with multiple results\n    box?: Box;\n    boxes?: Array<Box>; // TOOD: deal with multiple results\n    codeResult?: Barcode;\n    frame?: string;\n    line?: Line;\n    pattern?: Array<number>;\n    threshold?: number;\n};\n\ninterface BarcodeAndBarcodeLine {\n    codeResult: Barcode;\n    barcodeLine: BarcodeLine;\n}\n\nexport class BarcodeDecoder {\n    private _config: BarcodeDecoderConfig;\n    private _inputImageWrapper: ImageWrapper<Uint8Array>;\n    private _frequencyCanvas: HTMLCanvasElement;\n    private _patternCanvas: HTMLCanvasElement;\n    private _overlayContext: CanvasRenderingContext2D;\n    private _barcodeReaders: Array<BarcodeReader>;\n\n    constructor(config: BarcodeDecoderConfig, inputImageWrapper: ImageWrapper<Uint8Array>) {\n        this._config = config;\n        this._inputImageWrapper = inputImageWrapper;\n        this._barcodeReaders = [];\n\n        if (process.env.NODE_ENV !== 'production' && this._config.debug && typeof document !== 'undefined') {\n            const debugDiv = document.querySelector('#debug.detection');\n\n            this._frequencyCanvas = document.querySelector('canvas.frequency');\n            if (!this._frequencyCanvas) {\n                this._frequencyCanvas = document.createElement('canvas');\n                this._frequencyCanvas.className = 'frequency';\n                if (debugDiv) {\n                    debugDiv.appendChild(this._frequencyCanvas);\n                }\n            }\n            this._frequencyCanvas.style.display = this._config.debug.showFrequency ? 'block' : 'none';\n\n            this._patternCanvas = document.querySelector('canvas.patternBuffer');\n            if (!this._patternCanvas) {\n                this._patternCanvas = document.createElement('canvas');\n                this._patternCanvas.className = 'patternBuffer';\n                if (debugDiv) {\n                    debugDiv.appendChild(this._patternCanvas);\n                }\n            }\n            this._patternCanvas.style.display = this._config.debug.showPattern ? 'block' : 'none';\n\n            const overlayCanvas = document.querySelector<HTMLCanvasElement>('canvas.drawingBuffer');\n            this._overlayContext = overlayCanvas ? overlayCanvas.getContext('2d') : null;\n        }\n\n        this._initReaders();\n    }\n\n    decodeFromBoundingBoxes(boxes: Array<Box>): QuaggaBarcode {\n        let barcode: QuaggaBarcode = null;\n\n        if (boxes) {\n            if (this._config.multiple) {\n                const barcodes = boxes.map(box => this.decodeFromBoundingBox(box));\n                return { barcodes, boxes };\n            }\n            if (boxes.some(box => !!(barcode = this.decodeFromBoundingBox(box)))) {\n                barcode.boxes = boxes;\n            }\n        }\n\n        return barcode;\n    }\n\n    /**\n     * With the help of the configured readers this function tries to detect\n     * a valid barcode pattern within the given area.\n     * @param box The area to search in\n     * @returns The result {codeResult, line, angle, pattern, threshold}\n     */\n    decodeFromBoundingBox(box: Box): QuaggaBarcode {\n        const debug = process.env.NODE_ENV !== 'production' && this._overlayContext && this._config.debug;\n\n        if (debug && debug.drawBoundingBox) {\n            this._drawPath(box, 'blue', 2);\n        }\n\n        let line = this._getLine(box);\n\n        if (line === null) {\n            return null;\n        }\n\n        const angle = Math.atan2(line[1].y - line[0].y, line[1].x - line[0].x);\n        line = this._getExtendedLine(line, angle);\n\n        let result = this._tryDecode(line);\n        if (result === null) {\n            result = this._tryDecodeBruteForce(box, line, angle);\n        }\n\n        if (result === null) {\n            return null;\n        }\n\n        if (debug && debug.drawScanline) {\n            this._drawPath(line, 'red', 3);\n        }\n\n        return {\n            angle,\n            box,\n            codeResult: result.codeResult,\n            line,\n            pattern: result.barcodeLine.line,\n            threshold: result.barcodeLine.threshold\n        };\n    }\n\n    setReaders(readers: Array<BarcodeReaderDeclaration>): void {\n        this._config.readers = readers;\n        this._barcodeReaders.length = 0;\n        this._initReaders();\n    }\n\n    private _initReaders(): void {\n        this._config.readers.forEach(readerConfig => {\n            let reader: BarcodeReaderType;\n            let configuration: BarcodeReaderConfig = {};\n            let supplements = [];\n\n            if (typeof readerConfig === 'object') {\n                reader = readerConfig.format;\n                configuration = readerConfig.config || {};\n            } else if (typeof readerConfig === 'string') {\n                reader = readerConfig;\n            }\n\n            if (process.env.NODE_ENV !== 'production') {\n                console.log('Before registering reader:', reader);\n            }\n\n            if (configuration.supplements) {\n                supplements = configuration.supplements.map(supplement => new Readers[supplement]());\n            }\n\n            this._barcodeReaders.push(new Readers[reader](configuration, supplements));\n        });\n\n        if (process.env.NODE_ENV !== 'production') {\n            console.log('Registered Readers:',\n                ...this._barcodeReaders.map(({ config, FORMAT }) => JSON.stringify({ config, FORMAT })));\n        }\n    }\n\n    /**\n     * extend the line on both ends\n     * @param line\n     * @param angle\n     */\n    private _getExtendedLine(line: Line, angle: number): Line {\n        function extendLine(amount: number) {\n            const extension = {\n                y: amount * Math.sin(angle),\n                x: amount * Math.cos(angle)\n            };\n\n            line[0].y -= extension.y;\n            line[0].x -= extension.x;\n            line[1].y += extension.y;\n            line[1].x += extension.x;\n        }\n\n        const lineLength = Math.sqrt((line[1].y - line[0].y) ** 2 + (line[1].x - line[0].x) ** 2);\n        let extensionLength = lineLength * 0.1 | 0;\n\n        extendLine(extensionLength);\n\n        // check if inside image\n        while (extensionLength > 1 && (!this._inputImageWrapper.inImageWithBorder(line[0], 0)\n            || !this._inputImageWrapper.inImageWithBorder(line[1], 0))) {\n            extensionLength >>= 1;\n            extendLine(-extensionLength);\n        }\n\n        return line;\n    }\n\n    private _getLine(box: Box): Line {\n        return [{\n            x: (box[1].x + box[0].x) / 2,\n            y: (box[1].y + box[0].y) / 2\n        }, {\n            x: (box[3].x + box[2].x) / 2,\n            y: (box[3].y + box[2].y) / 2\n        }];\n    }\n\n    private _tryDecode(line: Line): BarcodeAndBarcodeLine {\n        const debug = process.env.NODE_ENV !== 'production' && this._config.debug;\n\n        if (debug && this._overlayContext) {\n            this._drawPath(line, 'red', 3);\n        }\n\n        let barcodeLine = Bresenham.getBarcodeLine(this._inputImageWrapper, line[0], line[1]);\n\n        if (debug && debug.showFrequency) {\n            this._printFrequency(barcodeLine.line);\n        }\n\n        barcodeLine = Bresenham.toBinaryLine(barcodeLine);\n\n        if (debug && debug.showPattern) {\n            this._printPattern(barcodeLine.line);\n        }\n\n        let codeResult: Barcode = null;\n\n        this._barcodeReaders.some(reader => !!(codeResult = reader.decodePattern(barcodeLine.line)));\n\n        return codeResult ? { codeResult, barcodeLine } : null;\n    }\n\n    /**\n     * This method slices the given area apart and tries to detect a barcode-pattern for each slice.\n     * It returns the decoded barcode, or null if nothing was found\n     * @param box\n     * @param line\n     * @param lineAngle\n     */\n    private _tryDecodeBruteForce(box: Box, line: Line, lineAngle: number): BarcodeAndBarcodeLine {\n        const sideLength = Math.sqrt((box[1].x - box[0].x) ** 2 + (box[1].y - box[0].y) ** 2);\n        const slices = 16;\n        const xdir = Math.sin(lineAngle);\n        const ydir = Math.cos(lineAngle);\n\n        for (let i = 1; i < slices; i++) {\n            // move line perpendicular to angle\n            const dir = sideLength / slices * i * (i % 2 === 0 ? -1 : 1);\n            line[0].y += dir * xdir;\n            line[0].x -= dir * ydir;\n            line[1].y += dir * xdir;\n            line[1].x -= dir * ydir;\n\n            const result = this._tryDecode(line);\n            if (result) {\n                return result;\n            }\n        }\n\n        return null;\n    }\n\n    /**\n     * Used for development only\n     */\n    private _printFrequency(line: Array<number>): void {\n        const context = this._frequencyCanvas.getContext('2d');\n        this._frequencyCanvas.width = line.length;\n        this._frequencyCanvas.height = 256;\n\n        context.beginPath();\n        context.strokeStyle = 'blue';\n\n        for (let i = 0; i < line.length; i++) {\n            context.moveTo(i, 255);\n            context.lineTo(i, 255 - line[i]);\n        }\n\n        context.closePath();\n        context.stroke();\n    }\n\n    /**\n     * Used for development only\n     */\n    private _printPattern(line: Array<number>): void {\n        const context = this._patternCanvas.getContext('2d');\n\n        this._patternCanvas.width = line.length;\n        context.fillStyle = 'black';\n\n        for (let i = 0; i < line.length; i++) {\n            if (line[i] === 1) {\n                context.fillRect(i, 0, 1, 100);\n            }\n        }\n    }\n\n    private _drawPath(path: Array<Point>, color: string, lineWidth: number): void {\n        ImageDebug.drawPath(path, this._overlayContext, color, lineWidth);\n    }\n}\n","import { Point } from '../common/point';\nimport { ImageWrapper } from '../common/image-wrapper';\n\nenum Slope {\n    Up = 1,\n    Down = -1\n};\n\nexport interface BarcodeLine {\n    line: Array<number>;\n    max?: number;\n    min?: number;\n    threshold?: number;\n}\n\nexport const Bresenham = {\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 and max values.\n     * @param imageWrapper\n     * @param p1 The start point {x,y}\n     * @param p2 The end point {x,y}\n     * @returns {line, min, max}\n     */\n    getBarcodeLine(imageWrapper: ImageWrapper, p1: Point, p2: Point): BarcodeLine {\n        let x0 = p1.x | 0;\n        let y0 = p1.y | 0;\n        let x1 = p2.x | 0;\n        let y1 = p2.y | 0;\n        const steep = Math.abs(y1 - y0) > Math.abs(x1 - x0);\n        let tmp: number;\n        const line = [];\n        const imageData = imageWrapper.data;\n        const width = imageWrapper.size.x;\n        let val: number;\n        let min = 255;\n        let max = 0;\n\n        function read(a: number, b: number) {\n            val = imageData[b * width + a];\n            min = val < min ? val : min;\n            max = val > max ? val : max;\n            line.push(val);\n        }\n\n        if (steep) {\n            tmp = x0;\n            x0 = y0;\n            y0 = tmp;\n\n            tmp = x1;\n            x1 = y1;\n            y1 = tmp;\n        }\n        if (x0 > x1) {\n            tmp = x0;\n            x0 = x1;\n            x1 = tmp;\n\n            tmp = y0;\n            y0 = y1;\n            y1 = tmp;\n        }\n\n        let deltax = x1 - x0;\n        let deltay = Math.abs(y1 - y0);\n        let error = (deltax / 2) | 0;\n        let y = y0;\n        let ystep = y0 < y1 ? 1 : -1;\n\n        for (let 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 += ystep;\n                error = error + deltax;\n            }\n        }\n\n        return {\n            line,\n            min,\n            max\n        };\n    },\n\n    /**\n     * Converts the result from getBarcodeLine into a binary representation\n     * also considering the frequency and slope of the signal for more robust results\n     * @param result {line, min, max}\n     */\n    toBinaryLine(result: BarcodeLine): BarcodeLine {\n        const min = result.min;\n        const max = result.max;\n        const line = result.line;\n        const center = min + (max - min) / 2;\n        const extrema = new Array<{ pos: number; val: number; }>();\n        let threshold = (max - min) / 12;\n        const rThreshold = -threshold;\n\n        // 1. find extrema\n        let currentDir = line[0] > center ? Slope.Up : Slope.Down;\n        extrema.push({\n            pos: 0,\n            val: line[0]\n        });\n        for (let i = 0; i < line.length - 2; i++) {\n            const slope = (line[i + 1] - line[i]);\n            const slope2 = (line[i + 2] - line[i + 1]);\n            let dir: Slope;\n            if ((slope + slope2) < rThreshold && line[i + 1] < (center * 1.5)) {\n                dir = Slope.Down;\n            } else if ((slope + slope2) > threshold && line[i + 1] > (center * 0.5)) {\n                dir = Slope.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 (let 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 (let 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 (let j = extrema[i].pos; j < extrema[i + 1].pos; j++) {\n                line[j] = line[j] > threshold ? 0 : 1;\n            }\n        }\n\n        return {\n            ...result,\n            threshold\n        };\n    }\n};\n","import { getUserMedia, enumerateDevices } from '../common/media-devices';\n\nlet _stream: MediaStream;\n\nexport const CameraAccess = {\n    /**\n     * Attempts to attach the camera-stream to a given video element\n     * and calls the callback function when the content is ready\n     * @param video\n     * @param videoConstraints\n     */\n    async request(video: HTMLVideoElement, videoConstraints: MediaTrackConstraints): Promise<void> {\n        const normalizedConstraints = CameraAccess.pickConstraints(videoConstraints);\n        _stream = await getUserMedia(normalizedConstraints);\n        video.srcObject = _stream;\n        video.setAttribute('autoplay', '');\n        video.setAttribute('muted', '');\n        video.setAttribute('playsinline', '');\n\n        return new Promise(resolve => video.addEventListener('loadedmetadata', () => {\n            video.play();\n            resolve();\n        })).then(_waitForVideo.bind(null, video));\n    },\n\n    release(): void {\n        const tracks = _stream && _stream.getVideoTracks();\n        if (tracks && tracks.length) {\n            tracks[0].stop();\n        }\n        _stream = null;\n    },\n\n    async enumerateVideoDevices(): Promise<Array<MediaDeviceInfo>> {\n        const devices = await enumerateDevices();\n        return devices.filter(({ kind }) => kind === 'videoinput');\n    },\n\n    getActiveStreamLabel(): string {\n        const track = CameraAccess.getActiveTrack();\n        return track ? track.label : '';\n    },\n\n    getActiveTrack() {\n        const tracks = _stream && _stream.getVideoTracks();\n        if (tracks && tracks.length) {\n            return tracks[0];\n        }\n\n        return null;\n    },\n\n    pickConstraints(videoConstraints: MediaTrackConstraints): MediaStreamConstraints {\n        let { width, height, facingMode, aspectRatio, deviceId } = videoConstraints;\n        const { minAspectRatio, facing } = videoConstraints as any;\n\n        if (typeof minAspectRatio !== 'undefined' && minAspectRatio > 0) {\n            aspectRatio = minAspectRatio;\n            console.log(`WARNING: Constraint 'minAspectRatio' is deprecated; Use 'aspectRatio' instead`);\n        }\n\n        if (typeof facing !== 'undefined') {\n            facingMode = facing;\n            console.log(`WARNING: Constraint 'facing' is deprecated. Use 'facingMode' instead'`);\n        }\n\n        const normalizedConstraints = deviceId && facingMode ?\n            { width, height, aspectRatio, deviceId } : { width, height, facingMode, aspectRatio, deviceId };\n\n        return {\n            audio: false,\n            video: normalizedConstraints\n        };\n    }\n}\n\nfunction _waitForVideo({ videoWidth, videoHeight }): Promise<void> {\n    return new Promise((resolve, reject) => {\n        let attempts = 10;\n\n        function checkVideo() {\n            if (attempts > 0) {\n                if (videoWidth > 10 && videoHeight > 10) {\n                    if (process.env.NODE_ENV !== 'production') {\n                        console.log(`${videoWidth}px x ${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 * @borrows https://github.com/exif-js/exif-js\n */\n\nconst ExifTags = { 0x0112: 'orientation' };\nexport const AvailableTags: Array<string> = Object.keys(ExifTags).map(key => ExifTags[key]);\n\nexport interface Tags {\n    [key: string]: number | string;\n}\n\nexport async function findTagsInObjectURL(src: string, tags = AvailableTags): Promise<Tags> {\n    if (/^blob:/i.test(src)) {\n        const buffer = await objectURLToBlob(src);\n        return findTagsInBuffer(buffer, tags);\n    }\n    return Promise.resolve(null);\n}\n\nexport function findTagsInBuffer(file: ArrayBuffer, selectedTags: Array<string> = AvailableTags): Tags {\n    const dataView = new DataView(file);\n    const length = file.byteLength;\n    const exifTags = selectedTags.reduce((result, selectedTag) => {\n        const exifTag = Object.keys(ExifTags).find(tag => ExifTags[tag] === selectedTag);\n        if (exifTag) {\n            result[exifTag] = selectedTag;\n        }\n        return result;\n    }, {});\n    let offset = 2;\n\n    if ((dataView.getUint8(0) !== 0xFF) || (dataView.getUint8(1) !== 0xD8)) {\n        return null;\n    }\n\n    while (offset < length) {\n        if (dataView.getUint8(offset) !== 0xFF) {\n            return null;\n        }\n\n        const marker = dataView.getUint8(offset + 1);\n        if (marker === 0xE1) {\n            return readEXIFData(dataView, offset + 4, exifTags);\n        } else {\n            offset += 2 + dataView.getUint16(offset + 2);\n        }\n    }\n\n    return null;\n}\n\nasync function objectURLToBlob(url: string): Promise<ArrayBuffer> {\n    const response = await fetch(url);\n    if (response.ok) {\n        return response.arrayBuffer();\n    }\n\n    throw new Error('HTTP Error ' + response.status);\n}\n\nfunction readEXIFData(dataView: DataView, start: number, exifTags: { [key: number]: string }): Tags {\n    if ('Exif'.split('').some((char, index) => dataView.getUint8(start + index) !== char.charCodeAt(0))) {\n        return null;\n    }\n\n    const tiffOffset = start + 6;\n    let bigEnd: boolean;\n\n    if (dataView.getUint16(tiffOffset) === 0x4949) {\n        bigEnd = false;\n    } else if (dataView.getUint16(tiffOffset) === 0x4D4D) {\n        bigEnd = true;\n    } else {\n        return null;\n    }\n\n    if (dataView.getUint16(tiffOffset + 2, !bigEnd) !== 0x002A) {\n        return null;\n    }\n\n    const firstIFDOffset = dataView.getUint32(tiffOffset + 4, !bigEnd);\n    if (firstIFDOffset < 0x00000008) {\n        return null;\n    }\n\n    const tags = readTags(dataView, tiffOffset + firstIFDOffset, exifTags, bigEnd);\n    return tags;\n}\n\nfunction readTags(dataView: DataView, dirStart: number, strings: { [key: number]: string }, bigEnd: boolean): Tags {\n    const entries = dataView.getUint16(dirStart, !bigEnd);\n    const tags: Tags = {};\n\n    for (let i = 0; i < entries; i++) {\n        const entryOffset = dirStart + i * 12 + 2;\n        const tag = strings[dataView.getUint16(entryOffset, !bigEnd)];\n        if (tag) {\n            tags[tag] = readTagValue(dataView, entryOffset, bigEnd);\n        }\n    }\n\n    return tags;\n}\n\nfunction readTagValue(dataView: DataView, entryOffset: number, bigEnd: boolean): number | string {\n    const type = dataView.getUint16(entryOffset + 2, !bigEnd);\n    const numValues = dataView.getUint32(entryOffset + 4, !bigEnd);\n\n    return type === 3 && numValues === 1 ? dataView.getUint16(entryOffset + 8, !bigEnd) : undefined;\n}\n","import { Point } from '../common/point';\nimport { InputStream } from './input-stream';\nimport { InputStreamConfig } from './input-stream-config';\n\nconst QUATER_CIRCLE = Math.PI / 2;\n\nexport class FrameGrabber {\n    private _inputStream: InputStream;\n    private _streamConfig: InputStreamConfig;\n    private _canvas: HTMLCanvasElement;\n    private _context: CanvasRenderingContext2D;\n    private _data: Uint8Array;\n    private _canvasHeight: number;\n    private _canvasWidth: number;\n    private _height: number;\n    private _width: number;\n    private _topLeft: Point;\n\n    constructor(inputStream: InputStream, canvas: HTMLCanvasElement) {\n        this._inputStream = inputStream;\n        this._streamConfig = inputStream.config;\n        this._canvasWidth = inputStream.canvasWidth;\n        this._canvasHeight = inputStream.canvasHeight;\n        this._width = inputStream.width;\n        this._height = inputStream.height;\n        this._topLeft = inputStream.topLeft;\n        this._canvas = canvas || document.createElement('canvas');\n        this._canvas.width = this._canvasWidth;\n        this._canvas.height = this._canvasHeight;\n        this._context = this._canvas.getContext('2d');\n        this._data = new Uint8Array(this._width * this._height);\n\n        if (process.env.NODE_ENV !== 'production') {\n            console.log('FrameGrabber', JSON.stringify({\n                size: {\n                    x: this._width,\n                    y: this._height\n                },\n                topLeft: this._topLeft,\n                videoSize: {\n                    x: inputStream.realWidth,\n                    y: inputStream.realHeight\n                },\n                canvasSize: {\n                    x: this._canvasWidth,\n                    y: this._canvasHeight\n                }\n            }));\n        }\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    grab(data: Uint8Array): boolean {\n        this._data = data;\n        const frame = this._inputStream.getFrame();\n\n        if (frame) {\n            this._adjustCanvasSize();\n\n            let drawable: HTMLImageElement | HTMLVideoElement;\n            let drawAngle = 0;\n\n            if (frame instanceof HTMLVideoElement) {\n                drawable = frame;\n            } else {\n                drawable = frame.image;\n\n                if (frame.tags) {\n                    switch (frame.tags.orientation) {\n                        case 6: {\n                            drawAngle = QUATER_CIRCLE;\n                            break;\n                        }\n                        case 8: {\n                            drawAngle = -QUATER_CIRCLE;\n                            break;\n                        }\n                    }\n                }\n            }\n\n            if (drawAngle !== 0) {\n                const halfWidth = this._canvasWidth >> 1;\n                const halfHeight = this._canvasHeight >> 1;\n\n                this._context.translate(halfWidth, halfHeight);\n                this._context.rotate(drawAngle);\n                this._context.drawImage(drawable, -halfHeight, -halfWidth, this._canvasHeight, this._canvasWidth);\n                this._context.rotate(-drawAngle);\n                this._context.translate(-halfWidth, -halfHeight);\n            } else {\n                this._context.drawImage(drawable, 0, 0, this._canvasWidth, this._canvasHeight);\n            }\n\n            const imageData = this._context.getImageData(this._topLeft.x, this._topLeft.y, this._width, this._height).data;\n\n            if (this._streamConfig.halfSample) {\n                this._grayAndHalfSampleFromCanvasData(imageData);\n            } else {\n                this._computeGray(imageData);\n            }\n\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    private _adjustCanvasSize(): void {\n        if (this._canvas.height !== this._canvasHeight || this._canvas.width !== this._canvasWidth) {\n            if (process.env.NODE_ENV !== 'production') {\n                console.warn('Canvas size needs to be adjusted');\n            }\n            this._canvas.height = this._canvasHeight;\n            this._canvas.width = this._canvasWidth;\n        }\n    }\n\n    private _grayAndHalfSampleFromCanvasData(imageData: Uint8ClampedArray): void {\n        const endIndex = imageData.length >> 2;\n        const outWidth = this._width >> 1;\n        let topRowIndex = 0;\n        let bottomRowIndex = this._width;\n        let outImageIndex = 0;\n\n        while (bottomRowIndex < endIndex) {\n            for (let i = 0; i < outWidth; i++) {\n                const top4 = topRowIndex << 2;\n                const bottom4 = bottomRowIndex << 2;\n                this._data[outImageIndex] = (\n                    (0.299 * imageData[top4 + 0] + 0.587 * imageData[top4 + 1] + 0.114 * imageData[top4 + 2]) +\n                    (0.299 * imageData[top4 + 4] + 0.587 * imageData[top4 + 5] + 0.114 * imageData[top4 + 6]) +\n                    (0.299 * imageData[bottom4 + 0] + 0.587 * imageData[bottom4 + 1] + 0.114 * imageData[bottom4 + 2]) +\n                    (0.299 * imageData[bottom4 + 4] + 0.587 * imageData[bottom4 + 5] + 0.114 * imageData[bottom4 + 6])\n                ) / 4 | 0;\n                outImageIndex++;\n                topRowIndex += 2;\n                bottomRowIndex += 2;\n            }\n            topRowIndex += this._width;\n            bottomRowIndex += this._width;\n        }\n    }\n\n    private _computeGray(imageData: Uint8ClampedArray): void {\n        const imageDataLength = imageData.length;\n\n        if (this._streamConfig && this._streamConfig.singleChannel) {\n            for (let i = 0, j = 0; i < imageDataLength; i += 4, j++) {\n                this._data[j] = imageData[i];\n            }\n        } else {\n            for (let i = 0, j = 0; i < imageDataLength; i += 4, j++) {\n                this._data[j] = 0.299 * imageData[i] + 0.587 * imageData[i + 1] + 0.114 * imageData[i + 2] | 0;\n            }\n        }\n    }\n}\n","import { findTagsInObjectURL, Tags } from './exif-helper';\n\nexport interface ImageInfo {\n    image: HTMLImageElement;\n    tags?: Tags;\n}\n\nexport class ImageLoader {\n    static async load(\n        baseUri: string,\n        callback: (_: Array<ImageInfo>) => void,\n        offset: number,\n        size: number,\n        sequence: boolean\n    ): Promise<void> {\n        const imageSrcs = new Array<string>(size);\n        const loadedImages = new Array<ImageInfo>(size);\n        const notLoadedImages = new Array<HTMLImageElement>();\n\n        if (sequence === false) {\n            imageSrcs[0] = baseUri;\n        } else {\n            for (let i = 0; i < size; i++) {\n                imageSrcs[i] = `${baseUri}image-${('00' + (offset + i)).slice(-3)}.jpg`;\n            }\n        }\n\n        imageSrcs.forEach(src => {\n            const image = new Image();\n            notLoadedImages.push(image);\n            image.onload = () => loaded(image);\n            image.src = src;\n        });\n\n        async function loaded(loadedImage: HTMLImageElement): Promise<void> {\n            for (let x = 0; x < notLoadedImages.length; x++) {\n                if (notLoadedImages[x] === loadedImage) {\n                    notLoadedImages.splice(x, 1);\n                    // TODO: assume the index is the same\n                    for (let y = 0; y < imageSrcs.length; y++) {\n                        const imageName = imageSrcs[y].substr(imageSrcs[y].lastIndexOf('/'));\n                        if (loadedImage.src.lastIndexOf(imageName) !== -1) {\n                            loadedImages[y] = { image: loadedImage };\n                            break;\n                        }\n                    }\n                    break;\n                }\n            }\n            if (notLoadedImages.length === 0) {\n                if (process.env.NODE_ENV !== 'production') {\n                    console.log('Images loaded');\n                }\n                try {\n                    if (sequence === false) {\n                        const firstImage = loadedImages[0];\n                        firstImage.tags = await findTagsInObjectURL(baseUri);\n                    }\n                } catch (ex) {\n                    console.log(ex);\n                } finally {\n                    callback(loadedImages);\n                }\n            }\n        }\n    }\n}\n","import { ImageInfo, ImageLoader } from './image-loader';\nimport { InputStream } from './input-stream';\nimport { InputStreamConfig } from './input-stream-config';\n\nexport class ImageStream extends InputStream {\n    private _baseUrl: string;\n    private _ended: boolean;\n    private _frameIndex: number;\n    private _height: number;\n    private _images: Array<ImageInfo>;\n    private _loaded: boolean;\n    private _offset: number;\n    private _paused: boolean;\n    private _size: number;\n    private _width: number;\n\n    constructor() {\n        super();\n\n        this._canvasHeight = 0;\n        this._canvasWidth = 0;\n        this._baseUrl = null;\n        this._ended = false;\n        this._frameIndex = 0;\n        this._height = 0;\n        this._images = null;\n        this._loaded = false;\n        this._offset = 1;\n        this._paused = true;\n        this._size = 0;\n        this._width = 0;\n    }\n\n    get realHeight(): number {\n        return this._height;\n    }\n\n    get realWidth(): number {\n        return this._width;\n    }\n\n    get config(): InputStreamConfig {\n        return this._config;\n    }\n\n    set config(config: InputStreamConfig) {\n        this._config = { ...config };\n        this._baseUrl = config.src;\n        this._size = config.sequence && config.length ? config.length : 1;\n\n        this._loadImages();\n    }\n\n    get ended(): boolean {\n        return this._ended;\n    }\n\n    setAttribute() { }\n\n    pause(): void {\n        this._paused = true;\n    }\n\n    play(): void {\n        this._paused = false;\n    }\n\n    set currentTime(time: number) {\n        this._frameIndex = time;\n    }\n\n    getFrame(): HTMLVideoElement | ImageInfo {\n        let frame: ImageInfo = null;\n\n        if (this._loaded && !this._paused) {\n            frame = this._images[this._frameIndex];\n\n            if (this._frameIndex < (this._size - 1)) {\n                this._frameIndex++;\n            } else {\n                setTimeout(() => {\n                    this._ended = true;\n                    this.trigger('ended', []);\n                }, 0);\n            }\n        }\n\n        return frame;\n    }\n\n    private _loadImages(): void {\n        this._loaded = false;\n        ImageLoader.load(this._baseUrl, images => {\n            this._images = images;\n\n            switch (images[0].tags && images[0].tags.orientation) {\n                case 6:\n                case 8: {\n                    this._width = images[0].image.height;\n                    this._height = images[0].image.width;\n                    break;\n                }\n                default: {\n                    this._width = images[0].image.width;\n                    this._height = images[0].image.height;\n                }\n            }\n\n            this._canvasWidth = this._calculatedWidth = this._config.size ? this._width > this._height ?\n                this._config.size : this._width * this._config.size / this._height | 0 : this._width;\n            this._canvasHeight = this._calculatedHeight = this._config.size ? this._width > this._height ?\n                this._height * this._config.size / this._width | 0 : this._config.size : this._height;\n            this._loaded = true;\n            this._frameIndex = 0;\n            setTimeout(() => this.trigger('canrecord', []), 0);\n        }, this._offset, this._size, this._config.sequence);\n    }\n}\n","import { Point } from '../common/point';\nimport { BarcodeLocatorConfig, PatchSizeConfig } from '../locator/barcode-locator-config';\nimport { InputStream } from './input-stream';\nimport { AreaConfig } from './input-stream-config';\n\nexport interface Dimension {\n    unit: '%' | 'px',\n    value: number;\n}\n\nfunction _computeDivisors(n: number): Array<number> {\n    const divisors = new Array<number>();\n    const largeDivisors = new Array<number>();\n\n    for (let divisor = 1; divisor * divisor <= n; divisor++) {\n        if (n % divisor === 0) {\n            divisors.push(divisor);\n            if (divisor * divisor !== n) {\n                largeDivisors.unshift(n / divisor | 0);\n            }\n        }\n    }\n\n    return divisors.concat(largeDivisors);\n}\n\nfunction _computeCommonDivisors(m: number, n: number): Array<number> {\n    if (m === n) {\n        return _computeDivisors(m);\n    }\n\n    const max = m > n ? m : n;\n    const min = m > n ? n : m;\n    const divisors = new Array<number>();\n    const largeDivisors = new Array<number>();\n\n    for (let divisor = 1; divisor * divisor <= min; divisor++) {\n        if (max % divisor === 0 && min % divisor === 0) {\n            divisors.push(divisor);\n            const largeDivisor = min / divisor | 0;\n            if (divisor !== largeDivisor && max % largeDivisor === 0) {\n                largeDivisors.unshift();\n            }\n        }\n    }\n\n    return divisors.concat(largeDivisors);\n}\n\nexport function calculatePatchSize(patchSize: PatchSizeConfig, { x, y }: Point): Point {\n    const wideSide = Math.max(x | 0, y | 0) | 0;\n    const nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80];\n    const nrOfPatchesMap = {\n        'x-small': 5,\n        small: 4,\n        medium: 3,\n        large: 2,\n        'x-large': 1\n    };\n    const nrOfPatchesIndex = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium | 0;\n    const nrOfPatches = nrOfPatchesList[nrOfPatchesIndex] | 0;\n    const desiredPatchSize = wideSide / nrOfPatches | 0;\n\n    function findPatchSizeForDivisors(divisors: Array<number>): Point {\n        let i = 0;\n        let found = divisors[divisors.length >> 1] | 0;\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] | 0;\n            } else {\n                found = divisors[i] | 0;\n            }\n        }\n        if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIndex + 1] / nrOfPatchesList[nrOfPatchesIndex] &&\n            desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIndex - 1] / nrOfPatchesList[nrOfPatchesIndex]) {\n            return { x: found, y: found };\n        }\n        return null;\n    }\n\n    const optimalPatchSize = findPatchSizeForDivisors(_computeCommonDivisors(x, y)) ||\n        findPatchSizeForDivisors(_computeDivisors(wideSide)) ||\n        findPatchSizeForDivisors(_computeDivisors(desiredPatchSize * nrOfPatches));\n\n    return optimalPatchSize;\n}\n\nexport function checkImageConstraints(inputStream: InputStream, config: BarcodeLocatorConfig) {\n    let width = inputStream.width;\n    let height = inputStream.height;\n    const shift = config.halfSample ? 1 : 0 | 0;\n    const inputStreamConfig = inputStream.config;\n\n    // calculate width and height based on area\n    if (inputStreamConfig && inputStreamConfig.area) {\n        const area = computeImageArea(width, height, inputStreamConfig.area);\n        inputStream.topLeft = area.topLeft;\n        inputStream.setCanvasSize(width, height);\n        width = area.width;\n        height = area.height;\n    }\n\n    const size = {\n        x: width >> shift,\n        y: height >> shift\n    };\n\n    const patchSize = calculatePatchSize(config.patchSize, size);\n    if (process.env.NODE_ENV !== 'production') {\n        console.log('Patch-Size:', JSON.stringify(patchSize));\n    }\n\n    inputStream.width = (size.x / patchSize.x << shift) * patchSize.x | 0;\n    inputStream.height = (size.y / patchSize.y << shift) * patchSize.y | 0;\n\n    if ((inputStream.width % patchSize.x) === 0 && (inputStream.height % patchSize.y) === 0) {\n        return true;\n    }\n\n    // eslint-disable-next-line max-len\n    throw new Error(`Image dimensions do not comply with the current settings: width (${width}) and height (${height}) must be a multiple of ${patchSize.x}`);\n}\n\nexport function _parseCssDimensionValues(value: string): Dimension {\n    const dimension: Dimension = {\n        value: parseFloat(value),\n        unit: value.indexOf('%') === value.length - 1 ? '%' : value.indexOf('px') === value.length - 2 ? 'px' : '%'\n    };\n\n    return dimension;\n}\n\nexport const _dimensionsConverters = {\n    bottom: (dimension: Dimension, { height }) => dimension.unit === '%' ?\n        height - height * dimension.value / 100 | 0 : dimension.unit === 'px' ? height - dimension.value : height,\n    left: (dimension: Dimension, { width }) => dimension.unit === '%' ?\n        width * dimension.value / 100 | 0 : dimension.unit === 'px' ? dimension.value : 0,\n    right: (dimension: Dimension, { width }) => dimension.unit === '%' ?\n        width - width * dimension.value / 100 | 0 : dimension.unit === 'px' ? width - dimension.value : width,\n    top: (dimension: Dimension, { height }): number => dimension.unit === '%' ?\n        height * dimension.value / 100 | 0 : dimension.unit === 'px' ? dimension.value : 0\n};\n\nexport function computeImageArea(inputWidth: number, inputHeight: number, area: AreaConfig) {\n    const context = { width: inputWidth, height: inputHeight };\n    const parsedArea: {\n        bottom?: number;\n        left?: number;\n        right?: number;\n        top?: number;\n    } = Object.keys(area).reduce((result, key) => {\n        const value = area[key];\n        const parsed = _parseCssDimensionValues(value);\n        const calculated = _dimensionsConverters[key](parsed, context);\n\n        result[key] = calculated;\n        return result;\n    }, {});\n\n    return {\n        topLeft: { x: parsedArea.left, y: parsedArea.top },\n        width: parsedArea.right - parsedArea.left,\n        height: parsedArea.bottom - parsedArea.top\n    };\n}\n","import { Point } from '../common/point';\nimport { ImageInfo } from './image-loader';\nimport { InputStreamConfig } from './input-stream-config';\n\nexport abstract class InputStream {\n    protected _calculatedHeight: number;\n    protected _calculatedWidth: number;\n    protected _canvasHeight: number;\n    protected _canvasWidth: number;\n    protected _config: InputStreamConfig;\n    protected _eventNames: Array<string>;\n    protected _eventHandlers: Map<string, Array<EventListener>>;\n    protected _topLeft: Point;\n\n    constructor() {\n        this._canvasWidth = 0;\n        this._canvasHeight = 0;\n        this._config = null;\n        this._eventNames = ['canrecord', 'ended'];\n        this._eventHandlers = new Map<string, Array<EventListener>>();\n        this._topLeft = { x: 0, y: 0 };\n    }\n\n    abstract get realHeight(): number;\n\n    abstract get realWidth(): number;\n\n    get height(): number {\n        return this._calculatedHeight;\n    }\n\n    set height(height: number) {\n        this._calculatedHeight = height;\n    }\n\n    get width(): number {\n        return this._calculatedWidth;\n    }\n\n    set width(width: number) {\n        this._calculatedWidth = width;\n    }\n\n    get topLeft(): Point {\n        return { ...this._topLeft };\n    }\n\n    set topLeft(topLeft: Point) {\n        this._topLeft.x = topLeft.x;\n        this._topLeft.y = topLeft.y;\n    }\n\n    setCanvasSize(width: number, height: number): void {\n        this._canvasWidth = width;\n        this._canvasHeight = height;\n    }\n\n    get canvasHeight(): number {\n        return this._canvasHeight;\n    }\n\n    get canvasWidth(): number {\n        return this._canvasWidth;\n    }\n\n    abstract get config(): InputStreamConfig;\n\n    abstract set config(config: InputStreamConfig);\n\n    abstract get ended(): boolean;\n\n    abstract setAttribute(name: string, value: string): void;\n\n    abstract pause(): void;\n\n    abstract play(): void;\n\n    abstract set currentTime(time: number);\n\n    addEventListener(event: string, listener: EventListener, _options?: boolean): void {\n        if (this._eventNames.indexOf(event) !== -1) {\n            if (!this._eventHandlers.has(event)) {\n                this._eventHandlers.set(event, new Array<EventListener>());\n            }\n            this._eventHandlers.get(event).push(listener);\n        }\n    }\n\n    clearEventHandlers(): void {\n        this._eventHandlers.clear();\n    }\n\n    trigger(eventName: string, argArray?: any) {\n        const handlers = this._eventHandlers.get(eventName);\n\n        if (handlers) {\n            handlers.forEach(handler => handler.apply(this, argArray));\n        }\n    }\n\n    abstract getFrame(): HTMLVideoElement | ImageInfo;\n}\n","import { VideoStream } from './video-stream';\n\nexport class LiveStream extends VideoStream {\n    constructor(video: HTMLVideoElement) {\n        video.setAttribute('autoplay', '');\n        super(video);\n    }\n\n    get ended(): boolean {\n        return false;\n    }\n}\n","import { ImageInfo } from './image-loader';\nimport { InputStream } from './input-stream';\nimport { InputStreamConfig } from './input-stream-config';\n\nexport class VideoStream extends InputStream {\n    private _video: HTMLVideoElement;\n\n    constructor(video: HTMLVideoElement) {\n        super();\n\n        this._video = video;\n    }\n\n    get realHeight(): number {\n        return this._video.videoHeight;\n    }\n\n    get realWidth(): number {\n        return this._video.videoWidth;\n    }\n\n    get config(): InputStreamConfig {\n        return this._config;\n    }\n\n    set config(config: InputStreamConfig) {\n        this._config = { ...config };\n        this._video.src = config.src || '';\n    }\n\n    get ended(): boolean {\n        return this._video.ended;\n    }\n\n    setAttribute(name: string, value: string): void {\n        this._video.setAttribute(name, value);\n    }\n\n    pause(): void {\n        this._video.pause();\n    }\n\n    play(): void {\n        this._video.play();\n    }\n\n    set currentTime(time: number) {\n        if (this._config.type !== 'LiveStream') {\n            this._video.currentTime = time;\n        }\n    }\n\n    addEventListener(event: string, listener: EventListener, options?: boolean): void {\n        super.addEventListener(event, listener, options);\n\n        if (this._eventNames.indexOf(event) === -1) {\n            this._video.addEventListener(event, listener, options);\n        }\n    }\n\n    clearEventHandlers(): void {\n        // TODO: come up with a way to remove video event handlers\n        // this._eventNames.forEach(eventName => {\n        //     const handlers = this._eventHandlers.get(eventName);\n        //     if (handlers && handlers.length > 0) {\n        //         handlers.forEach(handler => this._video.removeEventListener(eventName, handler));\n        //     }\n        // });\n        super.clearEventHandlers();\n    }\n\n    trigger(eventName: string, argArray?: any) {\n        if (eventName === 'canrecord') {\n            this._initSize();\n        }\n\n        super.trigger(eventName, argArray)\n    }\n\n    getFrame(): HTMLVideoElement | ImageInfo {\n        return this._video;\n    }\n\n    private _initSize() {\n        const width = this._video.videoWidth;\n        const height = this._video.videoHeight;\n\n        this._canvasWidth = this._calculatedWidth =\n            this._config.size ? width > height ? this._config.size : width * this._config.size / height | 0 : width;\n        this._canvasHeight = this._calculatedHeight =\n            this._config.size ? width > height ? height * this._config.size / width | 0 : this._config.size : height;\n    }\n}\n\nexport class LiveStream extends VideoStream {\n    constructor(video: HTMLVideoElement) {\n        video.setAttribute('autoplay', '');\n        super(video);\n    }\n\n    get ended(): boolean {\n        return false;\n    }\n}\n","import { ImageWrapper } from '../common/image-wrapper';\nimport { Point } from '../common/point';\n\n/**\n * Invert matrix\n * @param matrix the matrix to invert\n * @returns the inverted matrix\n */\nexport function invert(matrix: Float32Array): Float32Array {\n    const a0 = matrix[0];\n    const a1 = matrix[1];\n    const a2 = matrix[2];\n    const a3 = matrix[3];\n    const determinant = a0 * a3 - a2 * a1;\n\n    if (!determinant) {\n        return null;\n    }\n\n    return new Float32Array([a3 / determinant, -a1 / determinant, -a2 / determinant, a0 / determinant]);\n}\n\n/**\n * Transforms the vector with a matrix\n * @param { x, y } vector to transform\n * @param matrix matrix to transform with\n * @returns the transformed vector\n */\nexport function transformWithMatrix({ x, y }: Point, matrix: Float32Array): Point {\n    return {\n        x: matrix[0] * x + matrix[2] * y,\n        y: matrix[1] * x + matrix[3] * y\n    };\n}\n\nfunction _computeHistogram(imageWrapper: ImageWrapper, bitsPerPixel: number): Int32Array {\n    if (!bitsPerPixel) {\n        bitsPerPixel = 8;\n    }\n\n    const imageData = imageWrapper.data;\n    const bitShift = 8 - bitsPerPixel;\n    const bucketCount = 1 << bitsPerPixel;\n    const histogram = new Int32Array(bucketCount);\n\n    for (let i = imageData.length; i--;) {\n        histogram[imageData[i] >> bitShift]++;\n    }\n\n    return histogram;\n}\n\nfunction _determineOtsuThreshold(imageWrapper: ImageWrapper, bitsPerPixel?: number): number {\n    if (!bitsPerPixel) {\n        bitsPerPixel = 8;\n    }\n\n    const bitShift = 8 - bitsPerPixel;\n    const hist = _computeHistogram(imageWrapper, bitsPerPixel);\n    const vet = [0];\n    const max = (1 << bitsPerPixel) - 1;\n\n    function px(init: number, end: number): number {\n        let sum = 0;\n\n        for (let i = init; i <= end; i++) {\n            sum += hist[i];\n        }\n\n        return sum;\n    }\n\n    function mx(init: number, end: number): number {\n        let sum = 0;\n\n        for (let i = init; i <= end; i++) {\n            sum += i * hist[i];\n        }\n\n        return sum;\n    }\n\n    for (let k = 1; k < max; k++) {\n        const p1 = px(0, k);\n        const p2 = px(k + 1, max);\n        const p12 = p1 * p2 || 1;\n        const m1 = mx(0, k) * p2;\n        const m2 = mx(k + 1, max) * p1;\n        const m12 = m1 - m2;\n        vet[k] = m12 * m12 / p12;\n    }\n\n    // index of max element\n    const threshold = vet.reduce((maxIndex, item, index, array) => item > array[maxIndex] ? index : maxIndex, 0);\n\n    return threshold << bitShift;\n}\n\nexport function otsuThreshold(imageWrapper: ImageWrapper, targetWrapper: ImageWrapper): number {\n    const threshold = _determineOtsuThreshold(imageWrapper);\n    const targetData = targetWrapper.data;\n\n    imageWrapper.data.forEach((value, index) => {\n        targetData[index] = value < threshold ? 1 : 0;\n    });\n\n    return threshold;\n}\n\n/**\n * @param imageWrapper input image to be sampled\n * @param outImageWrapper {ImageWrapper} to be stored in\n */\nexport function halfSample(imageWrapper: ImageWrapper, outImageWrapper: ImageWrapper): void {\n    const image = imageWrapper.data;\n    const width = imageWrapper.size.x;\n    const outImage = outImageWrapper.data;\n    const endIndex = image.length;\n    const outWidth = width >> 1;\n    let topRowIndex = 0;\n    let bottomRowIndex = width;\n    let outImgIndex = 0;\n\n    while (bottomRowIndex < endIndex) {\n        for (let i = 0; i < outWidth; i++) {\n            outImage[outImgIndex] =\n                (image[topRowIndex] + image[topRowIndex + 1] + image[bottomRowIndex] + image[bottomRowIndex + 1]) >> 2;\n            outImgIndex++;\n            topRowIndex += 2;\n            bottomRowIndex += 2;\n        }\n        topRowIndex += width;\n        bottomRowIndex += width;\n    }\n}\n","import { Box } from '../common/box';\nimport { Cluster } from '../common/cluster';\nimport { HSV, hsv2rgb, RGB } from '../common/hsv2rgb';\nimport { ImageDebug } from '../common/image-debug';\nimport { ImageWrapper } from '../common/image-wrapper';\nimport { Moment } from '../common/moment';\nimport { Point } from '../common/point';\nimport { calculatePatchSize } from '../input/input-stream-utils';\nimport { BarcodeLocatorConfig } from './barcode-locator-config';\nimport { halfSample, invert, otsuThreshold, transformWithMatrix } from './barcode-locator-utils';\nimport { Rasterizer } from './rasterizer';\nimport skeletonizer from './skeletonizer';\nimport { SearchDirections } from './tracer';\n\ninterface Patch {\n    box: Box;\n    index: number;\n    moments: Array<Moment>;\n    pos: Point;\n    rad: number;\n    x: number;\n    y: number;\n}\n\ntype Sceletonizer = any;\n\nconst MomentSimilarityThreshold = 0.9;\n\nexport class BarcodeLocator {\n    private _config: BarcodeLocatorConfig;\n    private _inputImageWrapper: ImageWrapper;\n    private _currentImageWrapper: ImageWrapper;\n    private _skelImageWrapper: ImageWrapper;\n    private _subImageWrapper: ImageWrapper;\n    private _labelImageWrapper: ImageWrapper<Array<number>>;\n    private _binaryImageWrapper: ImageWrapper;\n    private _patchGrid: ImageWrapper;\n    private _patchLabelGrid: ImageWrapper<Int32Array>;\n    private _imageToPatchGrid: Array<Patch>;\n    private _patchSize: Point;\n    private _binaryContext: CanvasRenderingContext2D;\n    private _numPatches: Point;\n    private _skeletonizer: Sceletonizer;\n\n    constructor(inputImageWrapper: ImageWrapper, config: BarcodeLocatorConfig) {\n        this._config = config;\n        this._inputImageWrapper = inputImageWrapper;\n        this._numPatches = { x: 0, y: 0 };\n\n        this._initBuffers();\n        this._initCanvas();\n    }\n\n    locate() {\n        if (this._config.halfSample) {\n            halfSample(this._inputImageWrapper, this._currentImageWrapper);\n        }\n\n        this._binarizeImage();\n        const patchesFound = this._findPatches();\n        // return unless 5% or more patches are found\n        if (patchesFound.length < this._numPatches.x * this._numPatches.y * 0.05) {\n            return null;\n        }\n\n        // rasterize area by comparing angular similarity;\n        const maxLabel = this._rasterizeAngularSimilarity(patchesFound);\n        if (maxLabel < 1) {\n            return null;\n        }\n\n        // search for area with the most patches (biggest connected area)\n        const topLabels = this._findBiggestConnectedAreas(maxLabel);\n        if (topLabels.length === 0) {\n            return null;\n        }\n\n        const boxes = this._findBoxes(topLabels, maxLabel);\n        return boxes;\n    }\n\n    private _initBuffers(): void {\n        if (this._config.halfSample) {\n            this._currentImageWrapper = new ImageWrapper({\n                x: this._inputImageWrapper.size.x / 2 | 0,\n                y: this._inputImageWrapper.size.y / 2 | 0\n            });\n        } else {\n            this._currentImageWrapper = this._inputImageWrapper;\n        }\n\n        this._patchSize = calculatePatchSize(this._config.patchSize, this._currentImageWrapper.size);\n\n        this._numPatches.x = this._currentImageWrapper.size.x / this._patchSize.x | 0;\n        this._numPatches.y = this._currentImageWrapper.size.y / this._patchSize.y | 0;\n\n        this._binaryImageWrapper = new ImageWrapper(this._currentImageWrapper.size, undefined, Uint8Array, false);\n\n        this._labelImageWrapper = new ImageWrapper(this._patchSize, undefined, Array, true);\n\n        const skeletonImageData = new ArrayBuffer(64 * 1024);\n        this._subImageWrapper = new ImageWrapper(this._patchSize, new Uint8Array(skeletonImageData, 0, this._patchSize.x * this._patchSize.y));\n        this._skelImageWrapper = new ImageWrapper(this._patchSize,\n            new Uint8Array(skeletonImageData, this._patchSize.x * this._patchSize.y * 3, this._patchSize.x * this._patchSize.y),\n            undefined, true);\n        this._skeletonizer = skeletonizer(\n            (typeof window !== 'undefined') ? window : (typeof self !== 'undefined') ? self : global,\n            { size: this._patchSize.x },\n            skeletonImageData\n        );\n\n        const size = {\n            x: (this._currentImageWrapper.size.x / this._subImageWrapper.size.x) | 0,\n            y: (this._currentImageWrapper.size.y / this._subImageWrapper.size.y) | 0\n        };\n        this._patchLabelGrid = new ImageWrapper(size, undefined, Int32Array, true);\n        this._patchGrid = new ImageWrapper(size, undefined, undefined, true);\n        this._imageToPatchGrid = new Array<Patch>(this._patchLabelGrid.data.length);\n    }\n\n    private _initCanvas() {\n        if (this._config.useWorker || typeof document === 'undefined') {\n            return;\n        }\n\n        const canvas = document.createElement('canvas');\n        canvas.className = 'binaryBuffer';\n        canvas.width = this._binaryImageWrapper.size.x;\n        canvas.height = this._binaryImageWrapper.size.y;\n        if (process.env.NODE_ENV !== 'production' && this._config.debug && this._config.debug.showCanvas) {\n            document.querySelector('#debug').appendChild(canvas);\n        }\n        this._binaryContext = canvas.getContext('2d');\n    }\n\n    /**\n     * Creates a bounding box which encloses all the given patches\n     * @returns The minimal bounding box\n     */\n    private _boxFromPatches(patches: Array<Patch>): Box {\n        const debug = process.env.NODE_ENV !== 'production' && this._config.debug;\n        let averageRad = patches.reduce((sum, { pos, rad }) => {\n            if (debug && debug.showPatches) {\n                // draw all patches which are to be taken into consideration\n                this._drawRect(pos, this._subImageWrapper.size, 'red', 1);\n            }\n\n            return sum + rad;\n        }, 0) / patches.length;\n\n        averageRad = (averageRad * 180 / Math.PI + 90) % 180 - 90;\n        if (averageRad < 0) {\n            averageRad += 180;\n        }\n        averageRad = (180 - averageRad) * Math.PI / 180;\n\n        const cos = Math.cos(averageRad);\n        const sin = Math.sin(averageRad);\n        const matrix = new Float32Array([cos, sin, -sin, cos]);\n        const inverseMatrix = invert(matrix);\n\n        // iterate over patches and rotate by angle\n        patches.forEach(({ box }) => {\n            for (let j = 0; j < 4; j++) {\n                box[j] = transformWithMatrix(box[j], matrix);\n            }\n\n            if (debug && debug.boxFromPatches.showTransformed) {\n                this._drawPath(box, '#99ff00', 2);\n            }\n        });\n\n        let minX = this._binaryImageWrapper.size.x;\n        let minY = this._binaryImageWrapper.size.y;\n        let maxX = -minX;\n        let maxY = -minY;\n\n        // find bounding box\n        patches.forEach(({ box }) => {\n            box.forEach(({ x, y }) => {\n                if (x < minX) {\n                    minX = x;\n                }\n                if (x > maxX) {\n                    maxX = x;\n                }\n                if (y < minY) {\n                    minY = y;\n                }\n                if (y > maxY) {\n                    maxY = y;\n                }\n            });\n        });\n\n        let box: Box = [{ x: minX, y: minY }, { x: maxX, y: minY }, { x: maxX, y: maxY }, { x: minX, y: maxY }];\n\n        if (debug && debug.boxFromPatches.showTransformedBox) {\n            this._drawPath(box, '#ff0000', 2);\n        }\n\n        // reverse rotation\n        box = box.map(vertex => transformWithMatrix(vertex, inverseMatrix)) as Box;\n\n        if (debug && debug.boxFromPatches.showBB) {\n            this._drawPath(box, '#ff0000', 2);\n        }\n\n        if (this._config.halfSample) {\n            // scale\n            box = box.map(({ x, y }) => ({ x: x * 2, y: y *= 2 })) as Box;\n        }\n\n        return box;\n    }\n\n    /**\n     * Creates a binary image of the current image\n     */\n    private _binarizeImage(): void {\n        otsuThreshold(this._currentImageWrapper, this._binaryImageWrapper);\n        this._binaryImageWrapper.zeroBorder();\n\n        if (process.env.NODE_ENV !== 'production' && this._config.debug && this._config.debug.showCanvas) {\n            this._binaryImageWrapper.show(this._binaryContext, 255);\n        }\n    }\n\n    /**\n     * Iterate over the entire image, extract patches\n     */\n    private _findPatches(): Array<Patch> {\n        const debug = process.env.NODE_ENV !== 'production' && this._config.debug;\n        let patchesFound = new Array<Patch>();\n\n        for (let i = 0; i < this._numPatches.x; i++) {\n            for (let j = 0; j < this._numPatches.y; j++) {\n                const x = this._subImageWrapper.size.x * i;\n                const y = this._subImageWrapper.size.y * j;\n\n                // seperate parts\n                this._skeletonize(x, y);\n\n                // Rasterize, find individual bars\n                this._skelImageWrapper.zeroBorder();\n                this._labelImageWrapper.data.fill(0);\n                const rasterizer = new Rasterizer(this._skelImageWrapper, this._labelImageWrapper);\n                const rasterResult = rasterizer.rasterize(0);\n\n                if (debug && debug.showLabels) {\n                    this._labelImageWrapper.overlay(this._binaryContext, 360 / rasterResult.count | 0, x, y);\n                }\n\n                // calculate moments from the skeletonized patch\n                const moments = this._labelImageWrapper.moments(rasterResult.count);\n\n                // extract eligible patches\n                const patch = this._describePatch(moments, j * this._numPatches.x + i, x, y);\n                if (patch) {\n                    patchesFound.push(patch);\n\n                    if (debug && debug.showFoundPatches) {\n                        this._drawRect(patch.pos, this._subImageWrapper.size, '#99ff00', 2);\n                    }\n                }\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 maxLabel\n     */\n    private _findBiggestConnectedAreas(maxLabel: number): Array<number> {\n        let labelHist = new Array<number>(maxLabel).fill(0);\n\n        this._patchLabelGrid.data.forEach((data: number) => {\n            if (data > 0) {\n                labelHist[data - 1]++;\n            }\n        });\n\n        // extract top areas with at least 6 patches present\n        const topLabels = labelHist.map((value, index) => ({ value, index }))\n            .filter(({ value }) => value >= 5).sort((a, b) => b.value - a.value).map(({ index }) => index + 1);\n\n        return topLabels;\n    }\n\n    /**\n     *\n     */\n    private _findBoxes(topLabels: Array<number>, maxLabel: number): Array<Box> {\n        const boxes = new Array<Box>();\n        const showRemainingPatchLabels = process.env.NODE_ENV !== 'production' &&\n            this._config.debug && this._config.debug.showRemainingPatchLabels;\n\n        topLabels.forEach(label => {\n            const patches = new Array<Patch>();\n\n            this._patchLabelGrid.data.forEach((data: number, index: number) => {\n                if (data === label) {\n                    patches.push(this._imageToPatchGrid[index]);\n                }\n            });\n\n            const box = this._boxFromPatches(patches);\n\n            if (box) {\n                boxes.push(box);\n\n                if (showRemainingPatchLabels) {\n                    // draw patch-labels if requested\n                    const hsv: HSV = [(label / (maxLabel + 1)) * 360, 1, 1];\n                    const rgb: RGB = [0, 0, 0];\n                    hsv2rgb(hsv, rgb);\n\n                    const color = `rgb(${rgb.join(',')})`;\n\n                    patches.forEach(({ pos }) => this._drawRect(pos, this._subImageWrapper.size, color, 2));\n                }\n            }\n        });\n\n        return boxes;\n    }\n\n    /**\n     * Find similar moments (via cluster)\n     * @param moments\n     */\n    private _similarMoments(moments: Array<Moment>): Array<Moment> {\n        const clusters = Cluster.clusterize(moments, MomentSimilarityThreshold);\n        const topCluster = clusters.reduce((top, item) => {\n            const count = item.moments.length;\n            return count > top.count ? { item, count } : top;\n        }, { item: { moments: [] }, count: 0 });\n        const result = topCluster.item.moments;\n\n        return result;\n    }\n\n    private _skeletonize(x: number, y: number): void {\n        this._binaryImageWrapper.subImageAsCopy(this._subImageWrapper, x, y);\n        this._skeletonizer.skeletonize();\n\n        // Show skeleton if requested\n        if (process.env.NODE_ENV !== 'production' && this._config.debug && this._config.debug.showSkeleton) {\n            this._skelImageWrapper.overlay(this._binaryContext, 360, x, y);\n        }\n    }\n\n    /**\n     * Extracts and describes those patches which seem to contain a barcode pattern\n     * @param moments\n     * @param index\n     * @param x\n     * @param y\n     * @returns list of patches\n     */\n    private _describePatch(moments: Array<Moment>, index: number, x: number, y: number): Patch {\n        if (moments.length > 1) {\n            const minComponentWeight = Math.ceil(this._patchSize.x / 3);\n            // only collect moments which area covers at least minComponentWeight pixels\n            const eligibleMoments = moments.filter(moment => moment.m00 > minComponentWeight);\n\n            // if at least 2 moments are found which have at least minComponentWeights covered\n            if (eligibleMoments.length > 1) {\n                const matchingMoments = this._similarMoments(eligibleMoments);\n                const length = matchingMoments.length | 0;\n\n                // Only two of the moments are allowed not to fit into the equation\n                if (length > 1 && (length << 2) >= eligibleMoments.length * 3 && (length << 2) > moments.length) {\n                    // determine the similarity of the moments\n                    const rad = matchingMoments.reduce((sum: number, moment: Moment) => sum + moment.rad, 0) / length;\n\n                    return {\n                        index,\n                        pos: { x, y },\n                        box: [\n                            { x, y },\n                            { x: x + this._subImageWrapper.size.x, y },\n                            { x: x + this._subImageWrapper.size.x, y: y + this._subImageWrapper.size.y },\n                            { x, y: y + this._subImageWrapper.size.y }\n                        ],\n                        moments: matchingMoments,\n                        rad,\n                        x: Math.cos(rad),\n                        y: Math.sin(rad)\n                    };\n                }\n            }\n        }\n\n        return null;\n    }\n\n    private _notYetProcessed(): number {\n        for (let i = 0; i < this._patchLabelGrid.data.length; i++) {\n            if (this._patchLabelGrid.data[i] === 0 && this._patchGrid.data[i] === 1) {\n                return i;\n            }\n        }\n        return this._patchLabelGrid.data.length;\n    }\n\n    private _trace(currentIndex: number, label: number): void {\n        const threshold = 0.95;\n        const current: Point = {\n            x: currentIndex % this._patchLabelGrid.size.x,\n            y: (currentIndex / this._patchLabelGrid.size.x) | 0\n        };\n\n        if (currentIndex < this._patchLabelGrid.data.length) {\n            const currentPatch = this._imageToPatchGrid[currentIndex];\n            // assign label\n            this._patchLabelGrid.data[currentIndex] = label;\n\n            SearchDirections.forEach(direction => {\n                const y = current.y + direction[0];\n                const x = current.x + direction[1];\n                const index = y * this._patchLabelGrid.size.x + x;\n\n                // continue if patch empty\n                if (this._patchGrid.data[index] === 0) {\n                    this._patchLabelGrid.data[index] = Number.MAX_VALUE;\n                } else if (this._patchLabelGrid.data[index] === 0) {\n                    const patch = this._imageToPatchGrid[index];\n                    const similarity = Math.abs(patch.x * currentPatch.x + patch.y * currentPatch.y);\n                    if (similarity > threshold) {\n                        this._trace(index, label);\n                    }\n                }\n            });\n        }\n    }\n\n    /**\n     * Finds patches which are connected and share the same orientation\n     * @param patchesFound\n     */\n    private _rasterizeAngularSimilarity(patchesFound: Array<Patch>): number {\n        let label = 0;\n        const hsv: HSV = [0, 1, 1];\n        const rgb: RGB = [0, 0, 0];\n\n        // prepare for finding the right patches\n        this._patchGrid.data.fill(0);\n        this._patchLabelGrid.data.fill(0);\n        this._imageToPatchGrid.fill(null);\n\n        patchesFound.forEach(patch => {\n            this._imageToPatchGrid[patch.index] = patch;\n            this._patchGrid.data[patch.index] = 1;\n        });\n\n        // rasterize the patches found to determine area\n        this._patchGrid.zeroBorder();\n\n        let currentIndex = 0;\n        while ((currentIndex = this._notYetProcessed()) < this._patchLabelGrid.data.length) {\n            label++;\n            this._trace(currentIndex, label);\n        }\n\n        // draw patch-labels if requested\n        if (process.env.NODE_ENV !== 'production' && this._config.debug && this._config.debug.showPatchLabels) {\n            for (let j = 0; j < this._patchLabelGrid.data.length; j++) {\n                if (this._patchLabelGrid.data[j] > 0 && this._patchLabelGrid.data[j] <= label) {\n                    const patch = this._imageToPatchGrid[j];\n                    hsv[0] = (this._patchLabelGrid.data[j] / (label + 1)) * 360;\n                    hsv2rgb(hsv, rgb);\n                    this._drawRect(patch.pos, this._subImageWrapper.size, `rgb(${rgb.join(',')})`, 2);\n                }\n            }\n        }\n\n        return label;\n    }\n\n    private _drawRect({ x, y }: Point, size: Point, color: string, lineWidth: number): void {\n        this._binaryContext.strokeStyle = color;\n        this._binaryContext.fillStyle = color;\n        this._binaryContext.lineWidth = lineWidth || 1;\n        this._binaryContext.strokeRect(x, y, size.x, size.y);\n    }\n\n    private _drawPath(path: Array<Point>, color: string, lineWidth: number): void {\n        ImageDebug.drawPath(path, this._binaryContext, color, lineWidth);\n    }\n}\n","/**\n * @borrows http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\n */\n\nimport { ImageWrapper } from '../common/image-wrapper';\nimport { ContourVertex, Tracer } from './tracer';\n\nenum EdgeLabel {\n    Outside = -32767,\n    Inside = -32766\n};\n\nenum ContourDirection {\n    CW = 0,\n    CCW = 1,\n    Unknown = 2\n};\n\ninterface Contour {\n    dir: ContourDirection;\n    index: number;\n    firstVertex: ContourVertex;\n    previousPeer?: Contour;\n    nextPeer?: Contour;\n    insideContours: Contour;\n}\n\nexport interface RasterResult {\n    cc: Contour;\n    count: number;\n}\n\nexport class Rasterizer {\n    private _width: number;\n    private _height: number;\n    private _tracer: Tracer;\n    private _imageData: Uint8Array;\n    private _labelData: Array<number>;\n\n    constructor(imageWrapper: ImageWrapper<Uint8Array>, labelWrapper: ImageWrapper<Array<number>>) {\n        this._imageData = imageWrapper.data;\n        this._labelData = labelWrapper.data as Array<number>;\n        this._width = imageWrapper.size.x;\n        this._height = imageWrapper.size.y;\n        this._tracer = new Tracer(imageWrapper, labelWrapper);\n    }\n\n    rasterize(depthLabel: number): RasterResult {\n        const colorMap = new Array<number>();\n\n        for (let i = 0; i < 400; i++) {\n            colorMap[i] = 0;\n        }\n\n        colorMap[0] = this._imageData[0];\n\n        let cc: Contour = null;\n        let sc: Contour;\n        let connectedCount = 0;\n\n        for (let cy = 1; cy < this._height - 1; cy++) {\n            let labelIndex = 0;\n            let bc = colorMap[0];\n\n            for (let cx = 1; cx < this._width - 1; cx++) {\n                const pos = cy * this._width + cx;\n\n                if (this._labelData[pos] === 0) {\n                    const color = this._imageData[pos];\n                    if (color !== bc) {\n                        if (labelIndex === 0) {\n                            const lc = connectedCount + 1;\n                            colorMap[lc] = color;\n                            bc = color;\n                            const vertex = this._tracer.contourTracing(cy, cx, lc, color, EdgeLabel.Outside);\n                            if (vertex !== null) {\n                                connectedCount++;\n                                labelIndex = lc;\n                                const p: Contour = {\n                                    dir: ContourDirection.CW,\n                                    index: labelIndex,\n                                    firstVertex: vertex,\n                                    nextPeer: cc,\n                                    insideContours: null\n                                };\n                                if (cc !== null) {\n                                    cc.previousPeer = p;\n                                }\n                                cc = p;\n                            }\n                        } else {\n                            const vertex = this._tracer.contourTracing(cy, cx, EdgeLabel.Inside, color, labelIndex);\n                            if (vertex !== null) {\n                                const p: Contour = {\n                                    dir: depthLabel === 0 ? ContourDirection.CCW : ContourDirection.CW,\n                                    firstVertex: vertex,\n                                    index: depthLabel,\n                                    insideContours: null\n                                };\n                                sc = cc;\n                                while ((sc !== null) && sc.index !== labelIndex) {\n                                    sc = sc.nextPeer;\n                                }\n                                if (sc !== null) {\n                                    p.nextPeer = sc.insideContours;\n                                    if (sc.insideContours !== null) {\n                                        sc.insideContours.previousPeer = p;\n                                    }\n                                    sc.insideContours = p;\n                                }\n                            }\n                        }\n                    } else {\n                        this._labelData[pos] = labelIndex;\n                    }\n                } else if (this._labelData[pos] === EdgeLabel.Inside) {\n                    labelIndex = 0;\n                    bc = this._imageData[pos];\n                } else if (this._labelData[pos] === EdgeLabel.Outside) {\n                    labelIndex = 0;\n                    bc = colorMap[0];\n                } else {\n                    labelIndex = this._labelData[pos];\n                    bc = colorMap[labelIndex];\n                }\n            }\n        }\n\n        sc = cc;\n        while (sc !== null) {\n            sc.index = depthLabel;\n            sc = sc.nextPeer;\n        }\n\n        return {\n            cc,\n            count: connectedCount\n        };\n    }\n\n    drawContour(canvas: HTMLCanvasElement, firstContour: Contour): void {\n        const context = canvas.getContext('2d');\n\n        context.strokeStyle = 'red';\n        context.fillStyle = 'red';\n        context.lineWidth = 1;\n\n        let pq = firstContour;\n        let iq = pq && pq.insideContours;\n\n        while (pq !== null) {\n            let q = iq || pq;\n\n            if (iq !== null) {\n                iq = iq.nextPeer;\n            } else {\n                pq = pq.nextPeer;\n                iq = pq && pq.insideContours;\n            }\n\n            switch (q.dir) {\n                case ContourDirection.CW: {\n                    context.strokeStyle = 'red';\n                    break;\n                }\n                case ContourDirection.CCW: {\n                    context.strokeStyle = 'blue';\n                    break;\n                }\n                case ContourDirection.Unknown: {\n                    context.strokeStyle = 'green';\n                    break;\n                }\n            }\n\n            let p = q.firstVertex;\n            context.beginPath();\n            context.moveTo(p.x, p.y);\n\n            do {\n                p = p.next;\n                context.lineTo(p.x, p.y);\n            } while (p !== q.firstVertex);\n\n            context.stroke();\n        }\n    }\n}\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\n    return {\n        skeletonize: skeletonize\n    };\n}\nexport default Skeletonizer;\n/* eslint-enable eqeqeq */\n","import { ImageWrapper } from \"../common/image-wrapper\";\n\n/**\n * @borrows http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\n */\n\ntype Direction = number;\n\nexport const SearchDirections: Array<Array<Direction>> = [[0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [-1, -1], [-1, 0], [-1, 1]];\n\nexport interface ContourVertex {\n    x: number,\n    y: number,\n    dir: Direction,\n    next: ContourVertex,\n    prev: ContourVertex\n}\n\ninterface Current {\n    cx: number,\n    cy: number,\n    dir: Direction\n}\n\nexport class Tracer {\n    private _imageData: Uint8Array;\n    private _labelData: Array<number>;\n    private _width: number;\n\n    constructor(imageWrapper: ImageWrapper, labelWrapper: ImageWrapper<Array<number>>) {\n        this._imageData = imageWrapper.data;\n        this._labelData = labelWrapper.data as Array<number>;\n        this._width = imageWrapper.size.x;\n    }\n\n    trace(current: Current, color: number, label: number, edgeLabel: number): boolean {\n        for (let i = 0; i < 7; i++) {\n            const y = current.cy + SearchDirections[current.dir][0] | 0;\n            const x = current.cx + SearchDirections[current.dir][1] | 0;\n            const pos = y * this._width + x | 0;\n\n            if ((this._imageData[pos] === color) && ((this._labelData[pos] === 0) || (this._labelData[pos] === label))) {\n                this._labelData[pos] = label;\n                current.cx = x;\n                current.cy = y;\n\n                return true;\n            } else {\n                if (this._labelData[pos] === 0) {\n                    this._labelData[pos] = edgeLabel;\n                }\n                current.dir = (current.dir + 1) % 8;\n            }\n        }\n\n        return false;\n    }\n\n    contourTracing(sy: number, sx: number, label: number, color: number, edgeLabel: number): ContourVertex {\n        let Fv: ContourVertex = null;\n        const current: Current = {\n            cx: sx,\n            cy: sy,\n            dir: 0\n        };\n\n        if (this.trace(current, color, label, edgeLabel)) {\n            Fv = {\n                x: sx,\n                y: sy,\n                dir: current.dir,\n                next: null,\n                prev: null\n            };\n            let Cv = Fv;\n            let ldir = current.dir;\n            let P = {\n                x: current.cx,\n                y: current.cy,\n                dir: 0,\n                next: null,\n                prev: Cv\n            };\n            Cv.next = P;\n            Cv = P;\n\n            do {\n                current.dir = (current.dir + 6) % 8;\n\n                this.trace(current, color, label, edgeLabel);\n\n                if (ldir !== current.dir) {\n                    Cv.dir = current.dir;\n                    P = {\n                        x: current.cx,\n                        y: current.cy,\n                        dir: 0,\n                        next: null,\n                        prev: Cv\n                    };\n                    Cv.next = P;\n                    Cv = P;\n                } else {\n                    Cv.dir = ldir;\n                    Cv.x = current.cx;\n                    Cv.y = current.cy;\n                }\n\n                ldir = current.dir;\n            } while (current.cx !== sx || current.cy !== sy);\n\n            Fv.prev = Cv.prev;\n            Cv.prev.next = Fv;\n        }\n        return Fv;\n    }\n}\n","import _polyfills from './common/polyfills';\nimport { ResultCollector } from './analytics/result-collector';\nimport { Box } from './common/box';\nimport { EventCallback, Events, EventSubscription } from './common/events';\nimport { ImageDebug } from './common/image-debug';\nimport { ImageWrapper } from './common/image-wrapper';\nimport { merge } from './common/merge';\nimport { Point } from './common/point';\nimport { config as defaultConfig, QuaggaConfig } from './config/config';\nimport { BarcodeDecoder, QuaggaBarcode } from './decoder/barcode-decoder';\nimport { CameraAccess } from './input/camera-access';\nimport { FrameGrabber } from './input/frame-grabber';\nimport { ImageStream } from './input/image-stream';\nimport { InputStream } from './input/input-stream';\nimport { LiveStream } from './input/live-stream';\nimport { VideoStream } from './input/video-stream';\nimport { checkImageConstraints } from './input/input-stream-utils';\nimport { BarcodeLocator } from './locator/barcode-locator';\nimport { BarcodeReaderDeclaration } from './reader/barcode-reader';\n\ninterface WorkerThread {\n    worker: Worker;\n    imageData: Uint8Array;\n    busy: boolean;\n}\n\nexport interface QuaggaCanvasContainer {\n    ctx: {\n        image: CanvasRenderingContext2D,\n        overlay: CanvasRenderingContext2D\n    },\n    dom: {\n        image: HTMLCanvasElement,\n        overlay: HTMLCanvasElement\n    }\n}\n\nlet _inputStream: InputStream;\nlet _frameGrabber: FrameGrabber;\nlet _stopped: boolean;\nconst _canvasContainer: QuaggaCanvasContainer = {\n    ctx: {\n        image: null,\n        overlay: null\n    },\n    dom: {\n        image: null,\n        overlay: null\n    }\n};\nlet _inputImageWrapper: ImageWrapper;\nlet _locator: BarcodeLocator;\nlet _boxSize: Box;\nlet _decoder: BarcodeDecoder;\nlet _workerPool = new Array<WorkerThread>();\nlet _onUIThread: boolean;\nlet _resultCollector: ResultCollector;\nlet _config: QuaggaConfig;\n\nexport default {\n    init(config: QuaggaConfig, cb: () => void, imageWrapper?: ImageWrapper) {\n        _onUIThread = true;\n        _config = merge(defaultConfig, config);\n        if (imageWrapper) {\n            _onUIThread = false;\n            _initializeData(imageWrapper);\n            cb();\n        } else {\n            _initInputStream(cb);\n        }\n    },\n\n    CameraAccess: CameraAccess,\n\n    ImageDebug: ImageDebug,\n\n    ImageWrapper: ImageWrapper,\n\n    ResultCollector: ResultCollector,\n\n    get canvas(): QuaggaCanvasContainer {\n        return _canvasContainer;\n    },\n\n    start(): void {\n        if (_onUIThread && _config.inputStream.type === 'LiveStream') {\n            _startContinuousUpdate();\n        } else {\n            _update();\n        }\n    },\n\n    stop(): void {\n        _stopped = true;\n        _adjustWorkerPool(0);\n        if (_config.inputStream.type === 'LiveStream') {\n            CameraAccess.release();\n            _inputStream.clearEventHandlers();\n        }\n    },\n\n    decodeSingle(config: QuaggaConfig, resultCallback: (_: QuaggaBarcode) => void): void {\n        config = merge({\n            inputStream: {\n                type: 'ImageStream',\n                sequence: false,\n                size: 800,\n                src: config.src\n            },\n            numOfWorkers: (process.env.NODE_ENV !== 'production' && config.debug) ? 0 : 1,\n            locator: {\n                halfSample: false\n            }\n        }, config);\n\n        this.init(config, () => {\n            Events.once('processed', (result: QuaggaBarcode) => {\n                this.stop();\n                resultCallback.call(null, result);\n            }, true);\n            this.start();\n        });\n    },\n\n    pause(): void {\n        _stopped = true;\n    },\n\n    onDetected(callback: EventSubscription | EventCallback): void {\n        Events.subscribe('detected', callback);\n    },\n\n    offDetected(callback: EventCallback): void {\n        Events.unsubscribe('detected', callback);\n    },\n\n    onProcessed(callback: EventSubscription | EventCallback): void {\n        Events.subscribe('processed', callback);\n    },\n\n    offProcessed(callback: EventCallback): void {\n        Events.unsubscribe('processed', callback);\n    },\n\n    setReaders(readers: Array<BarcodeReaderDeclaration>): void {\n        if (_decoder) {\n            _decoder.setReaders(readers);\n        } else if (_onUIThread && _workerPool.length > 0) {\n            _workerPool.forEach(({ worker }) => worker.postMessage({ cmd: 'setReaders', readers }));\n        }\n    },\n\n    registerResultCollector(resultCollector: ResultCollector): void {\n        if (resultCollector && typeof resultCollector.addResult === 'function') {\n            _resultCollector = resultCollector;\n        }\n    }\n};\n\nfunction _initializeData(imageWrapper?: ImageWrapper): void {\n    _initBuffers(imageWrapper);\n    _decoder = new BarcodeDecoder(_config.decoder, _inputImageWrapper);\n}\n\nfunction _initInputStream(callback: (err?: any) => void): void {\n    let video: HTMLVideoElement;\n    if (_config.inputStream.type === 'VideoStream') {\n        video = document.createElement('video');\n        _inputStream = new VideoStream(video);\n    } else if (_config.inputStream.type === 'ImageStream') {\n        _inputStream = new ImageStream();\n    } else if (_config.inputStream.type === 'LiveStream') {\n        const 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 = new LiveStream(video);\n        CameraAccess.request(video, _config.inputStream.constraints)\n            .then(() => _inputStream.trigger('canrecord'), err => callback(err));\n    }\n\n    _inputStream.setAttribute('preload', 'auto');\n    _inputStream.config = _config.inputStream;\n    _inputStream.addEventListener('canrecord', _canRecord.bind(this, callback));\n}\n\nfunction _getViewPort(): HTMLElement {\n    const target = _config.inputStream.target;\n    // Check if target is already a DOM element\n    if (target instanceof HTMLElement) {\n        return target;\n    } else {\n        // Use '#interactive.viewport' as a fallback selector (backwards compatibility)\n        const selector = typeof target === 'string' ? target : '#interactive.viewport';\n        return document.querySelector(selector);\n    }\n}\n\nfunction _canRecord(cb: () => void): void {\n    checkImageConstraints(_inputStream, _config.locator);\n    _initCanvas();\n    _frameGrabber = new FrameGrabber(_inputStream, _canvasContainer.dom.image);\n\n    _adjustWorkerPool(_config.numOfWorkers, () => {\n        if (_config.numOfWorkers === 0) {\n            _initializeData();\n        }\n\n        _inputStream.play();\n        cb();\n    });\n}\n\nfunction _initCanvas(): void {\n    if (typeof document !== 'undefined') {\n        const 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.canvasWidth;\n        _canvasContainer.dom.image.height = _inputStream.canvasHeight;\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            const 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.canvasWidth;\n        _canvasContainer.dom.overlay.height = _inputStream.canvasHeight;\n    }\n}\n\nfunction _initBuffers(imageWrapper?: ImageWrapper): void {\n    if (imageWrapper) {\n        _inputImageWrapper = imageWrapper;\n    } else {\n        _inputImageWrapper = new ImageWrapper({\n            x: _inputStream.width,\n            y: _inputStream.height\n        });\n    }\n\n    if (process.env.NODE_ENV !== 'production') {\n        console.log(_inputImageWrapper.size);\n    }\n    _boxSize = [\n        { x: 0, y: 0 },\n        { x: 0, y: _inputImageWrapper.size.y },\n        { x: _inputImageWrapper.size.x, y: _inputImageWrapper.size.y },\n        { x: _inputImageWrapper.size.x, y: 0 }\n    ];\n    _locator = new BarcodeLocator(_inputImageWrapper, _config.locator);\n}\n\nfunction _transform(polygon: ReadonlyArray<Point>, offset: Point): void {\n    polygon.forEach(vertex => {\n        vertex.x += offset.x;\n        vertex.y += offset.y;\n    })\n}\n\nfunction _transformResult(result: QuaggaBarcode, offset: Point): void {\n    if (result.barcodes) {\n        result.barcodes.forEach(barcode => _transformResult(barcode, offset));\n    }\n\n    if (result.line) {\n        _transform(result.line, offset);\n    }\n\n    if (result.box) {\n        _transform(result.box, offset);\n    }\n\n    if (result.boxes) {\n        result.boxes.forEach(box => _transform(box, offset));\n    }\n}\n\nfunction _addResult(result: QuaggaBarcode, imageData: Uint8Array, canvasWidth: number, canvasHeight: number): void {\n    if (imageData && _resultCollector) {\n        if (result.barcodes) {\n            result.barcodes.forEach(({ codeResult }) => {\n                if (codeResult) {\n                    _resultCollector.addResult(imageData, canvasWidth, canvasHeight, codeResult)\n                }\n            });\n        } else if (result.codeResult) {\n            _resultCollector.addResult(imageData, canvasWidth, canvasHeight, result.codeResult);\n        }\n    }\n}\n\nfunction _hasCodeResult(result: QuaggaBarcode): boolean {\n    return result && (!!result.codeResult || result.barcodes && result.barcodes.some(barcode => !!barcode.codeResult));\n}\n\nfunction _publishResult(result?: QuaggaBarcode, imageData?: Uint8Array): void {\n    let resultToPublish: QuaggaBarcode | Array<QuaggaBarcode> = result;\n\n    if (result && _onUIThread) {\n        const offset = _inputStream.topLeft;\n\n        if (offset.x !== 0 || offset.y !== 0) {\n            _transformResult(result, offset);\n        }\n\n        _addResult(result, imageData, _inputStream.canvasWidth, _inputStream.canvasHeight);\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(): void {\n    const boxes = _config.locate ? _locator.locate() : [_boxSize];\n    const result = _decoder.decodeFromBoundingBoxes(boxes);\n    _publishResult(result, _inputImageWrapper.data);\n}\n\nfunction _update(): void {\n    if (_onUIThread) {\n        if (_workerPool.length > 0) {\n            const availableWorker = _workerPool.find(({ busy }) => !busy);\n            if (!availableWorker) {\n                return; // all workers are busy\n            }\n\n            const imageData = availableWorker.imageData;\n\n            if (_frameGrabber.grab(imageData)) {\n                availableWorker.busy = true;\n                availableWorker.worker.postMessage({ cmd: 'process', imageData }, [imageData.buffer]);\n            }\n        } else if (_frameGrabber.grab(_inputImageWrapper.data)) {\n            _locateAndDecode();\n        }\n    } else {\n        _locateAndDecode();\n    }\n}\n\nfunction _startContinuousUpdate(): void {\n    const delay = 1000 / (_config.frequency || 60);\n    let next = null;\n    _stopped = false;\n\n    (function frame(timestamp): void {\n        next = next || timestamp;\n        if (!_stopped) {\n            if (timestamp >= next) {\n                next += delay;\n                _update();\n            }\n            window.requestAnimationFrame(frame);\n        }\n    }(performance.now()));\n}\n\nfunction _initWorker(cb: (workerThread: WorkerThread) => void): void {\n    const blobURL = _generateWorkerBlob();\n    const workerThread = {\n        worker: new Worker(blobURL),\n        imageData: new Uint8Array(_inputStream.width * _inputStream.height),\n        busy: true\n    };\n\n    workerThread.worker.onmessage = ({ data }) => {\n        if (data.event === 'initialized') {\n            URL.revokeObjectURL(blobURL);\n            workerThread.busy = false;\n            workerThread.imageData = new Uint8Array(data.imageData);\n            if (process.env.NODE_ENV !== 'production') {\n                console.log('Worker initialized');\n            }\n            cb(workerThread);\n        } else if (data.event === 'processed') {\n            workerThread.busy = false;\n            workerThread.imageData = new Uint8Array(data.imageData);\n            _publishResult(data.result, workerThread.imageData);\n        } else if (data.event === 'error') {\n            if (process.env.NODE_ENV !== 'production') {\n                console.log('Worker error:', data.message);\n            }\n        }\n    };\n\n    workerThread.worker.postMessage({\n        cmd: 'init',\n        size: { x: _inputStream.width, y: _inputStream.height },\n        imageData: workerThread.imageData,\n        config: merge(_config, { inputStream: { target: null } })\n    }, [workerThread.imageData.buffer]);\n}\n\nfunction _workerInterface(factory: Function): void {\n    let Quagga: any;\n    const worker: any = self;\n    let imageWrapper: ImageWrapper;\n\n    if (factory) {\n        Quagga = factory().default;\n        if (!Quagga) {\n            worker.postMessage({ event: 'error', message: 'Quagga could not be created' });\n            return;\n        }\n    }\n\n    self.onmessage = ({ data }) => {\n        if (data.cmd === 'init') {\n            const config: QuaggaConfig = data.config;\n            config.numOfWorkers = 0;\n            imageWrapper = new Quagga.ImageWrapper({ x: data.size.x, y: data.size.y }, new Uint8Array(data.imageData));\n            Quagga.init(\n                config,\n                () => worker.postMessage(\n                    { event: 'initialized', imageData: imageWrapper.data }, [imageWrapper.data.buffer]\n                ),\n                imageWrapper\n            );\n            Quagga.onProcessed((result: QuaggaBarcode) =>\n                worker.postMessage(\n                    { event: 'processed', imageData: imageWrapper.data, result }, [imageWrapper.data.buffer]\n                )\n            );\n        } else if (data.cmd === 'process') {\n            imageWrapper.data = new Uint8Array(data.imageData);\n            Quagga.start();\n        } else if (data.cmd === 'setReaders') {\n            Quagga.setReaders(data.readers);\n        }\n    };\n}\n\nfunction _generateWorkerBlob(): string {\n    // @ts-ignore\n    let factorySource: string = __factorySource__ || '';\n    const blob = new Blob([`(${_workerInterface.toString()})(${factorySource});`], { type: 'text/javascript' });\n\n    return window.URL.createObjectURL(blob);\n}\n\nfunction _adjustWorkerPool(capacity: number, cb?: () => void): void {\n    const increaseBy = capacity - _workerPool.length;\n\n    if (increaseBy > 0) {\n        for (let i = 0; i < increaseBy; i++) {\n            _initWorker(workerThread => {\n                _workerPool.push(workerThread);\n                if (_workerPool.length >= capacity && cb) {\n                    cb();\n                }\n            });\n        }\n    } else {\n        if (increaseBy < 0) {\n            _workerPool.slice(increaseBy).forEach(({ worker }) => {\n                worker.terminate();\n                if (process.env.NODE_ENV !== 'production') {\n                    console.log('Worker terminated!');\n                }\n            });\n            _workerPool = _workerPool.slice(0, increaseBy);\n        }\n        return cb && cb();\n    }\n}\n","import { Barcode, BarcodeInfo, BarcodeReader, BarcodeReaderConfig } from './barcode-reader';\n\nconst N = 1;\nconst W = 3;\nconst START_PATTERN = [W, N, W, N, N, N];\nconst STOP_PATTERN = [W, N, N, N, W];\nconst CODE_PATTERN = [\n    [N, N, W, W, N],\n    [W, N, N, N, W],\n    [N, W, N, N, W],\n    [W, W, N, N, N],\n    [N, N, W, N, W],\n    [W, N, W, N, N],\n    [N, W, W, N, N],\n    [N, N, N, W, W],\n    [W, N, N, W, N],\n    [N, W, N, W, N]\n];\nconst startPatternLength = START_PATTERN.reduce((sum, val) => sum + val, 0);\n\nexport class TwoOfFiveReader extends BarcodeReader {\n    private _barSpaceRatio: [number, number];\n\n    constructor(config?: BarcodeReaderConfig) {\n        super(config);\n\n        this._barSpaceRatio = [1, 1];\n        this._format = '2of5';\n        this._singleCodeError = 0.78;\n        this._averageCodeError = 0.30;\n    }\n\n    decode(): Barcode {\n        const startInfo = this._findStart();\n\n        if (!startInfo) {\n            return null;\n        }\n\n        const endInfo = this._findEnd();\n\n        if (!endInfo) {\n            return null;\n        }\n\n        const counters = this._fillCounters(startInfo.end, endInfo.start, 0);\n\n        if (counters.length % 10 !== 0) {\n            return null;\n        }\n\n        const result = new Array<number>();\n        const decodedCodes = new Array<BarcodeInfo>();\n\n        decodedCodes.push(startInfo);\n\n        const code = this._decodePayload(counters, result, decodedCodes);\n\n        if (!code || result.length < 5) {\n            return null;\n        }\n\n        decodedCodes.push(endInfo);\n\n        return {\n            code: result.join(''),\n            start: startInfo.start,\n            end: endInfo.end,\n            startInfo,\n            decodedCodes\n        };\n    }\n\n    protected _findStart(): BarcodeInfo {\n        let offset = this._nextSet(this._row);\n        let narrowBarWidth = 1;\n        let startInfo: BarcodeInfo;\n\n        while (!startInfo) {\n            startInfo = this._findPattern(START_PATTERN, offset, 0, true);\n\n            if (!startInfo) {\n                return null;\n            }\n\n            narrowBarWidth = (startInfo.end - startInfo.start) / startPatternLength | 0;\n            const leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5;\n\n            if (leadingWhitespaceStart >= 0) {\n                if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                    return startInfo;\n                }\n            }\n\n            offset = startInfo.end;\n            startInfo = null;\n        }\n\n        return null;\n    }\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodeInfo): BarcodeInfo {\n        const trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;\n\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n\n        return null;\n    }\n\n    protected _findEnd(): BarcodeInfo {\n        this._row.reverse();\n\n        const offset = this._nextSet(this._row);\n        const endInfo = this._findPattern(STOP_PATTERN, offset, 0, true);\n\n        this._row.reverse();\n\n        if (endInfo === null) {\n            return null;\n        }\n\n        // reverse numbers\n        const start = endInfo.start;\n        endInfo.start = this._row.length - endInfo.end;\n        endInfo.end = this._row.length - start;\n\n        return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;\n    }\n\n    protected _decodeCode(counter: ReadonlyArray<number>): BarcodeInfo {\n        const bestMatch: BarcodeInfo = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        };\n\n        for (let code = 0; code < CODE_PATTERN.length; code++) {\n            const error = this._matchPattern(counter, CODE_PATTERN[code]);\n            if (error < bestMatch.error) {\n                bestMatch.code = code;\n                bestMatch.error = error;\n            }\n        }\n\n        return bestMatch.error < this.AVERAGE_CODE_ERROR ? bestMatch : null;\n    }\n\n    protected _decodePayload(counters: ReadonlyArray<number>, result: Array<number>, decodedCodes: Array<BarcodeInfo>): BarcodeInfo {\n        const counterLength = counters.length;\n        const counter = [0, 0, 0, 0, 0];\n        let pos = 0;\n        let code: BarcodeInfo;\n\n        while (pos < counterLength) {\n            for (let i = 0; i < 5; i++) {\n                counter[i] = counters[pos] * this._barSpaceRatio[0];\n                pos += 2;\n            }\n\n            code = this._decodeCode(counter);\n\n            if (!code) {\n                return null;\n            }\n\n            result.push(code.code);\n            decodedCodes.push(code);\n        }\n\n        return code;\n    }\n}\n","export enum BarcodeDirection {\n    Forward = 1,\n    Reverse = -1\n};\n\nexport type BarcodeFormat = string;\n\nexport type BarcodeReaderType = string;\n\nexport type BarcodeReaderDeclaration = BarcodeReaderType | { format: BarcodeReaderType; config: BarcodeReaderConfig; };\n\nexport interface BarcodeReaderConfig {\n    normalizeBarSpaceWidth?: boolean;\n    supplements?: Array<BarcodeReaderType>;\n}\n\nexport interface BarcodeCorrection {\n    bar: number;\n    space: number;\n}\n\nexport interface BarcodeInfo {\n    code?: number;\n    correction?: BarcodeCorrection;\n    end?: number;\n    endCounter?: number;\n    error?: number;\n    start?: number;\n    startCounter?: number;\n}\n\nexport interface Barcode {\n    code?: string;\n    codeset?: number;\n    correction?: BarcodeCorrection;\n    decodedCodes?: Array<string | BarcodeInfo>;\n    direction?: BarcodeDirection;\n    end?: number;\n    endInfo?: BarcodeInfo;\n    format?: BarcodeFormat;\n    start?: number;\n    startInfo?: BarcodeInfo;\n    supplement?: Barcode;\n}\n\nexport abstract class BarcodeReader {\n    protected _singleCodeError: number;\n    protected _averageCodeError: number;\n    protected _format: BarcodeFormat;\n    protected _row: Array<number>;\n\n    config: BarcodeReaderConfig;\n    supplements: Array<BarcodeReader>;\n\n    static get Exception() {\n        return {\n            StartNotFoundException: 'Start-Info was not found!',\n            CodeNotFoundException: 'Code could not be found!',\n            PatternNotFoundException: 'Pattern could not be found!'\n        };\n    }\n\n    get SINGLE_CODE_ERROR(): number {\n        return this._singleCodeError;\n    }\n\n    get AVERAGE_CODE_ERROR(): number {\n        return this._averageCodeError;\n    }\n\n    get FORMAT(): BarcodeFormat {\n        return this._format;\n    }\n\n    constructor(config?: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        this._format = 'unknown';\n        this._row = [];\n        this.config = config || {};\n        this.supplements = supplements;\n    }\n\n    abstract decode(row?: Array<number>, start?: number): Barcode;\n\n    protected _findPattern(pattern: ReadonlyArray<number>, offset: number, isWhite: 0 | 1, tryHarder: boolean): BarcodeInfo {\n        const counter = new Array<number>(pattern.length);\n        const bestMatch: BarcodeInfo = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        };\n        const epsilon = this.AVERAGE_CODE_ERROR;\n        let counterPos = 0;\n\n        if (!offset) {\n            offset = this._nextSet(this._row);\n        }\n\n        counter.fill(0);\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    const error = this._matchPattern(counter, pattern);\n\n                    if (error < epsilon) {\n                        bestMatch.error = error;\n                        bestMatch.start = i - counter.reduce((sum, value) => sum + value, 0);\n                        bestMatch.end = i;\n                        return bestMatch;\n                    }\n\n                    if (tryHarder) {\n                        for (let j = 0; j < counter.length - 2; j++) {\n                            counter[j] = counter[j + 2];\n                        }\n                        counter[counter.length - 2] = 0;\n                        counter[counter.length - 1] = 0;\n                        counterPos--;\n                    } else {\n                        return null;\n                    }\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = isWhite ? 0 : 1;\n            }\n        }\n        return null;\n    }\n\n    protected _nextUnset(line: ReadonlyArray<number>, start?: number): number {\n        for (let i = start || 0; i < line.length; i++) {\n            if (!line[i]) {\n                return i;\n            }\n        }\n        return line.length;\n    }\n\n    protected _nextSet(line: ReadonlyArray<number>, start?: number): number {\n        for (let i = start || 0; i < line.length; i++) {\n            if (line[i]) {\n                return i;\n            }\n        }\n        return line.length;\n    }\n\n    protected _matchRange(start: number, end: number, value: number): boolean {\n        for (let i = start < 0 ? 0 : start; i < end; i++) {\n            if (this._row[i] !== value) {\n                return false;\n            }\n        }\n        return true;\n    }\n\n    protected _matchPattern(counter: ReadonlyArray<number>, code: ReadonlyArray<number>, maxSingleError?: number): number {\n        let error = 0;\n        let sum = 0;\n        let modulo = 0;\n\n        maxSingleError = maxSingleError || this.SINGLE_CODE_ERROR || 1;\n\n        for (let i = 0; i < counter.length; i++) {\n            sum += counter[i];\n            modulo += code[i];\n        }\n\n        if (sum < modulo) {\n            return Number.MAX_VALUE;\n        }\n\n        const barWidth = sum / modulo;\n        maxSingleError *= barWidth;\n\n        for (let i = 0; i < counter.length; i++) {\n            const count = counter[i];\n            const scaled = code[i] * barWidth;\n            const singleError = Math.abs(count - scaled) / scaled;\n\n            if (singleError > maxSingleError) {\n                return Number.MAX_VALUE;\n            }\n\n            error += singleError;\n        }\n\n        return error / modulo;\n    }\n\n    protected _correctBars(counter: Array<number>, correction: number, indices: Array<number>) {\n        let length = indices.length;\n        let tmp = 0;\n\n        while (length--) {\n            tmp = counter[indices[length]] * (1 - ((1 - correction) / 2));\n            if (tmp > 1) {\n                counter[indices[length]] = tmp;\n            }\n        }\n    }\n\n    decodePattern(pattern: Array<number>): Barcode {\n        this._row = pattern;\n        let result = this.decode();\n\n        if (result === null) {\n            this._row.reverse();\n            result = this.decode();\n            if (result) {\n                result.direction = BarcodeDirection.Reverse;\n                result.start = this._row.length - result.start;\n                result.end = this._row.length - result.end;\n            }\n        } else {\n            result.direction = BarcodeDirection.Forward;\n        }\n\n        if (result) {\n            result.format = this.FORMAT;\n        }\n\n        return result;\n    }\n\n    _fillCounters(offset: number, end: number, isWhite: 0 | 1): Array<number> {\n        const counters = new Array<number>();\n        let counterPos = 0;\n\n        counters[counterPos] = 0;\n\n        for (let i = offset; i < end; i++) {\n            if (this._row[i] ^ isWhite) {\n                counters[counterPos]++;\n            } else {\n                counterPos++;\n                counters[counterPos] = 1;\n                isWhite = isWhite ? 0 : 1;\n            }\n        }\n\n        return counters;\n    }\n\n    protected _toCounters(start: number, counters: Uint16Array): Uint16Array {\n        const numCounters = counters.length;\n        const end = this._row.length;\n        let isWhite: 0 | 1 = this._row[start] ? 0 : 1;\n        let counterPos = 0;\n\n        counters.fill(0);\n\n        for (let i = start; i < end; i++) {\n            if (this._row[i] ^ isWhite) {\n                counters[counterPos]++;\n            } else {\n                counterPos++;\n                if (counterPos === numCounters) {\n                    break;\n                } else {\n                    counters[counterPos] = 1;\n                    isWhite = isWhite ? 0 : 1;\n                }\n            }\n        }\n\n        return counters;\n    }\n}\n","import { Barcode, BarcodeInfo, BarcodeReader } from './barcode-reader';\n\nconst ALPHABETH_STRING = '0123456789-$:/.+ABCD';\nconst ALPHABET = [...ALPHABETH_STRING].map(char => char.charCodeAt(0));\n// const ALPHABET = [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 45, 36, 58, 47, 46, 43, 65, 66, 67, 68];\nconst CHARACTER_ENCODINGS = [0x003, 0x006, 0x009, 0x060, 0x012, 0x042, 0x021, 0x024, 0x030, 0x048, 0x00c, 0x018, 0x045,\n    0x051, 0x054, 0x015, 0x01A, 0x029, 0x00B, 0x00E];\nconst START_END = [0x01A, 0x029, 0x00B, 0x00E];\nconst MIN_ENCODED_CHARS = 4;\nconst MAX_ACCEPTABLE = 2.0;\nconst PADDING = 1.5;\n\ninterface Threshold {\n    space: {\n        narrow: {\n            size: number;\n            counts: number;\n            min: number;\n            max: number;\n        };\n        wide: {\n            size: number;\n            counts: number;\n            min: number;\n            max: number;\n        };\n    };\n    bar: {\n        narrow: {\n            size: number;\n            counts: number;\n            min: number;\n            max: number;\n        };\n        wide: {\n            size: number;\n            counts: number;\n            min: number;\n            max: number;\n        };\n    };\n}\n\nexport class CodabarReader extends BarcodeReader {\n    private _counters: Array<number>;\n\n    constructor() {\n        super();\n\n        this._format = 'codabar';\n        this._counters = [];\n    }\n\n    decode(): Barcode {\n        this._counters = this._fillCounters(this._nextUnset(this._row), this._row.length, 1);\n\n        const start = this._findStart();\n        if (!start) {\n            return null;\n        }\n\n        const result = new Array<string>();\n        let nextStart = start.startCounter;\n        let pattern: number;\n\n        do {\n            pattern = this._toPattern(nextStart);\n            if (pattern < 0) {\n                return null;\n            }\n            const decodedChar = this._patternToChar(pattern);\n            if (decodedChar === null) {\n                return null;\n            }\n            result.push(decodedChar);\n            nextStart += 8;\n            if (result.length > 1 && START_END.some(code => code === pattern)) {\n                break;\n            }\n        } while (nextStart < this._counters.length);\n\n        // verify end\n        if ((result.length - 2) < MIN_ENCODED_CHARS || !START_END.some(code => code === pattern)) {\n            return null;\n        }\n\n        // verify end white space\n        if (!this._verifyWhitespace(start.startCounter, nextStart - 8)) {\n            return null;\n        }\n\n        if (!this._validateResult(result, start.startCounter)) {\n            return null;\n        }\n\n        nextStart = nextStart > this._counters.length ? this._counters.length : nextStart;\n        const end = start.start + this._sumCounters(start.startCounter, nextStart - 8);\n\n        return {\n            code: result.join(''),\n            start: start.start,\n            end,\n            startInfo: start,\n            decodedCodes: result\n        };\n    }\n\n    protected _verifyWhitespace(startCounter: number, endCounter: number): boolean {\n        if ((startCounter - 1 <= 0)\n            || this._counters[startCounter - 1] >= (this._calculatePatternLength(startCounter) / 2.0)) {\n            if ((endCounter + 8 >= this._counters.length)\n                || this._counters[endCounter + 7] >= (this._calculatePatternLength(endCounter) / 2.0)) {\n                return true;\n            }\n        }\n\n        return false;\n    }\n\n    private _calculatePatternLength(offset: number): number {\n        let sum = 0;\n\n        for (let i = offset; i < offset + 7; i++) {\n            sum += this._counters[i];\n        }\n\n        return sum;\n    }\n\n    private _thresholdResultPattern(result: ReadonlyArray<string>, startCounter: number): Threshold {\n        const categorization: Threshold = {\n            space: {\n                narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE },\n                wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE }\n            },\n            bar: {\n                narrow: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE },\n                wide: { size: 0, counts: 0, min: 0, max: Number.MAX_VALUE }\n            }\n        };\n        let pos = startCounter;\n\n        for (let i = 0; i < result.length; i++) {\n            let pattern = this._charToPattern(result[i]);\n\n            for (let j = 6; j >= 0; j--) {\n                const kind = (j & 1) === 2 ? categorization.bar : categorization.space;\n                const cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\n                cat.size += this._counters[pos + j];\n                cat.counts++;\n                pattern >>= 1;\n            }\n            pos += 8;\n        }\n\n        ['space', 'bar'].forEach(key => {\n            const kind = categorization[key];\n            kind.wide.min = Math.floor((kind.narrow.size / kind.narrow.counts + kind.wide.size / kind.wide.counts) / 2);\n            kind.narrow.max = Math.ceil(kind.wide.min);\n            kind.wide.max = Math.ceil((kind.wide.size * MAX_ACCEPTABLE + PADDING) / kind.wide.counts);\n        });\n\n        return categorization;\n    }\n\n    private _charToPattern(char: string): number {\n        const charCode = char.charCodeAt(0);\n\n        for (let i = 0; i < ALPHABET.length; i++) {\n            if (ALPHABET[i] === charCode) {\n                return CHARACTER_ENCODINGS[i];\n            }\n        }\n\n        return 0x0;\n    }\n\n    private _validateResult(result: ReadonlyArray<string>, startCounter: number): boolean {\n        const threshold = this._thresholdResultPattern(result, startCounter);\n        let pos = startCounter;\n\n        for (let i = 0; i < result.length; i++) {\n            let pattern = this._charToPattern(result[i]);\n\n            for (let j = 6; j >= 0; j--) {\n                const kind = (j & 1) === 0 ? threshold.bar : threshold.space;\n                const cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\n                const size = this._counters[pos + j];\n                if (size < cat.min || size > cat.max) {\n                    return false;\n                }\n                pattern >>= 1;\n            }\n            pos += 8;\n        }\n\n        return true;\n    }\n\n    private _patternToChar(pattern: number): string {\n        for (let i = 0; i < CHARACTER_ENCODINGS.length; i++) {\n            if (CHARACTER_ENCODINGS[i] === pattern) {\n                return String.fromCharCode(ALPHABET[i]);\n            }\n        }\n\n        return null;\n    }\n\n    private _computeAlternatingThreshold(offset: number, end: number): number {\n        let min = Number.MAX_VALUE;\n        let max = 0;\n\n        for (let i = offset; i < end; i += 2) {\n            const counter = this._counters[i];\n            if (counter > max) {\n                max = counter;\n            }\n            if (counter < min) {\n                min = counter;\n            }\n        }\n\n        return ((min + max) / 2.0) | 0;\n    }\n\n    private _toPattern(offset: number): number {\n        const numCounters = 7;\n        const end = offset + numCounters;\n\n        if (end > this._counters.length) {\n            return -1;\n        }\n\n        const barThreshold = this._computeAlternatingThreshold(offset, end);\n        const spaceThreshold = this._computeAlternatingThreshold(offset + 1, end);\n        let bitmask = 1 << (numCounters - 1);\n        let pattern = 0;\n\n        for (let i = 0; i < numCounters; i++) {\n            const threshold = (i & 1) === 0 ? barThreshold : spaceThreshold;\n            if (this._counters[offset + i] > threshold) {\n                pattern |= bitmask;\n            }\n            bitmask >>= 1;\n        }\n\n        return pattern;\n    }\n\n    private _sumCounters(start: number, end: number): number {\n        let sum = 0;\n\n        for (let i = start; i < end; i++) {\n            sum += this._counters[i];\n        }\n\n        return sum;\n    }\n\n    protected _findStart(): BarcodeInfo {\n        let start = this._nextUnset(this._row);\n\n        for (let i = 1; i < this._counters.length; i++) {\n            const pattern = this._toPattern(i);\n            if (pattern !== -1 && START_END.some(code => code === pattern)) {\n                // TODO: Look for whitespace ahead\n                start += this._sumCounters(0, i);\n                const end = start + this._sumCounters(i, i + 8);\n                return {\n                    start,\n                    end,\n                    startCounter: i,\n                    endCounter: i + 8\n                };\n            }\n        }\n\n        return null;\n    }\n}\n","import { Barcode, BarcodeCorrection, BarcodeInfo, BarcodeReader } from './barcode-reader';\n\nconst CODE_SHIFT = 98;\nconst CODE_C = 99;\nconst CODE_B = 100;\nconst CODE_A = 101;\nconst START_CODE_A = 103;\nconst START_CODE_B = 104;\nconst START_CODE_C = 105;\nconst STOP_CODE = 106;\nconst CODE_PATTERN = [\n    [2, 1, 2, 2, 2, 2],\n    [2, 2, 2, 1, 2, 2],\n    [2, 2, 2, 2, 2, 1],\n    [1, 2, 1, 2, 2, 3],\n    [1, 2, 1, 3, 2, 2],\n    [1, 3, 1, 2, 2, 2],\n    [1, 2, 2, 2, 1, 3],\n    [1, 2, 2, 3, 1, 2],\n    [1, 3, 2, 2, 1, 2],\n    [2, 2, 1, 2, 1, 3],\n    [2, 2, 1, 3, 1, 2],\n    [2, 3, 1, 2, 1, 2],\n    [1, 1, 2, 2, 3, 2],\n    [1, 2, 2, 1, 3, 2],\n    [1, 2, 2, 2, 3, 1],\n    [1, 1, 3, 2, 2, 2],\n    [1, 2, 3, 1, 2, 2],\n    [1, 2, 3, 2, 2, 1],\n    [2, 2, 3, 2, 1, 1],\n    [2, 2, 1, 1, 3, 2],\n    [2, 2, 1, 2, 3, 1],\n    [2, 1, 3, 2, 1, 2],\n    [2, 2, 3, 1, 1, 2],\n    [3, 1, 2, 1, 3, 1],\n    [3, 1, 1, 2, 2, 2],\n    [3, 2, 1, 1, 2, 2],\n    [3, 2, 1, 2, 2, 1],\n    [3, 1, 2, 2, 1, 2],\n    [3, 2, 2, 1, 1, 2],\n    [3, 2, 2, 2, 1, 1],\n    [2, 1, 2, 1, 2, 3],\n    [2, 1, 2, 3, 2, 1],\n    [2, 3, 2, 1, 2, 1],\n    [1, 1, 1, 3, 2, 3],\n    [1, 3, 1, 1, 2, 3],\n    [1, 3, 1, 3, 2, 1],\n    [1, 1, 2, 3, 1, 3],\n    [1, 3, 2, 1, 1, 3],\n    [1, 3, 2, 3, 1, 1],\n    [2, 1, 1, 3, 1, 3],\n    [2, 3, 1, 1, 1, 3],\n    [2, 3, 1, 3, 1, 1],\n    [1, 1, 2, 1, 3, 3],\n    [1, 1, 2, 3, 3, 1],\n    [1, 3, 2, 1, 3, 1],\n    [1, 1, 3, 1, 2, 3],\n    [1, 1, 3, 3, 2, 1],\n    [1, 3, 3, 1, 2, 1],\n    [3, 1, 3, 1, 2, 1],\n    [2, 1, 1, 3, 3, 1],\n    [2, 3, 1, 1, 3, 1],\n    [2, 1, 3, 1, 1, 3],\n    [2, 1, 3, 3, 1, 1],\n    [2, 1, 3, 1, 3, 1],\n    [3, 1, 1, 1, 2, 3],\n    [3, 1, 1, 3, 2, 1],\n    [3, 3, 1, 1, 2, 1],\n    [3, 1, 2, 1, 1, 3],\n    [3, 1, 2, 3, 1, 1],\n    [3, 3, 2, 1, 1, 1],\n    [3, 1, 4, 1, 1, 1],\n    [2, 2, 1, 4, 1, 1],\n    [4, 3, 1, 1, 1, 1],\n    [1, 1, 1, 2, 2, 4],\n    [1, 1, 1, 4, 2, 2],\n    [1, 2, 1, 1, 2, 4],\n    [1, 2, 1, 4, 2, 1],\n    [1, 4, 1, 1, 2, 2],\n    [1, 4, 1, 2, 2, 1],\n    [1, 1, 2, 2, 1, 4],\n    [1, 1, 2, 4, 1, 2],\n    [1, 2, 2, 1, 1, 4],\n    [1, 2, 2, 4, 1, 1],\n    [1, 4, 2, 1, 1, 2],\n    [1, 4, 2, 2, 1, 1],\n    [2, 4, 1, 2, 1, 1],\n    [2, 2, 1, 1, 1, 4],\n    [4, 1, 3, 1, 1, 1],\n    [2, 4, 1, 1, 1, 2],\n    [1, 3, 4, 1, 1, 1],\n    [1, 1, 1, 2, 4, 2],\n    [1, 2, 1, 1, 4, 2],\n    [1, 2, 1, 2, 4, 1],\n    [1, 1, 4, 2, 1, 2],\n    [1, 2, 4, 1, 1, 2],\n    [1, 2, 4, 2, 1, 1],\n    [4, 1, 1, 2, 1, 2],\n    [4, 2, 1, 1, 1, 2],\n    [4, 2, 1, 2, 1, 1],\n    [2, 1, 2, 1, 4, 1],\n    [2, 1, 4, 1, 2, 1],\n    [4, 1, 2, 1, 2, 1],\n    [1, 1, 1, 1, 4, 3],\n    [1, 1, 1, 3, 4, 1],\n    [1, 3, 1, 1, 4, 1],\n    [1, 1, 4, 1, 1, 3],\n    [1, 1, 4, 3, 1, 1],\n    [4, 1, 1, 1, 1, 3],\n    [4, 1, 1, 3, 1, 1],\n    [1, 1, 3, 1, 4, 1],\n    [1, 1, 4, 1, 3, 1],\n    [3, 1, 1, 1, 4, 1],\n    [4, 1, 1, 1, 3, 1],\n    [2, 1, 1, 4, 1, 2],\n    [2, 1, 1, 2, 1, 4],\n    [2, 1, 1, 2, 3, 2],\n    [2, 3, 3, 1, 1, 1, 2]\n];\nconst MODULE_INDICES = { bar: [0, 2, 4], space: [1, 3, 5] };\n\nexport class Code128Reader extends BarcodeReader {\n    constructor() {\n        super();\n\n        this._format = 'code_128';\n        this._singleCodeError = 0.64;\n        this._averageCodeError = 0.30;\n    }\n\n    protected _decodeCode(start: number, correction: BarcodeCorrection): BarcodeInfo {\n        const counter = [0, 0, 0, 0, 0, 0];\n        const offset = start;\n        const bestMatch: BarcodeInfo = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: start,\n            end: start,\n            correction: {\n                bar: 1,\n                space: 1\n            }\n        };\n        const epsilon = this.AVERAGE_CODE_ERROR;\n        let isWhite: 0 | 1 = this._row[offset] ? 0 : 1;\n        let counterPos = 0;\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    if (correction) {\n                        this._correct(counter, correction);\n                    }\n\n                    for (let code = 0; code < CODE_PATTERN.length; code++) {\n                        const error = this._matchPattern(counter, CODE_PATTERN[code]);\n                        if (error < bestMatch.error) {\n                            bestMatch.code = code;\n                            bestMatch.error = error;\n                        }\n                    }\n\n                    bestMatch.end = i;\n\n                    if (bestMatch.code === -1 || bestMatch.error > epsilon) {\n                        return null;\n                    }\n\n                    const expected = CODE_PATTERN[bestMatch.code];\n                    if (expected) {\n                        bestMatch.correction.bar = this._calculateCorrection(expected, counter, MODULE_INDICES.bar);\n                        bestMatch.correction.space = this._calculateCorrection(expected, counter, MODULE_INDICES.space);\n                    }\n\n                    return bestMatch;\n                } else {\n                    counterPos++;\n                }\n\n                counter[counterPos] = 1;\n                isWhite = isWhite ? 0 : 1;\n            }\n        }\n\n        return null;\n    }\n\n    private _correct(counter: Array<number>, correction: BarcodeCorrection): void {\n        this._correctBars(counter, correction.bar, MODULE_INDICES.bar);\n        this._correctBars(counter, correction.space, MODULE_INDICES.space);\n    }\n\n    protected _findStart() {\n        const counter = [0, 0, 0, 0, 0, 0];\n        const offset = this._nextSet(this._row);\n        const bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0,\n            correction: {\n                bar: 1,\n                space: 1\n            }\n        };\n        const epsilon = this.AVERAGE_CODE_ERROR;\n        let isWhite: 0 | 1 = 0;\n        let counterPos = 0;\n        let sum: number;\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    sum = 0;\n                    for (let j = 0; j < counter.length; j++) {\n                        sum += counter[j];\n                    }\n                    for (let code = START_CODE_A; code <= START_CODE_C; code++) {\n                        const error = this._matchPattern(counter, CODE_PATTERN[code]);\n                        if (error < bestMatch.error) {\n                            bestMatch.code = code;\n                            bestMatch.error = error;\n                        }\n                    }\n                    if (bestMatch.error < epsilon) {\n                        bestMatch.start = i - sum;\n                        bestMatch.end = i;\n                        bestMatch.correction.bar = this._calculateCorrection(CODE_PATTERN[bestMatch.code], counter,\n                            MODULE_INDICES.bar);\n                        bestMatch.correction.space = this._calculateCorrection(CODE_PATTERN[bestMatch.code], counter,\n                            MODULE_INDICES.space);\n                        return bestMatch;\n                    }\n\n                    for (let j = 0; j < 4; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[4] = 0;\n                    counter[5] = 0;\n                    counterPos--;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = isWhite ? 0 : 1;\n            }\n        }\n\n        return null;\n    }\n\n    decode(): Barcode {\n        const result = new Array<string | number>();\n        const startInfo = this._findStart();\n        let code: BarcodeInfo = null;\n        let done = false;\n        let multiplier = 0;\n        let checksum = 0;\n        let codeset: number;\n        let rawResult = new Array<number>();\n        let decodedCodes = new Array<BarcodeInfo>();\n        let shiftNext = false;\n        let unshift: boolean;\n        let removeLastCharacter = true;\n\n        if (startInfo === null) {\n            return null;\n        }\n        code = {\n            code: startInfo.code,\n            start: startInfo.start,\n            end: startInfo.end,\n            correction: {\n                bar: startInfo.correction.bar,\n                space: startInfo.correction.space\n            }\n        };\n        decodedCodes.push(code);\n        checksum = code.code;\n\n        switch (code.code) {\n            case START_CODE_A:\n                codeset = CODE_A;\n                break;\n            case START_CODE_B:\n                codeset = CODE_B;\n                break;\n            case START_CODE_C:\n                codeset = CODE_C;\n                break;\n            default:\n                return null;\n        }\n\n        while (!done) {\n            unshift = shiftNext;\n            shiftNext = false;\n            code = this._decodeCode(code.end, code.correction);\n            if (code !== null) {\n                if (code.code !== STOP_CODE) {\n                    removeLastCharacter = true;\n                }\n\n                if (code.code !== STOP_CODE) {\n                    rawResult.push(code.code);\n                    multiplier++;\n                    checksum += multiplier * code.code;\n                }\n                decodedCodes.push(code);\n\n                switch (codeset) {\n                    case CODE_A: {\n                        if (code.code < 64) {\n                            result.push(String.fromCharCode(32 + code.code));\n                        } else if (code.code < 96) {\n                            result.push(String.fromCharCode(code.code - 64));\n                        } else {\n                            if (code.code !== STOP_CODE) {\n                                removeLastCharacter = false;\n                            }\n                            switch (code.code) {\n                                case CODE_SHIFT:\n                                    shiftNext = true;\n                                    codeset = CODE_B;\n                                    break;\n                                case CODE_B:\n                                    codeset = CODE_B;\n                                    break;\n                                case CODE_C:\n                                    codeset = CODE_C;\n                                    break;\n                                case STOP_CODE:\n                                    done = true;\n                                    break;\n                            }\n                        }\n                        break;\n                    }\n                    case CODE_B: {\n                        if (code.code < 96) {\n                            result.push(String.fromCharCode(32 + code.code));\n                        } else {\n                            if (code.code !== STOP_CODE) {\n                                removeLastCharacter = false;\n                            }\n                            switch (code.code) {\n                                case CODE_SHIFT:\n                                    shiftNext = true;\n                                    codeset = CODE_A;\n                                    break;\n                                case CODE_A:\n                                    codeset = CODE_A;\n                                    break;\n                                case CODE_C:\n                                    codeset = CODE_C;\n                                    break;\n                                case STOP_CODE:\n                                    done = true;\n                                    break;\n                            }\n                        }\n                        break;\n                    }\n                    case CODE_C: {\n                        if (code.code < 100) {\n                            result.push(code.code < 10 ? '0' + code.code : code.code);\n                        } else {\n                            if (code.code !== STOP_CODE) {\n                                removeLastCharacter = false;\n                            }\n                            switch (code.code) {\n                                case CODE_A:\n                                    codeset = CODE_A;\n                                    break;\n                                case CODE_B:\n                                    codeset = CODE_B;\n                                    break;\n                                case STOP_CODE:\n                                    done = true;\n                                    break;\n                            }\n                        }\n                        break;\n                    }\n                }\n            } else {\n                done = true;\n            }\n            if (unshift) {\n                codeset = codeset === CODE_A ? CODE_B : CODE_A;\n            }\n        }\n\n        if (code === null) {\n            return null;\n        }\n\n        code.end = this._nextUnset(this._row, code.end);\n        if (!this._verifyTrailingWhitespace(code)) {\n            return null;\n        }\n\n        checksum -= multiplier * rawResult[rawResult.length - 1];\n        if (checksum % 103 !== rawResult[rawResult.length - 1]) {\n            return null;\n        }\n\n        if (!result.length) {\n            return null;\n        }\n\n        // remove last code from result (checksum)\n        if (removeLastCharacter) {\n            result.splice(result.length - 1, 1);\n        }\n\n        return {\n            code: result.join(''),\n            start: startInfo.start,\n            end: code.end,\n            codeset,\n            startInfo,\n            decodedCodes,\n            endInfo: code\n        };\n    }\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodeInfo): BarcodeInfo {\n        const trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;\n\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n\n        return null;\n    }\n\n    private _calculateCorrection(\n        expected: ReadonlyArray<number>,\n        normalized: ReadonlyArray<number>,\n        indices: ReadonlyArray<number>\n    ): number {\n        let sumNormalized = 0;\n        let sumExpected = 0;\n\n        for (let length = indices.length; length--;) {\n            sumExpected += expected[indices[length]];\n            sumNormalized += normalized[indices[length]];\n        }\n\n        return sumExpected / sumNormalized;\n    }\n}\n","import { Barcode, BarcodeInfo, BarcodeReader } from './barcode-reader';\n\nconst ASTERISK = 0x094;\nconst ALPHABETH_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%';\nconst ALPHABET = new Uint16Array([...ALPHABETH_STRING].map(char => char.charCodeAt(0)));\n// const ALPHABET = [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78,\n//     79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 45, 46, 32, 42, 36, 47, 43, 37];\nconst CHARACTER_ENCODINGS = new Uint16Array([\n    0x034, 0x121, 0x061, 0x160, 0x031, 0x130, 0x070, 0x025, 0x124, 0x064, 0x109, 0x049, 0x148, 0x019, 0x118, 0x058,\n    0x00D, 0x10C, 0x04C, 0x01C, 0x103, 0x043, 0x142, 0x013, 0x112, 0x052, 0x007, 0x106, 0x046, 0x016, 0x181, 0x0C1,\n    0x1C0, 0x091, 0x190, 0x0D0, 0x085, 0x184, 0x0C4, 0x094, 0x0A8, 0x0A2, 0x08A, 0x02A\n]);\n\nexport class Code39Reader extends BarcodeReader {\n    constructor() {\n        super();\n\n        this._format = 'code_39';\n    }\n\n    decode(): Barcode {\n        const start = this._findStart();\n\n        if (!start) {\n            return null;\n        }\n\n        const result = new Array<string>();\n        let counters = new Uint16Array(9);\n        let decodedChar: string;\n        let lastStart: number;\n        let nextStart = this._nextSet(this._row, start.end);\n\n        do {\n            this._toCounters(nextStart, counters);\n            const pattern = this._toPattern(counters);\n            if (pattern < 0) {\n                return null;\n            }\n            decodedChar = this._patternToChar(pattern);\n            if (decodedChar === null) {\n                return null;\n            }\n            result.push(decodedChar);\n            lastStart = nextStart;\n            nextStart += counters.reduce((sum, item) => sum + item, 0);\n            nextStart = this._nextSet(this._row, nextStart);\n        } while (decodedChar !== '*');\n        result.pop();\n\n        if (!result.length) {\n            return null;\n        }\n\n        if (!this._verifyTrailingWhitespace(lastStart, nextStart, counters)) {\n            return null;\n        }\n\n        return {\n            code: result.join(''),\n            start: start.start,\n            end: nextStart,\n            startInfo: start,\n            decodedCodes: result\n        };\n    }\n\n    protected _patternToChar(pattern): string {\n        for (let i = 0; i < CHARACTER_ENCODINGS.length; i++) {\n            if (CHARACTER_ENCODINGS[i] === pattern) {\n                return String.fromCharCode(ALPHABET[i]);\n            }\n        }\n        return null;\n    }\n\n    private _verifyTrailingWhitespace(lastStart: number, nextStart: number, counters: Uint16Array): boolean {\n        const patternSize = counters.reduce((sum, item) => sum + item, 0);\n        const trailingWhitespaceEnd = nextStart - lastStart - patternSize;\n        return (trailingWhitespaceEnd * 3) >= patternSize;\n    }\n\n    private _findNextWidth(counters: Uint16Array, current: number): number {\n        let minWidth = Number.MAX_VALUE;\n\n        for (let i = 0; i < counters.length; i++) {\n            if (counters[i] < minWidth && counters[i] > current) {\n                minWidth = counters[i];\n            }\n        }\n\n        return minWidth;\n    }\n\n    private _toPattern(counters: Uint16Array): number {\n        const numCounters = counters.length;\n        let maxNarrowWidth = 0;\n        let numWideBars = numCounters;\n        let wideBarWidth = 0;\n        let pattern: number;\n\n        while (numWideBars > 3) {\n            maxNarrowWidth = this._findNextWidth(counters, maxNarrowWidth);\n            numWideBars = 0;\n            pattern = 0;\n            for (let i = 0; i < numCounters; i++) {\n                if (counters[i] > maxNarrowWidth) {\n                    pattern |= 1 << (numCounters - 1 - i);\n                    numWideBars++;\n                    wideBarWidth += counters[i];\n                }\n            }\n\n            if (numWideBars === 3) {\n                for (let i = 0; i < numCounters && numWideBars > 0; i++) {\n                    if (counters[i] > maxNarrowWidth) {\n                        numWideBars--;\n                        if ((counters[i] * 2) >= wideBarWidth) {\n                            return -1;\n                        }\n                    }\n                }\n                return pattern;\n            }\n        }\n        return -1;\n    }\n\n    protected _findStart(): BarcodeInfo {\n        const offset = this._nextSet(this._row);\n        let patternStart = offset;\n        const counter = new Uint16Array(9);\n        let counterPos = 0;\n        let isWhite: 0 | 1 = 0;\n        let whiteSpaceMustStart: number;\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    // find start pattern\n                    if (this._toPattern(counter) === ASTERISK) {\n                        whiteSpaceMustStart = Math.max(0, patternStart - ((i - patternStart) / 4)) | 0;\n                        if (this._matchRange(whiteSpaceMustStart, patternStart, 0)) {\n                            return {\n                                start: patternStart,\n                                end: i\n                            };\n                        }\n                    }\n\n                    patternStart += counter[0] + counter[1];\n                    for (let j = 0; j < 7; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[7] = 0;\n                    counter[8] = 0;\n                    counterPos--;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = isWhite ? 0 : 1;\n            }\n        }\n\n        return null;\n    }\n}\n","import { Barcode } from './barcode-reader';\nimport { Code39Reader } from './code-39-reader';\n\nexport class Code39VINReader extends Code39Reader {\n    constructor() {\n        super();\n\n        this._format = 'code_39_vin';\n    }\n\n    /**\n     * @borrows\n     * https://github.com/zxing/zxing/blob/master/core/src/main/java/com/google/zxing/client/result/VINResultParser.java\n     */\n    decode(): Barcode {\n        const result = super.decode();\n        if (!result) {\n            return null;\n        }\n\n        let code = result.code;\n\n        if (!code) {\n            return null;\n        }\n\n        code = code.replace(/[IOQ]/g, '');\n\n        if (!/[A-Z0-9]{17}/.test(code)) {\n            if (process.env.NODE_ENV !== 'production') {\n                console.log('Failed AZ09 pattern code:', code);\n            }\n            return null;\n        }\n\n        if (!this._checkChecksum(code)) {\n            return null;\n        }\n\n        result.code = code;\n        return result;\n    }\n\n    private _checkChecksum(code: string): boolean {\n        // TODO\n        return !!code;\n    }\n}\n","import { Barcode, BarcodeInfo, BarcodeReader } from './barcode-reader';\n\nconst ALPHABETH_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*';\nconst ALPHABET = new Uint16Array([...ALPHABETH_STRING].map(char => char.charCodeAt(0)));\nconst CHARACTER_ENCODINGS = new Uint16Array([\n    0x114, 0x148, 0x144, 0x142, 0x128, 0x124, 0x122, 0x150, 0x112, 0x10A, 0x1A8, 0x1A4, 0x1A2, 0x194, 0x192, 0x18A,\n    0x168, 0x164, 0x162, 0x134, 0x11A, 0x158, 0x14C, 0x146, 0x12C, 0x116, 0x1B4, 0x1B2, 0x1AC, 0x1A6, 0x196, 0x19A,\n    0x16C, 0x166, 0x136, 0x13A, 0x12E, 0x1D4, 0x1D2, 0x1CA, 0x16E, 0x176, 0x1AE, 0x126, 0x1DA, 0x1D6, 0x132, 0x15E\n]);\nconst ASTERISK = 0x15E;\n\nexport class Code93Reader extends BarcodeReader {\n    constructor() {\n        super();\n\n        this._format = 'code_93';\n    }\n\n    decode(): Barcode {\n        const start = this._findStart();\n\n        if (!start) {\n            return null;\n        }\n\n        let result = new Array<string>();\n        let counters = new Uint16Array(6);\n        let decodedChar: string;\n        let lastStart: number;\n        let nextStart = this._nextSet(this._row, start.end);\n\n        do {\n            this._toCounters(nextStart, counters);\n            const pattern = this._toPattern(counters);\n            if (pattern < 0) {\n                return null;\n            }\n            decodedChar = this._patternToChar(pattern);\n            if (decodedChar === null) {\n                return null;\n            }\n            result.push(decodedChar);\n            lastStart = nextStart;\n            nextStart += counters.reduce((sum, item) => sum + item, 0);\n            nextStart = this._nextSet(this._row, nextStart);\n        } while (decodedChar !== '*');\n        result.pop();\n\n        if (!result.length) {\n            return null;\n        }\n\n        if (!this._verifyEnd(lastStart, nextStart)) {\n            return null;\n        }\n\n        if (!this._verifyChecksums(result)) {\n            return null;\n        }\n\n        result = result.slice(0, result.length - 2);\n        if ((result = this._decodeExtended(result)) === null) {\n            return null;\n        }\n\n        return {\n            code: result.join(''),\n            start: start.start,\n            end: nextStart,\n            startInfo: start,\n            decodedCodes: result\n        };\n    }\n\n    protected _patternToChar(pattern: number): string {\n        for (let i = 0; i < CHARACTER_ENCODINGS.length; i++) {\n            if (CHARACTER_ENCODINGS[i] === pattern) {\n                return String.fromCharCode(ALPHABET[i]);\n            }\n        }\n        return null;\n    }\n\n    private _verifyEnd(lastStart: number, nextStart: number): boolean {\n        if (lastStart === nextStart || !this._row[nextStart]) {\n            return false;\n        }\n        return true;\n    }\n\n    private _toPattern(counters: Uint16Array): number {\n        const numCounters = counters.length;\n        let pattern = 0;\n        let sum = 0;\n        for (let i = 0; i < numCounters; i++) {\n            sum += counters[i];\n        }\n\n        for (let i = 0; i < numCounters; i++) {\n            let normalized = Math.round(counters[i] * 9 / sum);\n            if (normalized < 1 || normalized > 4) {\n                return -1;\n            }\n            if ((i & 1) === 0) {\n                for (let j = 0; j < normalized; j++) {\n                    pattern = (pattern << 1) | 1;\n                }\n            } else {\n                pattern <<= normalized;\n            }\n        }\n\n        return pattern;\n    }\n\n    private _findStart(): BarcodeInfo {\n        const counter = new Uint16Array(6);\n        const offset = this._nextSet(this._row);\n        let patternStart = offset;\n        let counterPos = 0;\n        let isWhite: 0 | 1 = 0;\n        let whiteSpaceMustStart: number;\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    // find start pattern\n                    if (this._toPattern(counter) === ASTERISK) {\n                        whiteSpaceMustStart = Math.max(0, patternStart - ((i - patternStart) / 4)) | 0;\n                        if (this._matchRange(whiteSpaceMustStart, patternStart, 0)) {\n                            return {\n                                start: patternStart,\n                                end: i\n                            };\n                        }\n                    }\n\n                    patternStart += counter[0] + counter[1];\n                    for (let j = 0; j < 4; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[4] = 0;\n                    counter[5] = 0;\n                    counterPos--;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = isWhite ? 0 : 1;\n            }\n        }\n\n        return null;\n    }\n\n    private _decodeExtended(charArray: Array<string>): Array<string> {\n        const length = charArray.length;\n        const result = new Array<string>();\n        for (let i = 0; i < length; i++) {\n            const char = charArray[i];\n            if (char >= 'a' && char <= 'd') {\n                if (i > (length - 2)) {\n                    return null;\n                }\n                const nextChar = charArray[++i];\n                const nextCharCode = nextChar.charCodeAt(0);\n                let decodedChar: string;\n                switch (char) {\n                    case 'a': {\n                        if (nextChar >= 'A' && nextChar <= 'Z') {\n                            decodedChar = String.fromCharCode(nextCharCode - 64);\n                        } else {\n                            return null;\n                        }\n                        break;\n                    }\n                    case 'b': {\n                        if (nextChar >= 'A' && nextChar <= 'E') {\n                            decodedChar = String.fromCharCode(nextCharCode - 38);\n                        } else if (nextChar >= 'F' && nextChar <= 'J') {\n                            decodedChar = String.fromCharCode(nextCharCode - 11);\n                        } else if (nextChar >= 'K' && nextChar <= 'O') {\n                            decodedChar = String.fromCharCode(nextCharCode + 16);\n                        } else if (nextChar >= 'P' && nextChar <= 'S') {\n                            decodedChar = String.fromCharCode(nextCharCode + 43);\n                        } else if (nextChar >= 'T' && nextChar <= 'Z') {\n                            decodedChar = String.fromCharCode(127);\n                        } else {\n                            return null;\n                        }\n                        break;\n                    }\n                    case 'c': {\n                        if (nextChar >= 'A' && nextChar <= 'O') {\n                            decodedChar = String.fromCharCode(nextCharCode - 32);\n                        } else if (nextChar === 'Z') {\n                            decodedChar = ':';\n                        } else {\n                            return null;\n                        }\n                        break;\n                    }\n                    case 'd': {\n                        if (nextChar >= 'A' && nextChar <= 'Z') {\n                            decodedChar = String.fromCharCode(nextCharCode + 32);\n                        } else {\n                            return null;\n                        }\n                        break;\n                    }\n                }\n                result.push(decodedChar);\n            } else {\n                result.push(char);\n            }\n        }\n        return result;\n    }\n\n    private _verifyChecksums(charArray: Array<string>): boolean {\n        return this._matchCheckChar(charArray, charArray.length - 2, 20)\n            && this._matchCheckChar(charArray, charArray.length - 1, 15);\n    }\n\n    private _matchCheckChar(charArray: Array<string>, index: number, maxWeight: number): boolean {\n        const arrayToCheck = charArray.slice(0, index);\n        const length = arrayToCheck.length;\n        const weightedSums = arrayToCheck.reduce((sum, char, i) => {\n            const weight = (((i * -1) + (length - 1)) % maxWeight) + 1;\n            const value = ALPHABET.indexOf(char.charCodeAt(0));\n            return sum + (weight * value);\n        }, 0);\n\n        const checkChar = ALPHABET[(weightedSums % 47)];\n        return checkChar === charArray[index].charCodeAt(0);\n    }\n}\n","import { Barcode, BarcodeInfo, BarcodeReader, BarcodeReaderConfig } from './barcode-reader';\nimport { EANReader } from './ean-reader';\n\nexport class EAN2Reader extends EANReader {\n    constructor(config?: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        super(config, supplements);\n\n        this._format = 'ean_2';\n    }\n\n    decode(row?: Array<number>, start?: number): Barcode {\n        const end = row.length;\n        const result = new Array<number>();\n        const decodedCodes = new Array<BarcodeInfo>();\n        let offset = start;\n        let codeFrequency = 0;\n        let code: BarcodeInfo;\n\n        this._row = row;\n\n        for (let i = 0; i < 2 && offset < end; i++) {\n            code = this._decodeCode(offset);\n            if (!code) {\n                return null;\n            }\n            decodedCodes.push(code);\n            result.push(code.code % 10);\n            if (code.code >= this.CODE_G_START) {\n                codeFrequency |= 1 << (1 - i);\n            }\n            if (i !== 1) {\n                offset = this._nextSet(this._row, code.end);\n                offset = this._nextUnset(this._row, offset);\n            }\n        }\n\n        if (result.length !== 2 || (parseInt(result.join('')) % 4) !== codeFrequency) {\n            return null;\n        }\n\n        return {\n            code: result.join(''),\n            decodedCodes,\n            end: code.end\n        };\n    }\n}\n","import { Barcode, BarcodeInfo, BarcodeReader, BarcodeReaderConfig } from './barcode-reader';\nimport { EANReader } from './ean-reader';\n\nexport class EAN5Reader extends EANReader {\n    get CHECK_DIGIT_ENCODINGS(): Array<number> {\n        return [24, 20, 18, 17, 12, 6, 3, 10, 9, 5];\n    }\n\n    constructor(config?: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        super(config, supplements);\n\n        this._format = 'ean_5';\n    }\n\n    decode(row?: Array<number>, start?: number): Barcode {\n        const end = row.length;\n        const result = new Array<number>();\n        const decodedCodes = new Array<BarcodeInfo>();\n        let codeFrequency = 0;\n        let offset = start;\n        let code: BarcodeInfo;\n\n        this._row = row;\n\n        for (let i = 0; i < 5 && offset < end; i++) {\n            code = this._decodeCode(offset);\n            if (!code) {\n                return null;\n            }\n            decodedCodes.push(code);\n            result.push(code.code % 10);\n            if (code.code >= this.CODE_G_START) {\n                codeFrequency |= 1 << (4 - i);\n            }\n            if (i !== 4) {\n                offset = this._nextSet(this._row, code.end);\n                offset = this._nextUnset(this._row, offset);\n            }\n        }\n\n        if (result.length !== 5) {\n            return null;\n        }\n\n        if (this._extensionChecksum(result) !== this._determineCheckDigit(codeFrequency)) {\n            return null;\n        }\n\n        return {\n            code: result.join(''),\n            decodedCodes,\n            end: code.end\n        };\n    }\n\n    private _determineCheckDigit(codeFrequency: number): number | null {\n        for (let i = 0; i < 10; i++) {\n            if (codeFrequency === this.CHECK_DIGIT_ENCODINGS[i]) {\n                return i;\n            }\n        }\n        return null;\n    }\n\n    private _extensionChecksum(result: Array<number>): number {\n        let length = result.length;\n        let sum = 0;\n\n        for (let i = length - 2; i >= 0; i -= 2) {\n            sum += result[i];\n        }\n        sum *= 3;\n        for (let i = length - 1; i >= 0; i -= 2) {\n            sum += result[i];\n        }\n        sum *= 3;\n\n        return sum % 10;\n    }\n}\n","import { BarcodeInfo, BarcodeReader, BarcodeReaderConfig } from './barcode-reader';\nimport { EANReader } from './ean-reader';\n\nexport class EAN8Reader extends EANReader {\n    constructor(config?: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        super(config, supplements);\n\n        this._format = 'ean_8';\n    }\n\n    protected _decodePayload(code: BarcodeInfo, result: Array<number>, decodedCodes: Array<BarcodeInfo>): BarcodeInfo {\n        for (let i = 0; i < 4; i++) {\n            code = this._decodeCode(code.end, this.CODE_G_START);\n            if (!code) {\n                return null;\n            }\n            result.push(code.code);\n            decodedCodes.push(code);\n        }\n\n        code = this._findPattern(this.MIDDLE_PATTERN, code.end, 1, false);\n\n        if (code === null) {\n            return null;\n        }\n\n        decodedCodes.push(code);\n\n        for (let i = 0; i < 4; i++) {\n            code = this._decodeCode(code.end, this.CODE_G_START);\n\n            if (!code) {\n                return null;\n            }\n\n            decodedCodes.push(code);\n            result.push(code.code);\n        }\n\n        return code;\n    }\n}\n","import { merge } from '../common/merge';\nimport { Barcode, BarcodeInfo, BarcodeReader, BarcodeReaderConfig } from './barcode-reader';\n\nconst EXTENSION_START_PATTERN = [1, 1, 2];\nconst CODE_PATTERN = [\n    [3, 2, 1, 1],\n    [2, 2, 2, 1],\n    [2, 1, 2, 2],\n    [1, 4, 1, 1],\n    [1, 1, 3, 2],\n    [1, 2, 3, 1],\n    [1, 1, 1, 4],\n    [1, 3, 1, 2],\n    [1, 2, 1, 3],\n    [3, 1, 1, 2],\n    [1, 1, 2, 3],\n    [1, 2, 2, 2],\n    [2, 2, 1, 2],\n    [1, 1, 4, 1],\n    [2, 3, 1, 1],\n    [1, 3, 2, 1],\n    [4, 1, 1, 1],\n    [2, 1, 3, 1],\n    [3, 1, 2, 1],\n    [2, 1, 1, 3]\n];\nconst CODE_FREQUENCY = [0, 11, 13, 14, 19, 25, 28, 21, 22, 26];\n\nexport class EANReader extends BarcodeReader {\n    get CODE_L_START(): number {\n        return 0;\n    }\n\n    get CODE_G_START(): number {\n        return 10;\n    }\n\n    get START_PATTERN(): Array<number> {\n        return [1, 1, 1];\n    }\n\n    get STOP_PATTERN(): Array<number> {\n        return [1, 1, 1];\n    }\n\n    get MIDDLE_PATTERN(): Array<number> {\n        return [1, 1, 1, 1, 1];\n    }\n\n    constructor(config?: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        super(merge({\n            supplements: [] // Allowed extensions to be decoded (2 and/or 5)\n        }, config), supplements);\n\n        this._format = 'ean_13';\n        this._singleCodeError = 0.70;\n        this._averageCodeError = 0.48;\n    }\n\n    protected _decodeCode(start: number, coderange?: number): BarcodeInfo {\n        const counter = [0, 0, 0, 0];\n        const offset = start;\n        const bestMatch: BarcodeInfo = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: start,\n            end: start\n        };\n        const epsilon = this.AVERAGE_CODE_ERROR;\n        let isWhite: 0 | 1 = this._row[offset] ? 0 : 1;\n        let counterPos = 0;\n\n        if (!coderange) {\n            coderange = CODE_PATTERN.length;\n        }\n\n        for (let i = offset; i < this._row.length; i++) {\n            if (this._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    for (let code = 0; code < coderange; code++) {\n                        const error = this._matchPattern(counter, CODE_PATTERN[code]);\n                        if (error < bestMatch.error) {\n                            bestMatch.code = code;\n                            bestMatch.error = error;\n                        }\n                    }\n                    bestMatch.end = i;\n                    if (bestMatch.error > epsilon) {\n                        return null;\n                    }\n                    return bestMatch;\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = isWhite ? 0 : 1;\n            }\n        }\n\n        return null;\n    }\n\n    protected _findStart(): BarcodeInfo {\n        let offset = this._nextSet(this._row);\n        let startInfo: BarcodeInfo;\n\n        while (!startInfo) {\n            startInfo = this._findPattern(this.START_PATTERN, offset, 0, true);\n\n            if (!startInfo) {\n                return null;\n            }\n\n            const leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);\n\n            if (leadingWhitespaceStart >= 0) {\n                if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                    return startInfo;\n                }\n            }\n\n            offset = startInfo.end;\n            startInfo = null;\n        }\n\n        return null;\n    }\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodeInfo): BarcodeInfo {\n        const trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);\n\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n\n        return null;\n    }\n\n    protected _findEnd(offset: number, isWhite: 0 | 1): BarcodeInfo {\n        const endInfo = this._findPattern(this.STOP_PATTERN, offset, isWhite, false);\n\n        return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;\n    }\n\n    private _calculateFirstDigit(codeFrequency: number): number | null {\n        for (let i = 0; i < CODE_FREQUENCY.length; i++) {\n            if (codeFrequency === CODE_FREQUENCY[i]) {\n                return i;\n            }\n        }\n        return null;\n    }\n\n    protected _decodePayload(code: BarcodeInfo, result: Array<number>, decodedCodes: Array<BarcodeInfo>): BarcodeInfo {\n        let codeFrequency = 0x0;\n\n        for (let i = 0; i < 6; i++) {\n            code = this._decodeCode(code.end);\n            if (!code) {\n                return null;\n            }\n            if (code.code >= this.CODE_G_START) {\n                code.code -= this.CODE_G_START;\n                codeFrequency |= 1 << (5 - i);\n            } else {\n                codeFrequency |= 0 << (5 - i);\n            }\n            result.push(code.code);\n            decodedCodes.push(code);\n        }\n\n        const firstDigit = this._calculateFirstDigit(codeFrequency);\n\n        if (firstDigit === null) {\n            return null;\n        }\n\n        result.unshift(firstDigit);\n\n        code = this._findPattern(this.MIDDLE_PATTERN, code.end, 1, false);\n\n        if (code === null) {\n            return null;\n        }\n\n        decodedCodes.push(code);\n\n        for (let i = 0; i < 6; i++) {\n            code = this._decodeCode(code.end, this.CODE_G_START);\n\n            if (!code) {\n                return null;\n            }\n\n            decodedCodes.push(code);\n            result.push(code.code);\n        }\n\n        return code;\n    }\n\n    decode(): Barcode {\n        const result = new Array<number>();\n        const decodedCodes = new Array<BarcodeInfo>();\n        let resultInfo: Barcode = {};\n        let startInfo = this._findStart();\n\n        if (!startInfo) {\n            return null;\n        }\n\n        let code: BarcodeInfo = {\n            code: startInfo.code,\n            start: startInfo.start,\n            end: startInfo.end\n        };\n        decodedCodes.push(code);\n\n        code = this._decodePayload(code, result, decodedCodes);\n\n        if (!code) {\n            return null;\n        }\n\n        code = this._findEnd(code.end, 0);\n\n        if (!code) {\n            return null;\n        }\n\n        decodedCodes.push(code);\n\n        // Checksum\n        if (!this._checksum(result)) {\n            return null;\n        }\n\n        if (this.supplements.length > 0) {\n            const supplement = this._decodeExtensions(code.end);\n            if (!supplement) {\n                return null;\n            }\n\n            const lastCode = supplement.decodedCodes[supplement.decodedCodes.length - 1] as BarcodeInfo;\n            const endInfo = {\n                start: lastCode.start + (((lastCode.end - lastCode.start) / 2) | 0),\n                end: lastCode.end\n            };\n\n            if (!this._verifyTrailingWhitespace(endInfo)) {\n                return null;\n            }\n\n            resultInfo = {\n                supplement,\n                code: result.join('') + supplement.code\n            };\n        }\n\n        return {\n            code: result.join(''),\n            start: startInfo.start,\n            end: code.end,\n            startInfo,\n            decodedCodes,\n            ...resultInfo\n        };\n    }\n\n    private _decodeExtensions(offset: number): Barcode {\n        const start = this._nextSet(this._row, offset);\n        const startInfo = this._findPattern(EXTENSION_START_PATTERN, start, 0, false);\n\n        if (startInfo === null) {\n            return null;\n        }\n\n        for (let i = 0; i < this.supplements.length; i++) {\n            let result = this.supplements[i].decode(this._row, startInfo.end);\n            if (result !== null) {\n                return {\n                    code: result.code,\n                    start,\n                    startInfo,\n                    end: result.end,\n                    decodedCodes: result.decodedCodes\n                };\n            }\n        }\n\n        return null;\n    }\n\n    protected _checksum(result: Array<number>): boolean {\n        let sum = 0;\n\n        for (let i = result.length - 2; i >= 0; i -= 2) {\n            sum += result[i];\n        }\n\n        sum *= 3;\n\n        for (let i = result.length - 1; i >= 0; i -= 2) {\n            sum += result[i];\n        }\n\n        return sum % 10 === 0;\n    }\n}","import { merge } from '../common/merge';\nimport { Barcode, BarcodeInfo, BarcodeReader, BarcodeReaderConfig } from './barcode-reader';\n\nconst N = 1;\nconst W = 3;\nconst START_PATTERN = [N, N, N, N];\nconst STOP_PATTERN = [N, N, W];\nconst CODE_PATTERN = [\n    [N, N, W, W, N],\n    [W, N, N, N, W],\n    [N, W, N, N, W],\n    [W, W, N, N, N],\n    [N, N, W, N, W],\n    [W, N, W, N, N],\n    [N, W, W, N, N],\n    [N, N, N, W, W],\n    [W, N, N, W, N],\n    [N, W, N, W, N]\n];\nconst MAX_CORRECTION_FACTOR = 5;\n\nexport class I2of5Reader extends BarcodeReader {\n    private _barSpaceRatio: [number, number];\n\n    constructor(config?: BarcodeReaderConfig) {\n        super(merge({\n            normalizeBarSpaceWidth: false // Normalize the width difference between bars and spaces\n        }, config));\n\n        this._barSpaceRatio = [1, 1];\n        this._format = 'i2of5';\n\n        if (this.config.normalizeBarSpaceWidth) {\n            this._singleCodeError = 0.38;\n            this._averageCodeError = 0.09;\n        } else {\n            this._singleCodeError = 0.78;\n            this._averageCodeError = 0.38;\n        }\n    }\n\n    decode(): Barcode {\n        const startInfo = this._findStart();\n\n        if (!startInfo) {\n            return null;\n        }\n\n        const endInfo = this._findEnd();\n\n        if (!endInfo) {\n            return null;\n        }\n\n        const counters = this._fillCounters(startInfo.end, endInfo.start, 0);\n\n        if (counters.length % 10 !== 0) {\n            return null;\n        }\n\n        const result = new Array<number>();\n        const decodedCodes = new Array<BarcodeInfo>();\n\n        decodedCodes.push(startInfo);\n\n        const code = this._decodePayload(counters, result, decodedCodes);\n\n        if (!code || result.length % 2 !== 0 || result.length < 6) {\n            return null;\n        }\n\n        decodedCodes.push(endInfo);\n\n        return {\n            code: result.join(''),\n            start: startInfo.start,\n            end: endInfo.end,\n            startInfo,\n            decodedCodes\n        };\n    }\n\n    protected _matchPattern(counter: Array<number>, code: ReadonlyArray<number>): number {\n        if (this.config.normalizeBarSpaceWidth) {\n            const counterSum: [number, number] = [0, 0];\n            const codeSum: [number, number] = [0, 0];\n            const correction: [number, number] = [0, 0];\n            const correctionRatio = MAX_CORRECTION_FACTOR;\n            const correctionRatioInverse = 1 / correctionRatio;\n\n            for (let i = 0; i < counter.length; i++) {\n                counterSum[i % 2] += counter[i];\n                codeSum[i % 2] += code[i];\n            }\n\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\n            for (let i = 0; i < counter.length; i++) {\n                counter[i] *= this._barSpaceRatio[i % 2];\n            }\n        }\n\n        return super._matchPattern(counter, code);\n    }\n\n    protected _findStart(): BarcodeInfo {\n        let offset = this._nextSet(this._row);\n        let startInfo: BarcodeInfo;\n\n        while (!startInfo) {\n            startInfo = this._findPattern(START_PATTERN, offset, 0, true);\n            if (!startInfo) {\n                return null;\n            }\n\n            const narrowBarWidth = (startInfo.end - startInfo.start) >> 2;\n            const leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10;\n\n            if (leadingWhitespaceStart >= 0) {\n                if (this._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                    return startInfo;\n                }\n            }\n\n            offset = startInfo.end;\n            startInfo = null;\n        }\n\n        return null;\n    }\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodeInfo): BarcodeInfo {\n        const trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;\n\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n\n        return null;\n    }\n\n    protected _findEnd(): BarcodeInfo {\n        this._row.reverse();\n\n        const endInfo = this._findPattern(STOP_PATTERN, undefined, 0, false);\n\n        this._row.reverse();\n\n        if (endInfo === null) {\n            return null;\n        }\n\n        // reverse numbers\n        const start = endInfo.start;\n        endInfo.start = this._row.length - endInfo.end;\n        endInfo.end = this._row.length - start;\n\n        return endInfo !== null ? this._verifyTrailingWhitespace(endInfo) : null;\n    }\n\n    protected _decodeCode(counter: Array<number>): BarcodeInfo {\n        const bestMatch: BarcodeInfo = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        };\n\n        for (let code = 0; code < CODE_PATTERN.length; code++) {\n            const error = this._matchPattern(counter, CODE_PATTERN[code]);\n            if (error < bestMatch.error) {\n                bestMatch.code = code;\n                bestMatch.error = error;\n            }\n        }\n\n        return bestMatch.error < this.AVERAGE_CODE_ERROR ? bestMatch : null;\n    }\n\n    protected _decodePayload(counters: ReadonlyArray<number>, result: Array<number>, decodedCodes: Array<BarcodeInfo>): [BarcodeInfo, BarcodeInfo] {\n        const counterLength = counters.length;\n        const counter0 = [0, 0, 0, 0, 0];\n        const counter1 = [0, 0, 0, 0, 0];\n        let code0: BarcodeInfo;\n        let code1: BarcodeInfo;\n        let pos = 0;\n\n        while (pos < counterLength) {\n            for (let i = 0; i < 5; i++) {\n                counter0[i] = counters[pos] * this._barSpaceRatio[0];\n                counter1[i] = counters[pos + 1] * this._barSpaceRatio[1];\n                pos += 2;\n            }\n\n            code0 = this._decodeCode(counter0);\n            if (!code0) {\n                return null;\n            }\n\n            code1 = this._decodeCode(counter1);\n            if (!code1) {\n                return null;\n            }\n\n            result.push(code0.code, code1.code);\n            decodedCodes.push(code0, code1);\n        }\n\n        return [code0, code1];\n    }\n}\n","import { Code128Reader } from './code-128-reader';\nimport { Code39Reader } from './code-39-reader';\nimport { Code39VINReader } from './code-39-vin-reader';\nimport { CodabarReader } from './codabar-reader';\nimport { EANReader } from './ean-reader';\nimport { EAN8Reader } from './ean-8-reader';\nimport { EAN2Reader } from './ean-2-reader';\nimport { EAN5Reader } from './ean-5-reader';\nimport { UPCReader } from './upc-reader';\nimport { UPCEReader } from './upc-e-reader';\nimport { I2of5Reader } from './i2of5-reader';\nimport { TwoOfFiveReader } from './2of5-reader';\nimport { Code93Reader } from './code-93-reader';\n\nexport const Readers = {\n    code_128_reader: Code128Reader,\n    ean_reader: EANReader,\n    ean_5_reader: EAN5Reader,\n    ean_2_reader: EAN2Reader,\n    ean_8_reader: EAN8Reader,\n    code_39_reader: Code39Reader,\n    code_39_vin_reader: Code39VINReader,\n    codabar_reader: CodabarReader,\n    upc_reader: UPCReader,\n    upc_e_reader: UPCEReader,\n    i2of5_reader: I2of5Reader,\n    '2of5_reader': TwoOfFiveReader,\n    code_93_reader: Code93Reader\n};\n","import { BarcodeInfo, BarcodeReader, BarcodeReaderConfig } from './barcode-reader';\nimport { EANReader } from './ean-reader';\n\nconst CODE_FREQUENCY = [[56, 52, 50, 49, 44, 38, 35, 42, 41, 37], [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]];\n\nexport class UPCEReader extends EANReader {\n    get STOP_PATTERN() {\n        return [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7];\n    }\n\n    constructor(config?: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        super(config, supplements);\n\n        this._format = 'upc_e';\n    }\n\n    protected _decodePayload(code: BarcodeInfo, result: Array<number>, decodedCodes: Array<BarcodeInfo>): BarcodeInfo {\n        let codeFrequency = 0x0;\n\n        for (let i = 0; i < 6; i++) {\n            code = this._decodeCode(code.end);\n            if (!code) {\n                return null;\n            }\n            if (code.code >= this.CODE_G_START) {\n                code.code = code.code - this.CODE_G_START;\n                codeFrequency |= 1 << (5 - i);\n            }\n            result.push(code.code);\n            decodedCodes.push(code);\n        }\n\n        if (!this._determineParity(codeFrequency, result)) {\n            return null;\n        }\n\n        return code;\n    }\n\n    private _determineParity(codeFrequency: number, result: Array<number>): boolean {\n        for (let nrSystem = 0; nrSystem < CODE_FREQUENCY.length; nrSystem++) {\n            for (let i = 0; i < CODE_FREQUENCY[nrSystem].length; i++) {\n                if (codeFrequency === CODE_FREQUENCY[nrSystem][i]) {\n                    result.unshift(nrSystem);\n                    result.push(i);\n                    return true;\n                }\n            }\n        }\n        return false;\n    }\n\n    private _convertToUPCA(result: Array<number>): Array<number> {\n        const lastDigit = result[result.length - 2];\n        let upca = [result[0]];\n\n        if (lastDigit <= 2) {\n            upca = upca.concat(result.slice(1, 3)).concat([lastDigit, 0, 0, 0, 0]).concat(result.slice(3, 6));\n        } else if (lastDigit === 3) {\n            upca = upca.concat(result.slice(1, 4)).concat([0, 0, 0, 0, 0]).concat(result.slice(4, 6));\n        } else if (lastDigit === 4) {\n            upca = upca.concat(result.slice(1, 5)).concat([0, 0, 0, 0, 0, result[5]]);\n        } else {\n            upca = upca.concat(result.slice(1, 6)).concat([0, 0, 0, 0, lastDigit]);\n        }\n\n        upca.push(result[result.length - 1]);\n        return upca;\n    }\n\n    protected _checksum(result: Array<number>): boolean {\n        return super._checksum(this._convertToUPCA(result));\n    }\n\n    protected _findEnd(offset: number, isWhite: 0 | 1) {\n        isWhite = 1;\n        return super._findEnd(offset, isWhite);\n    }\n\n    protected _verifyTrailingWhitespace(endInfo: BarcodeInfo): BarcodeInfo {\n        const trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;\n\n        if (trailingWhitespaceEnd < this._row.length) {\n            if (this._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n                return endInfo;\n            }\n        }\n\n        return null;\n    }\n}","import { Barcode, BarcodeReader, BarcodeReaderConfig } from './barcode-reader';\nimport { EANReader } from './ean-reader';\n\nexport class UPCReader extends EANReader {\n    constructor(config?: BarcodeReaderConfig, supplements?: Array<BarcodeReader>) {\n        super(config, supplements);\n\n        this._format = 'upc_a';\n    }\n\n    decode(): Barcode {\n        const result = super.decode();\n\n        if (result && result.code && result.code.length === 13 && result.code.charAt(0) === '0') {\n            result.code = result.code.substring(1);\n            return result;\n        }\n\n        return null;\n    }\n}"],"sourceRoot":""}