ul {
padding: 0;
margin: 0;
@@ -83,41 +113,41 @@
overflow-y: hidden;
white-space: nowrap;
}
-/* line 59, ../sass/_viewport.scss */
+
#result_strip > ul > li {
display: inline-block;
vertical-align: middle;
width: 160px;
}
-/* line 63, ../sass/_viewport.scss */
+
#result_strip > ul > li .thumbnail {
padding: 5px;
margin: 4px;
border: 1px dashed #CCC;
}
-/* line 68, ../sass/_viewport.scss */
+
#result_strip > ul > li .thumbnail img {
max-width: 140px;
}
-/* line 71, ../sass/_viewport.scss */
+
#result_strip > ul > li .thumbnail .caption {
white-space: normal;
}
-/* line 73, ../sass/_viewport.scss */
+
#result_strip > ul > li .thumbnail .caption h4 {
text-align: center;
word-wrap: break-word;
height: 40px;
margin: 0px;
}
-/* line 83, ../sass/_viewport.scss */
+
#result_strip > ul:after {
content: "";
display: table;
clear: both;
}
-/* line 7, ../sass/_overlay.scss */
+
.scanner-overlay {
display: none;
width: 640px;
@@ -133,21 +163,21 @@
-webkit-box-shadow: #333333 0px 4px 10px;
box-shadow: #333333 0px 4px 10px;
}
-/* line 20, ../sass/_overlay.scss */
+
.scanner-overlay > .header {
position: relative;
margin-bottom: 14px;
}
-/* line 23, ../sass/_overlay.scss */
+
.scanner-overlay > .header h4, .scanner-overlay > .header .close {
line-height: 16px;
}
-/* line 26, ../sass/_overlay.scss */
+
.scanner-overlay > .header h4 {
margin: 0px;
padding: 0px;
}
-/* line 30, ../sass/_overlay.scss */
+
.scanner-overlay > .header .close {
position: absolute;
right: 0px;
@@ -160,7 +190,7 @@
cursor: pointer;
}
-/* line 1, ../sass/_icons.scss */
+
i.icon-24-scan {
width: 24px;
height: 24px;
@@ -172,11 +202,8 @@ i.icon-24-scan {
vertical-align: text-top;
}
-@media (min-width: 604px) and (max-width: 1024px) {
- /* tablet styles */
-}
@media (max-width: 603px) {
- /* line 2, ../sass/phone/_core.scss */
+
#container {
width: 300px;
margin: 10px auto;
@@ -184,46 +211,58 @@ i.icon-24-scan {
-webkit-box-shadow: none;
box-shadow: none;
}
- /* line 9, ../sass/phone/_core.scss */
+
#container form.voucher-form input.voucher-code {
width: 180px;
}
}
@media (max-width: 603px) {
- /* line 5, ../sass/phone/_viewport.scss */
+
+ .reader-config-group {
+ width: 100%;
+ }
+
+ .reader-config-group label > span {
+ width: 50%;
+ }
+
+ .reader-config-group label > select, .reader-config-group label > input {
+ max-width: calc(50% - 2px);
+ }
+
#interactive.viewport {
width: 300px;
height: 300px;
overflow: hidden;
}
- /* line 11, ../sass/phone/_viewport.scss */
+
#interactive.viewport canvas, video {
margin-top: -50px;
width: 300px;
height: 400px;
}
- /* line 15, ../sass/phone/_viewport.scss */
+
#interactive.viewport canvas.drawingBuffer, video.drawingBuffer {
margin-left: -300px;
}
- /* line 20, ../sass/phone/_viewport.scss */
+
#result_strip {
margin-top: 5px;
padding-top: 5px;
}
- /* line 24, ../sass/phone/_viewport.scss */
+
#result_strip ul.thumbnails > li {
width: 150px;
}
- /* line 27, ../sass/phone/_viewport.scss */
+
#result_strip ul.thumbnails > li .thumbnail .imgWrapper {
width: 130px;
height: 130px;
overflow: hidden;
}
- /* line 31, ../sass/phone/_viewport.scss */
+
#result_strip ul.thumbnails > li .thumbnail .imgWrapper img {
margin-top: -25px;
width: 130px;
@@ -231,7 +270,7 @@ i.icon-24-scan {
}
}
@media (max-width: 603px) {
- /* line 8, ../sass/phone/_overlay.scss */
+
.overlay.scanner {
width: 640px;
height: 510px;
@@ -243,66 +282,17 @@ i.icon-24-scan {
-webkit-box-shadow: none;
box-shadow: none;
}
- /* line 17, ../sass/phone/_overlay.scss */
+
.overlay.scanner > .header {
margin-bottom: 14px;
}
- /* line 19, ../sass/phone/_overlay.scss */
+
.overlay.scanner > .header h4, .overlay.scanner > .header .close {
line-height: 16px;
}
- /* line 22, ../sass/phone/_overlay.scss */
+
.overlay.scanner > .header .close {
height: 16px;
width: 16px;
}
}
-/* line 15, ../sass/styles.scss */
-body {
- background-color: #FFF;
- margin: 0px;
- font-family: Ubuntu, sans-serif;
- color: #1e1e1e;
- font-weight: normal;
- padding-top: 0;
-}
-
-/* line 24, ../sass/styles.scss */
-h1, h2, h3, h4 {
- font-family: "Cabin Condensed", sans-serif;
-}
-
-/* line 28, ../sass/styles.scss */
-header {
- background: #FFC600;
- padding: 1em;
-}
-/* line 31, ../sass/styles.scss */
-header .headline {
- width: 640px;
- margin: 0 auto;
-}
-/* line 34, ../sass/styles.scss */
-header .headline h1 {
- color: #FFDD69;
- font-size: 3em;
- margin-bottom: 0;
-}
-/* line 39, ../sass/styles.scss */
-header .headline h2 {
- margin-top: 0.2em;
-}
-
-/* line 45, ../sass/styles.scss */
-footer {
- background: #0A4DB7;
- color: #6C9CE8;
- padding: 1em 2em 2em;
-}
-
-/* line 51, ../sass/styles.scss */
-#container {
- width: 640px;
- margin: 20px auto;
- padding: 10px;
-}
diff --git a/example/file_input.html b/example/file_input.html
index 3d25fb1..d45abd5 100644
--- a/example/file_input.html
+++ b/example/file_input.html
@@ -51,7 +51,9 @@
-
+
+
+
+
+
diff --git a/example/live_w_locator.js b/example/live_w_locator.js
index 412a14e..6477acf 100644
--- a/example/live_w_locator.js
+++ b/example/live_w_locator.js
@@ -2,7 +2,19 @@ $(function() {
var resultCollector = Quagga.ResultCollector.create({
capture: true,
capacity: 20,
- blacklist: [{code: "2167361334", format: "i2of5"}],
+ blacklist: [{
+ code: "WIWV8ETQZ1", format: "code_93"
+ }, {
+ code: "EH3C-%GU23RK3", format: "code_93"
+ }, {
+ code: "O308SIHQOXN5SA/PJ", format: "code_93"
+ }, {
+ code: "DG7Q$TV8JQ/EN", format: "code_93"
+ }, {
+ code: "VOFD1DB5A.1F6QU", format: "code_93"
+ }, {
+ code: "4SO64P4X8 U4YUU1T-", format: "code_93"
+ }],
filter: function(codeResult) {
// only store results which match this constraint
// e.g.: codeResult
@@ -19,12 +31,57 @@ $(function() {
}
//Quagga.registerResultCollector(resultCollector);
App.attachListeners();
+ App.checkCapabilities();
Quagga.start();
});
},
handleError: function(err) {
console.log(err);
},
+ checkCapabilities: function() {
+ var track = Quagga.CameraAccess.getActiveTrack();
+ var capabilities = {};
+ if (typeof track.getCapabilities === 'function') {
+ capabilities = track.getCapabilities();
+ }
+ this.applySettingsVisibility('zoom', capabilities.zoom);
+ this.applySettingsVisibility('torch', capabilities.torch);
+ },
+ updateOptionsForMediaRange: function(node, range) {
+ console.log('updateOptionsForMediaRange', node, range);
+ var NUM_STEPS = 6;
+ var stepSize = (range.max - range.min) / NUM_STEPS;
+ var option;
+ var value;
+ while (node.firstChild) {
+ node.removeChild(node.firstChild);
+ }
+ for (var i = 0; i <= NUM_STEPS; i++) {
+ value = range.min + (stepSize * i);
+ option = document.createElement('option');
+ option.value = value;
+ option.innerHTML = value;
+ node.appendChild(option);
+ }
+ },
+ applySettingsVisibility: function(setting, capability) {
+ // depending on type of capability
+ if (typeof capability === 'boolean') {
+ var node = document.querySelector('input[name="settings_' + setting + '"]');
+ if (node) {
+ node.parentNode.style.display = capability ? 'block' : 'none';
+ }
+ return;
+ }
+ if (window.MediaSettingsRange && capability instanceof window.MediaSettingsRange) {
+ var node = document.querySelector('select[name="settings_' + setting + '"]');
+ if (node) {
+ this.updateOptionsForMediaRange(node, capability);
+ node.parentNode.style.display = 'block';
+ }
+ return;
+ }
+ },
initCameraSelection: function(){
var streamLabel = Quagga.CameraAccess.getActiveStreamLabel();
@@ -104,6 +161,17 @@ $(function() {
$(".controls").off("click", "button.stop");
$(".controls .reader-config-group").off("change", "input, select");
},
+ applySetting: function(setting, value) {
+ var track = Quagga.CameraAccess.getActiveTrack();
+ if (track && typeof track.getCapabilities === 'function') {
+ switch (setting) {
+ case 'zoom':
+ return track.applyConstraints({advanced: [{zoom: parseFloat(value)}]});
+ case 'torch':
+ return track.applyConstraints({advanced: [{torch: !!value}]});
+ }
+ }
+ },
setState: function(path, value) {
var self = this;
@@ -111,6 +179,10 @@ $(function() {
value = self._accessByPath(self.inputMapper, path)(value);
}
+ if (path.startsWith('settings.')) {
+ var setting = path.substring(9);
+ return self.applySetting(setting, value);
+ }
self._accessByPath(self.state, path, value);
console.log(JSON.stringify(self.state));
@@ -169,7 +241,8 @@ $(function() {
patchSize: "medium",
halfSample: true
},
- numOfWorkers: 4,
+ numOfWorkers: 2,
+ frequency: 10,
decoder: {
readers : [{
format: "code_128_reader",
diff --git a/example/node-test-with-buffer.js b/example/node-test-with-buffer.js
new file mode 100644
index 0000000..585c992
--- /dev/null
+++ b/example/node-test-with-buffer.js
@@ -0,0 +1,27 @@
+var Quagga = require('../lib/quagga').default;
+
+var buffer = require('fs').readFileSync('../test/fixtures/code_128/image-001.jpg');
+
+decode(buffer);
+function decode(buff){
+ Quagga.decodeSingle({
+ src: buff,
+ numOfWorkers: 0,
+ inputStream: {
+ mime: "image/jpeg",
+ size: 800,
+ area: {
+ top: "10%",
+ right: "5%",
+ left: "5%",
+ bottom: "10%"
+ }
+ }
+ }, function(result) {
+ if (result.codeResult) {
+ console.log("result", result.codeResult.code);
+ } else {
+ console.log("not detected");
+ }
+ });
+}
diff --git a/example/sass/_icons.scss b/example/sass/_icons.scss
deleted file mode 100644
index 8e47dd5..0000000
--- a/example/sass/_icons.scss
+++ /dev/null
@@ -1,10 +0,0 @@
-i.icon-24-scan{
- width: 24px;
- height: 24px;
- background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6QzFFMjMzNTBFNjcwMTFFMkIzMERGOUMzMzEzM0E1QUMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6QzFFMjMzNTFFNjcwMTFFMkIzMERGOUMzMzEzM0E1QUMiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpDMUUyMzM0RUU2NzAxMUUyQjMwREY5QzMzMTMzQTVBQyIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpDMUUyMzM0RkU2NzAxMUUyQjMwREY5QzMzMTMzQTVBQyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PtQr90wAAAUuSURBVHjanFVLbFRVGP7ua97T9DGPthbamAYYBNSMVbBpjCliWWGIEBMWsnDJxkh8RDeEDW5MDGticMmGBWnSlRSCwgLFNkqmmrRIqzjTznTazkxn5s7c6/efzm0G0Jhwkj/nP+d/nv91tIWFBTQaDQWapkGW67p4ltUub5qmAi0UCqF/a/U2m81tpmddotwwDGSz2dzi4uKSaOucnJycGhsbe1XXdQiIIcdxEAgEtgXq9brySHCht79UXi/8QheawN27d385fPjwuEl6XyKR6LdtW7t06RLK5TKOHj2K/fv3Q87Dw8OYn5/HiRMnMDs7i5mZGQwODiqlPp8PuVwO6XRaOXb16lXl1OnTp5FMJvtosF8M+MWLarWqGJaWlpBKpRRcu3YN4+PjmJ6exsTEhDJw5coVjI6OKgPhcBiZTAbxeBx+vx+XL19Gd3c3Tp48Ka9zqDYgBlTQxYNgMIhIJKLCILkQb+TZsgvdsiyFi+feWRR7oRNZyanQtvW2V4DEUUBiK2eJpeDirSyhCe7F2QPh8fiEp72i9PbsC5G52DbiKZA771yr1dTuGfJ4PQNPFoAyQNR1aNEmsS5eyB3PgjeooMZd2AWvNmzYci/Gea7TeFOcI93jV/K67noGmi4vdRI9gPSDeMLSdKUBZZczlWm1rTtHjLZ24d+WER2tc8N1m+Y+ID74wx0zGYvhg9UNrJdtHJyZRdQfwPsrq9g99xsGlgsYmr6BNzO/IVwsYfjBQ6XYz6JI/72MV366B5/lw0elOkJWGUM3bmKtWjXSLuLaBWhnPnnp0FfoiFi4+TMfVAb2poBkDLjO845uYLEAjL4ALGWBP5YAOsP4AJYBFDaB1HOSVWD2PuV95H2RdV93Lv74/cf6p6Zxq/h6OofeOPJBC39JtONdwOAAViOs4p4OFGTf0Uc8iiyrr9YdQrUnDLsngrVOC0jQib44HlF2RafRZBz1Qy+vfhgK3NJZBlrm+LEm9qWwzFgLU7Ozg0JxZP06jQSRpQ7EerAWDSt6PuhHPmChEAog56fCLvJT5hHTm3OZkz3DyLx7XNWTGEA1GkV14gjWgwbW0ESVjYRwCOuai03L5E7OUBAV4kXSS4auoGIaKOma4m8EA5R1sMEGLh95C+XuLph0WJWpxepYYLtfT0RRgY1KgNODY6BoaChRuEhDCIZQYseuki5KN6hcQHiq7OZNv4/Zq2O6P4Lfkwn46vZjjaYZrIpvWbpzjLErrc4xUGE4avRedpYJalRcIl5hQius/SrPm9xrNOQYJhao6BvNUeWqtY8KaWuNjHOFAr7mM9f4NA4UbKysoUJ8PV9UzVOx6wxDDWUOxnK1pmCD07fOMAvtIsM3l89Dl3HRGhVma9AZMqjOnz2LQqWCxs6dqr3T7x1DTzKJaG8SekcHhg4cgI/56uKdlKnBV/WndqN3YAB/7tyBd3oT6GBIOzs7kc/nDfFdDFT5bS73cp06dQoaPa/Rw/rtO/resTHxxE2m9rCrbSR27UJCcMf1BpiA5rAAGgdfc868fUR1sMwj0cm9Iu9IctweisViB3hhKTHDcHc5jv/LspbyaZrR1OD82/fIlOkuB9LnEWRmDX2TsddUPg3D5gvuc0je0rZaD5EW6G3yjS+A3eeBEWq3XW/Abw1HhUspXADufQb86oW7tZytkYCN//3hHwBvDALPi8EnSOYK8DAOfCc2h4aGcO7cuafkzampqf9UripH12/DtOZbx8ciVGzYy5OO40o25ascGRl5Ssc/AgwAjW3JwqIUjSYAAAAASUVORK5CYII=");
- display: inline-block;
- background-repeat: no-repeat;
- line-height: 24px;
- margin-top: 1px;
- vertical-align: text-top;
-}
diff --git a/example/sass/_overlay.scss b/example/sass/_overlay.scss
deleted file mode 100644
index 1de596b..0000000
--- a/example/sass/_overlay.scss
+++ /dev/null
@@ -1,48 +0,0 @@
-$overlayWidth: $videoWidth;
-$overlayHeadline: 16px;
-$overlayHeadlineMargin: 14px;
-$overlayPadding: 20px;
-$overlayHeight: $videoHeight + $overlayHeadlineMargin + $overlayHeadline;
-
-.scanner-overlay {
- display: none;
- width: $overlayWidth;
- height: $overlayHeight;
- position: absolute;
- padding: $overlayPadding;
- top: 50%;
- margin-top: -($overlayHeight)/2 - $overlayPadding;
- left: 50%;
- margin-left: -($overlayWidth + 2*$overlayPadding)/2;
- background-color: $overlayBackground;
- @include box-shadow(#333333 0px 4px 10px);
-
- & > .header{
- position: relative;
- margin-bottom: $overlayHeadlineMargin;
- h4, .close{
- line-height: $overlayHeadline;
- }
- h4{
- margin: 0px;
- padding: 0px;
- }
- .close{
- position: absolute;
- right: 0px;
- top: 0px;
- height: $overlayHeadline;
- width: $overlayHeadline;
- text-align: center;
- font-weight: bold;
- font-size: 14px;
- cursor: pointer;
- }
- }
-
- & > .body{
-
-
-
- }
-}
diff --git a/example/sass/_phone.scss b/example/sass/_phone.scss
deleted file mode 100644
index e634c4d..0000000
--- a/example/sass/_phone.scss
+++ /dev/null
@@ -1,3 +0,0 @@
-@import "phone/core";
-@import "phone/viewport";
-@import "phone/overlay";
\ No newline at end of file
diff --git a/example/sass/_tablet.scss b/example/sass/_tablet.scss
deleted file mode 100644
index fe679f1..0000000
--- a/example/sass/_tablet.scss
+++ /dev/null
@@ -1,4 +0,0 @@
-@include tablet {
- /* tablet styles */
-
-}
\ No newline at end of file
diff --git a/example/sass/_utility.scss b/example/sass/_utility.scss
deleted file mode 100644
index bc0d56d..0000000
--- a/example/sass/_utility.scss
+++ /dev/null
@@ -1,17 +0,0 @@
-$tablet_upper: 1024px;
-$phone_upper: 603px;
-
-@mixin phone {
- @media (max-width: $phone_upper) {
- @content;
- }
-
-} // @mixin phone
-
-@mixin tablet {
-
- @media (min-width: $phone_upper+1) and (max-width: $tablet_upper) {
- @content;
- }
-
-} // @mixin tablet
\ No newline at end of file
diff --git a/example/sass/_variables.scss b/example/sass/_variables.scss
deleted file mode 100644
index 785728a..0000000
--- a/example/sass/_variables.scss
+++ /dev/null
@@ -1,7 +0,0 @@
-$background_color: #FFF;
-$overlayBackground: #FFF;
-$videoWidth: 640px;
-$videoHeight: 480px;
-
-$text-font: Ubuntu, sans-serif;
-$header-font: 'Cabin Condensed', sans-serif;
\ No newline at end of file
diff --git a/example/sass/_viewport.scss b/example/sass/_viewport.scss
deleted file mode 100644
index f0d085b..0000000
--- a/example/sass/_viewport.scss
+++ /dev/null
@@ -1,89 +0,0 @@
-#interactive.viewport{
- width: $videoWidth;
- height: $videoHeight;
-}
-
-#interactive.viewport canvas, video{
- float: left;
- width: $videoWidth;
- height: $videoHeight;
- &.drawingBuffer{
- margin-left: -$videoWidth;
- }
-}
-
-.controls {
- fieldset {
- border: none;
- }
- .input-group {
- float: left;
- input, button {
- display: block;
- }
- }
- .reader-config-group {
- float: right;
-
- label {
- display: block;
- span {
- width: 11rem;
- display: inline-block;
- text-align: right;
- }
- }
- }
- &:after {
- content:'';
- display: block;
- clear: both;
- }
-}
-
-#result_strip{
- margin: 10px 0;
- border-top: 1px solid #EEE;
- border-bottom: 1px solid #EEE;
- padding: 10px 0;
-
- & > ul {
- padding: 0;
- margin: 0;
- list-style-type: none;
- width: auto;
- overflow-x: auto;
- overflow-y: hidden;
- white-space: nowrap;
-
- & > li{
- display: inline-block;
- vertical-align: middle;
- width: $videoWidth/4;
- .thumbnail{
- padding: 5px;
- margin: 4px;
- border: 1px dashed #CCC;
-
- img{
- max-width: $videoWidth/4 - 20px;
- }
- .caption{
- white-space: normal;
- h4{
- text-align: center;
- word-wrap: break-word;
- height: 40px;
- margin: 0px;
- }
- }
- }
- }
-
- &:after{
- content: "";
- display: table;
- clear: both;
- }
- }
-}
diff --git a/example/sass/colors.scss b/example/sass/colors.scss
deleted file mode 100644
index 1af8ab8..0000000
--- a/example/sass/colors.scss
+++ /dev/null
@@ -1,55 +0,0 @@
-/* LESS - http://lesscss.org style sheet */
-/* Palette color codes */
-/* Palette URL: http://paletton.com/#uid=31g0q0kHZAviRSkrHLOGomVNzac */
-
-/* Feel free to copy&paste color codes to your application */
-
-
-/* MIXINS */
-
-/* As hex codes */
-
-$color-primary-0: #FFC600; /* Main Primary color */
-$color-primary-1: #FFDD69;
-$color-primary-2: #FFCE22;
-$color-primary-3: #B78E00;
-$color-primary-4: #513F00;
-
-$color-secondary-1-0: #0A4DB7; /* Main Secondary color (1) */
-$color-secondary-1-1: #6C9CE8;
-$color-secondary-1-2: #2E6FD6;
-$color-secondary-1-3: #073379;
-$color-secondary-1-4: #021636;
-
-$color-secondary-2-0: #5809BB; /* Main Secondary color (2) */
-$color-secondary-2-1: #A36BE9;
-$color-secondary-2-2: #782DD8;
-$color-secondary-2-3: #3A077C;
-$color-secondary-2-4: #190237;
-
-
-
-/* As RGBa codes */
-
-$rgba-primary-0: rgba(255,198, 0,1); /* Main Primary color */
-$rgba-primary-1: rgba(255,221,105,1);
-$rgba-primary-2: rgba(255,206, 34,1);
-$rgba-primary-3: rgba(183,142, 0,1);
-$rgba-primary-4: rgba( 81, 63, 0,1);
-
-$rgba-secondary-1-0: rgba( 10, 77,183,1); /* Main Secondary color (1) */
-$rgba-secondary-1-1: rgba(108,156,232,1);
-$rgba-secondary-1-2: rgba( 46,111,214,1);
-$rgba-secondary-1-3: rgba( 7, 51,121,1);
-$rgba-secondary-1-4: rgba( 2, 22, 54,1);
-
-$rgba-secondary-2-0: rgba( 88, 9,187,1); /* Main Secondary color (2) */
-$rgba-secondary-2-1: rgba(163,107,233,1);
-$rgba-secondary-2-2: rgba(120, 45,216,1);
-$rgba-secondary-2-3: rgba( 58, 7,124,1);
-$rgba-secondary-2-4: rgba( 25, 2, 55,1);
-
-
-
-/* Generated by Paletton.com © 2002-2014 */
-/* http://paletton.com */
\ No newline at end of file
diff --git a/example/sass/fonts.scss b/example/sass/fonts.scss
deleted file mode 100644
index 2863604..0000000
--- a/example/sass/fonts.scss
+++ /dev/null
@@ -1 +0,0 @@
-@import url('http://fonts.googleapis.com/css?family=Ubuntu:400,700|Cabin+Condensed:400,600');
\ No newline at end of file
diff --git a/example/sass/phone/_core.scss b/example/sass/phone/_core.scss
deleted file mode 100644
index ce92a02..0000000
--- a/example/sass/phone/_core.scss
+++ /dev/null
@@ -1,15 +0,0 @@
-@include phone {
- #container{
- width: 300px;
- margin: 10px auto;
- @include box-shadow(none);
-
- form.voucher-form{
- input{
- &.voucher-code{
- width: 180px;
- }
- }
- }
- }
-}
diff --git a/example/sass/phone/_overlay.scss b/example/sass/phone/_overlay.scss
deleted file mode 100644
index 1251062..0000000
--- a/example/sass/phone/_overlay.scss
+++ /dev/null
@@ -1,28 +0,0 @@
-@include phone {
- $overlayWidth: $videoWidth;
- $overlayHeadline: 16px;
- $overlayHeadlineMargin: 14px;
- $overlayPadding: 20px;
- $overlayHeight: $videoHeight + $overlayHeadlineMargin + $overlayHeadline;
-
- .overlay.scanner {
- width: $overlayWidth;
- height: $overlayHeight;
- padding: $overlayPadding;
- margin-top: -($overlayHeight)/2 - $overlayPadding;
- margin-left: -($overlayWidth + 2*$overlayPadding)/2;
- background-color: $overlayBackground;
- @include box-shadow(none);
-
- & > .header{
- margin-bottom: $overlayHeadlineMargin;
- h4, .close{
- line-height: $overlayHeadline;
- }
- .close{
- height: $overlayHeadline;
- width: $overlayHeadline;
- }
- }
- }
-}
\ No newline at end of file
diff --git a/example/sass/phone/_viewport.scss b/example/sass/phone/_viewport.scss
deleted file mode 100644
index 5c861b5..0000000
--- a/example/sass/phone/_viewport.scss
+++ /dev/null
@@ -1,42 +0,0 @@
-@include phone {
- $videoWidth: 300px;
- $videoHeight: 400px;
-
- #interactive.viewport{
- width: $videoWidth;
- height: $videoWidth;
- overflow: hidden;
- }
-
- #interactive.viewport canvas, video{
- margin-top: ($videoWidth - $videoHeight)/2;
- width: $videoWidth;
- height: $videoHeight;
- &.drawingBuffer{
- margin-left: -$videoWidth;
- }
- }
-
- #result_strip{
- margin-top: 5px;
- padding-top: 5px;
- ul.thumbnails{
- & > li{
- width: $videoWidth/2;
- .thumbnail{
- .imgWrapper{
- width: $videoWidth/2 - 20px;
- height: $videoWidth/2 - 20px;
- overflow: hidden;
- img{
- margin-top: (($videoWidth/2 - 20px) - ($videoHeight/2 - 20px))/2;
- width: $videoWidth/2 - 20px;
- height: $videoHeight/2 - 20px;
- }
- }
-
- }
- }
- }
- }
-}
\ No newline at end of file
diff --git a/example/sass/scanner.scss b/example/sass/scanner.scss
deleted file mode 100644
index 223f093..0000000
--- a/example/sass/scanner.scss
+++ /dev/null
@@ -1,14 +0,0 @@
-
-@import "compass/css3";
-@import "variables";
-@import "utility";
-
-/* usual styles */
-
-@import "fonts";
-@import "viewport";
-@import "overlay";
-@import "icons";
-
-@import "tablet";
-@import "phone";
diff --git a/example/sass/styles.scss b/example/sass/styles.scss
deleted file mode 100644
index 5638d91..0000000
--- a/example/sass/styles.scss
+++ /dev/null
@@ -1,56 +0,0 @@
-@import "compass/css3";
-@import "variables";
-@import "utility";
-
-/* usual styles */
-@import "colors";
-@import "fonts";
-@import "viewport";
-@import "overlay";
-@import "icons";
-
-@import "tablet";
-@import "phone";
-
-body{
- background-color: #FFF;
- margin: 0px;
- font-family: $text-font;
- color: #1e1e1e;
- font-weight: normal;
- padding-top: 0;
-}
-
-h1,h2,h3,h4 {
- font-family: $header-font;
-}
-
-header {
- background: $color-primary-0;
- padding: 1em;
- .headline {
- width: 640px;
- margin: 0 auto;
- h1 {
- color: $color-primary-1;
- font-size: 3em;
- margin-bottom: 0;
- }
- h2 {
- margin-top: 0.2em;
- }
- }
-}
-
-footer {
- background: $color-secondary-1-0;
- color: $color-secondary-1-1;
- padding: 1em 2em 2em;
-}
-
-#container{
- width: 640px;
- margin: 20px auto;
- padding: 10px;
-}
-
diff --git a/example/static_images.html b/example/static_images.html
index 307c168..dfb4c31 100644
--- a/example/static_images.html
+++ b/example/static_images.html
@@ -45,6 +45,9 @@
+
+
+
diff --git a/karma-integration.conf.js b/karma-integration.conf.js
index 60a983d..1d7fe3a 100644
--- a/karma-integration.conf.js
+++ b/karma-integration.conf.js
@@ -14,6 +14,9 @@ module.exports = function(config) {
'test/test-main-integration.js': ['webpack']
},
webpack: {
+ entry: [
+ './src/quagga.js'
+ ],
module: {
loaders: [{
test: /\.jsx?$/,
@@ -45,7 +48,7 @@ module.exports = function(config) {
reporters: ['progress'],
port: 9876,
colors: true,
- logLevel: config.LOG_INFO,
+ logLevel: config.LOG_INFO, // LOG_DEBUG
autoWatch: true,
browsers: ['Chrome'],
singleRun: false
diff --git a/karma.conf.js b/karma.conf.js
index ce177aa..0601cd4 100644
--- a/karma.conf.js
+++ b/karma.conf.js
@@ -13,6 +13,9 @@ module.exports = function(config) {
'test/test-main.js': ['webpack']
},
webpack: {
+ entry: [
+ './src/quagga.js'
+ ],
module: {
loaders: [{
test: /\.jsx?$/,
diff --git a/lib/input_stream.js b/lib/input_stream.js
index 5829c62..8e481e8 100644
--- a/lib/input_stream.js
+++ b/lib/input_stream.js
@@ -24,7 +24,7 @@ InputStream.createImageStream = function() {
function loadImages() {
loaded = false;
- GetPixels(baseUrl, function(err, pixels) {
+ GetPixels(baseUrl, _config.mime, function(err, pixels) {
if (err) {
console.log(err);
exit(1);
diff --git a/lib/quagga.js b/lib/quagga.js
index 2a02ed4..6ca7143 100644
--- a/lib/quagga.js
+++ b/lib/quagga.js
@@ -7,7 +7,7 @@
exports["Quagga"] = factory(require("get-pixels"), require("ndarray"), require("ndarray-linear-interpolate"));
else
root["Quagga"] = factory(root["get-pixels"], root["ndarray"], root["ndarray-linear-interpolate"]);
-})(this, function(__WEBPACK_EXTERNAL_MODULE_162__, __WEBPACK_EXTERNAL_MODULE_163__, __WEBPACK_EXTERNAL_MODULE_164__) {
+})(this, function(__WEBPACK_EXTERNAL_MODULE_164__, __WEBPACK_EXTERNAL_MODULE_165__, __WEBPACK_EXTERNAL_MODULE_166__) {
return /******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
@@ -73,7 +73,7 @@ return /******/ (function(modules) { // webpackBootstrap
/******/ __webpack_require__.p = "/";
/******/
/******/ // Load entry module and return exports
-/******/ return __webpack_require__(__webpack_require__.s = 165);
+/******/ return __webpack_require__(__webpack_require__.s = 167);
/******/ })
/************************************************************************/
/******/ ([
@@ -115,38 +115,6 @@ module.exports = isObject;
/***/ }),
/* 1 */
-/***/ (function(module, exports) {
-
-/**
- * Checks if `value` is classified as an `Array` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an array, else `false`.
- * @example
- *
- * _.isArray([1, 2, 3]);
- * // => true
- *
- * _.isArray(document.body.children);
- * // => false
- *
- * _.isArray('abc');
- * // => false
- *
- * _.isArray(_.noop);
- * // => false
- */
-var isArray = Array.isArray;
-
-module.exports = isArray;
-
-
-/***/ }),
-/* 2 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -154,659 +122,821 @@ module.exports = isArray;
exports.__esModule = true;
-var _merge2 = __webpack_require__(28);
+var _array_helper = __webpack_require__(3);
-var _merge3 = _interopRequireDefault(_merge2);
+var _array_helper2 = _interopRequireDefault(_array_helper);
-var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-var _barcode_reader = __webpack_require__(5);
+function BarcodeReader(config, supplements) {
+ this._row = [];
+ this.config = config || {};
+ this.supplements = supplements;
+ return this;
+}
-var _barcode_reader2 = _interopRequireDefault(_barcode_reader);
+BarcodeReader.prototype._nextUnset = function (line, start) {
+ var i;
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ if (start === undefined) {
+ start = 0;
+ }
+ for (i = start; i < line.length; i++) {
+ if (!line[i]) {
+ return i;
+ }
+ }
+ return line.length;
+};
-function EANReader(opts, supplements) {
- opts = (0, _merge3.default)(getDefaulConfig(), opts);
- _barcode_reader2.default.call(this, opts, supplements);
-}
+BarcodeReader.prototype._matchPattern = function (counter, code, maxSingleError) {
+ var i,
+ error = 0,
+ singleError = 0,
+ sum = 0,
+ modulo = 0,
+ barWidth,
+ count,
+ scaled;
-function getDefaulConfig() {
- var config = {};
+ maxSingleError = maxSingleError || this.SINGLE_CODE_ERROR || 1;
- Object.keys(EANReader.CONFIG_KEYS).forEach(function (key) {
- config[key] = EANReader.CONFIG_KEYS[key].default;
- });
- return config;
-}
+ for (i = 0; i < counter.length; i++) {
+ sum += counter[i];
+ modulo += code[i];
+ }
+ if (sum < modulo) {
+ return Number.MAX_VALUE;
+ }
+ barWidth = sum / modulo;
+ maxSingleError *= barWidth;
-var properties = {
- CODE_L_START: { value: 0 },
- CODE_G_START: { value: 10 },
- START_PATTERN: { value: [1, 1, 1] },
- STOP_PATTERN: { value: [1, 1, 1] },
- MIDDLE_PATTERN: { value: [1, 1, 1, 1, 1] },
- EXTENSION_START_PATTERN: { value: [1, 1, 2] },
- CODE_PATTERN: { value: [[3, 2, 1, 1], [2, 2, 2, 1], [2, 1, 2, 2], [1, 4, 1, 1], [1, 1, 3, 2], [1, 2, 3, 1], [1, 1, 1, 4], [1, 3, 1, 2], [1, 2, 1, 3], [3, 1, 1, 2], [1, 1, 2, 3], [1, 2, 2, 2], [2, 2, 1, 2], [1, 1, 4, 1], [2, 3, 1, 1], [1, 3, 2, 1], [4, 1, 1, 1], [2, 1, 3, 1], [3, 1, 2, 1], [2, 1, 1, 3]] },
- CODE_FREQUENCY: { value: [0, 11, 13, 14, 19, 25, 28, 21, 22, 26] },
- SINGLE_CODE_ERROR: { value: 0.70 },
- AVG_CODE_ERROR: { value: 0.48 },
- FORMAT: { value: "ean_13", writeable: false }
+ for (i = 0; i < counter.length; i++) {
+ count = counter[i];
+ scaled = code[i] * barWidth;
+ singleError = Math.abs(count - scaled) / scaled;
+ if (singleError > maxSingleError) {
+ return Number.MAX_VALUE;
+ }
+ error += singleError;
+ }
+ return error / modulo;
};
-EANReader.prototype = Object.create(_barcode_reader2.default.prototype, properties);
-EANReader.prototype.constructor = EANReader;
+BarcodeReader.prototype._nextSet = function (line, offset) {
+ var i;
-EANReader.prototype._decodeCode = function (start, coderange) {
- var counter = [0, 0, 0, 0],
+ offset = offset || 0;
+ for (i = offset; i < line.length; i++) {
+ if (line[i]) {
+ return i;
+ }
+ }
+ return line.length;
+};
+
+BarcodeReader.prototype._correctBars = function (counter, correction, indices) {
+ var length = indices.length,
+ tmp = 0;
+ while (length--) {
+ tmp = counter[indices[length]] * (1 - (1 - correction) / 2);
+ if (tmp > 1) {
+ counter[indices[length]] = tmp;
+ }
+ }
+};
+
+BarcodeReader.prototype._matchTrace = function (cmpCounter, epsilon) {
+ var counter = [],
i,
self = this,
- offset = start,
+ offset = self._nextSet(self._row),
isWhite = !self._row[offset],
counterPos = 0,
bestMatch = {
error: Number.MAX_VALUE,
code: -1,
- start: start,
- end: start
+ start: 0
},
- code,
error;
- if (!coderange) {
- coderange = self.CODE_PATTERN.length;
- }
+ if (cmpCounter) {
+ for (i = 0; i < cmpCounter.length; i++) {
+ counter.push(0);
+ }
+ for (i = offset; i < self._row.length; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ if (counterPos === counter.length - 1) {
+ error = self._matchPattern(counter, cmpCounter);
- for (i = offset; i < self._row.length; i++) {
- if (self._row[i] ^ isWhite) {
- counter[counterPos]++;
- } else {
- if (counterPos === counter.length - 1) {
- for (code = 0; code < coderange; code++) {
- error = self._matchPattern(counter, self.CODE_PATTERN[code]);
- if (error < bestMatch.error) {
- bestMatch.code = code;
- bestMatch.error = error;
+ if (error < epsilon) {
+ bestMatch.start = i - offset;
+ bestMatch.end = i;
+ bestMatch.counter = counter;
+ return bestMatch;
+ } else {
+ return null;
}
+ } else {
+ counterPos++;
}
- bestMatch.end = i;
- if (bestMatch.error > self.AVG_CODE_ERROR) {
- return null;
- }
- return bestMatch;
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
+ }
+ }
+ } else {
+ counter.push(0);
+ for (i = offset; i < self._row.length; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
} else {
counterPos++;
+ counter.push(0);
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
}
- counter[counterPos] = 1;
- isWhite = !isWhite;
}
}
- return null;
+
+ // if cmpCounter was not given
+ bestMatch.start = offset;
+ bestMatch.end = self._row.length - 1;
+ bestMatch.counter = counter;
+ return bestMatch;
};
-EANReader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder, epsilon) {
- var counter = [],
- self = this,
- i,
- counterPos = 0,
- bestMatch = {
- error: Number.MAX_VALUE,
- code: -1,
- start: 0,
- end: 0
- },
- error,
- j,
- sum;
+BarcodeReader.prototype.decodePattern = function (pattern) {
+ var self = this,
+ result;
- if (!offset) {
- offset = self._nextSet(self._row);
+ self._row = pattern;
+ result = self._decode();
+ if (result === null) {
+ self._row.reverse();
+ result = self._decode();
+ if (result) {
+ result.direction = BarcodeReader.DIRECTION.REVERSE;
+ result.start = self._row.length - result.start;
+ result.end = self._row.length - result.end;
+ }
+ } else {
+ result.direction = BarcodeReader.DIRECTION.FORWARD;
}
-
- if (isWhite === undefined) {
- isWhite = false;
+ if (result) {
+ result.format = self.FORMAT;
}
+ return result;
+};
- if (tryHarder === undefined) {
- tryHarder = true;
- }
+BarcodeReader.prototype._matchRange = function (start, end, value) {
+ var i;
- if (epsilon === undefined) {
- epsilon = self.AVG_CODE_ERROR;
+ start = start < 0 ? 0 : start;
+ for (i = start; i < end; i++) {
+ if (this._row[i] !== value) {
+ return false;
+ }
}
+ return true;
+};
- for (i = 0; i < pattern.length; i++) {
- counter[i] = 0;
- }
+BarcodeReader.prototype._fillCounters = function (offset, end, isWhite) {
+ var self = this,
+ counterPos = 0,
+ i,
+ counters = [];
- for (i = offset; i < self._row.length; i++) {
+ isWhite = typeof isWhite !== 'undefined' ? isWhite : true;
+ offset = typeof offset !== 'undefined' ? offset : self._nextUnset(self._row);
+ end = end || self._row.length;
+
+ counters[counterPos] = 0;
+ for (i = offset; i < end; i++) {
if (self._row[i] ^ isWhite) {
- counter[counterPos]++;
+ counters[counterPos]++;
} else {
- if (counterPos === counter.length - 1) {
- sum = 0;
- for (j = 0; j < counter.length; j++) {
- sum += counter[j];
- }
- error = self._matchPattern(counter, pattern);
-
- if (error < epsilon) {
- bestMatch.error = error;
- bestMatch.start = i - sum;
- bestMatch.end = i;
- return bestMatch;
- }
- if (tryHarder) {
- for (j = 0; j < counter.length - 2; j++) {
- counter[j] = counter[j + 2];
- }
- counter[counter.length - 2] = 0;
- counter[counter.length - 1] = 0;
- counterPos--;
- } else {
- return null;
- }
- } else {
- counterPos++;
- }
- counter[counterPos] = 1;
+ counterPos++;
+ counters[counterPos] = 1;
isWhite = !isWhite;
}
}
- return null;
+ return counters;
};
-EANReader.prototype._findStart = function () {
+BarcodeReader.prototype._toCounters = function (start, counter) {
var self = this,
- leadingWhitespaceStart,
- offset = self._nextSet(self._row),
- startInfo;
+ numCounters = counter.length,
+ end = self._row.length,
+ isWhite = !self._row[start],
+ i,
+ counterPos = 0;
- while (!startInfo) {
- startInfo = self._findPattern(self.START_PATTERN, offset);
- if (!startInfo) {
- return null;
- }
- leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);
- if (leadingWhitespaceStart >= 0) {
- if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
- return startInfo;
+ _array_helper2.default.init(counter, 0);
+
+ for (i = start; i < end; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ counterPos++;
+ if (counterPos === numCounters) {
+ break;
+ } else {
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
}
}
- offset = startInfo.end;
- startInfo = null;
}
-};
-
-EANReader.prototype._verifyTrailingWhitespace = function (endInfo) {
- var self = this,
- trailingWhitespaceEnd;
- trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);
- if (trailingWhitespaceEnd < self._row.length) {
- if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
- return endInfo;
- }
- }
- return null;
+ return counter;
};
-EANReader.prototype._findEnd = function (offset, isWhite) {
- var self = this,
- endInfo = self._findPattern(self.STOP_PATTERN, offset, isWhite, false);
+Object.defineProperty(BarcodeReader.prototype, "FORMAT", {
+ value: 'unknown',
+ writeable: false
+});
- return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;
+BarcodeReader.DIRECTION = {
+ FORWARD: 1,
+ REVERSE: -1
};
-EANReader.prototype._calculateFirstDigit = function (codeFrequency) {
- var i,
- self = this;
-
- for (i = 0; i < self.CODE_FREQUENCY.length; i++) {
- if (codeFrequency === self.CODE_FREQUENCY[i]) {
- return i;
- }
- }
- return null;
+BarcodeReader.Exception = {
+ StartNotFoundException: "Start-Info was not found!",
+ CodeNotFoundException: "Code could not be found!",
+ PatternNotFoundException: "Pattern could not be found!"
};
-EANReader.prototype._decodePayload = function (code, result, decodedCodes) {
- var i,
- self = this,
- codeFrequency = 0x0,
- firstDigit;
-
- for (i = 0; i < 6; i++) {
- code = self._decodeCode(code.end);
- if (!code) {
- return null;
- }
- if (code.code >= self.CODE_G_START) {
- code.code = code.code - self.CODE_G_START;
- codeFrequency |= 1 << 5 - i;
- } else {
- codeFrequency |= 0 << 5 - i;
- }
- result.push(code.code);
- decodedCodes.push(code);
- }
+BarcodeReader.CONFIG_KEYS = {};
- firstDigit = self._calculateFirstDigit(codeFrequency);
- if (firstDigit === null) {
- return null;
- }
- result.unshift(firstDigit);
+exports.default = BarcodeReader;
- code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);
- if (code === null) {
- return null;
- }
- decodedCodes.push(code);
+/***/ }),
+/* 2 */
+/***/ (function(module, exports) {
- for (i = 0; i < 6; i++) {
- code = self._decodeCode(code.end, self.CODE_G_START);
- if (!code) {
- return null;
- }
- decodedCodes.push(code);
- result.push(code.code);
- }
+/**
+ * Checks if `value` is classified as an `Array` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an array, else `false`.
+ * @example
+ *
+ * _.isArray([1, 2, 3]);
+ * // => true
+ *
+ * _.isArray(document.body.children);
+ * // => false
+ *
+ * _.isArray('abc');
+ * // => false
+ *
+ * _.isArray(_.noop);
+ * // => false
+ */
+var isArray = Array.isArray;
- return code;
-};
+module.exports = isArray;
-EANReader.prototype._decode = function () {
- var startInfo,
- self = this,
- code,
- result = [],
- decodedCodes = [],
- resultInfo = {};
- startInfo = self._findStart();
- if (!startInfo) {
- return null;
- }
- code = {
- code: startInfo.code,
- start: startInfo.start,
- end: startInfo.end
- };
- decodedCodes.push(code);
- code = self._decodePayload(code, result, decodedCodes);
- if (!code) {
- return null;
- }
- code = self._findEnd(code.end, false);
- if (!code) {
- return null;
- }
+/***/ }),
+/* 3 */
+/***/ (function(module, exports, __webpack_require__) {
- decodedCodes.push(code);
+"use strict";
- // Checksum
- if (!self._checksum(result)) {
- return null;
- }
- if (this.supplements.length > 0) {
- var ext = this._decodeExtensions(code.end);
- if (!ext) {
- return null;
- }
- var lastCode = ext.decodedCodes[ext.decodedCodes.length - 1],
- endInfo = {
- start: lastCode.start + ((lastCode.end - lastCode.start) / 2 | 0),
- end: lastCode.end
- };
- if (!self._verifyTrailingWhitespace(endInfo)) {
- return null;
+exports.__esModule = true;
+exports.default = {
+ init: function init(arr, val) {
+ var l = arr.length;
+ while (l--) {
+ arr[l] = val;
}
- resultInfo = {
- supplement: ext,
- code: result.join("") + ext.code
- };
- }
-
- return _extends({
- code: result.join(""),
- start: startInfo.start,
- end: code.end,
- codeset: "",
- startInfo: startInfo,
- decodedCodes: decodedCodes
- }, resultInfo);
-};
+ },
-EANReader.prototype._decodeExtensions = function (offset) {
- var i,
- start = this._nextSet(this._row, offset),
- startInfo = this._findPattern(this.EXTENSION_START_PATTERN, start, false, false),
- result;
+ /**
+ * Shuffles the content of an array
+ * @return {Array} the array itself shuffled
+ */
+ shuffle: function shuffle(arr) {
+ var i = arr.length - 1,
+ j,
+ x;
+ for (i; i >= 0; i--) {
+ j = Math.floor(Math.random() * i);
+ x = arr[i];
+ arr[i] = arr[j];
+ arr[j] = x;
+ }
+ return arr;
+ },
- if (startInfo === null) {
- return null;
- }
+ toPointList: function toPointList(arr) {
+ var i,
+ j,
+ row = [],
+ rows = [];
+ for (i = 0; i < arr.length; i++) {
+ row = [];
+ for (j = 0; j < arr[i].length; j++) {
+ row[j] = arr[i][j];
+ }
+ rows[i] = "[" + row.join(",") + "]";
+ }
+ return "[" + rows.join(",\r\n") + "]";
+ },
- for (i = 0; i < this.supplements.length; i++) {
- result = this.supplements[i].decode(this._row, startInfo.end);
- if (result !== null) {
- return {
- code: result.code,
- start: start,
- startInfo: startInfo,
- end: result.end,
- codeset: "",
- decodedCodes: result.decodedCodes
- };
+ /**
+ * returns the elements which's score is bigger than the threshold
+ * @return {Array} the reduced array
+ */
+ threshold: function threshold(arr, _threshold, scoreFunc) {
+ var i,
+ queue = [];
+ for (i = 0; i < arr.length; i++) {
+ if (scoreFunc.apply(arr, [arr[i]]) >= _threshold) {
+ queue.push(arr[i]);
+ }
}
- }
- return null;
-};
+ return queue;
+ },
-EANReader.prototype._checksum = function (result) {
- var sum = 0,
- i;
+ maxIndex: function maxIndex(arr) {
+ var i,
+ max = 0;
+ for (i = 0; i < arr.length; i++) {
+ if (arr[i] > arr[max]) {
+ max = i;
+ }
+ }
+ return max;
+ },
- for (i = result.length - 2; i >= 0; i -= 2) {
- sum += result[i];
- }
- sum *= 3;
- for (i = result.length - 1; i >= 0; i -= 2) {
- sum += result[i];
- }
- return sum % 10 === 0;
-};
+ max: function max(arr) {
+ var i,
+ max = 0;
+ for (i = 0; i < arr.length; i++) {
+ if (arr[i] > max) {
+ max = arr[i];
+ }
+ }
+ return max;
+ },
-EANReader.CONFIG_KEYS = {
- supplements: {
- 'type': 'arrayOf(string)',
- 'default': [],
- 'description': 'Allowed extensions to be decoded (2 and/or 5)'
+ sum: function sum(arr) {
+ var length = arr.length,
+ sum = 0;
+
+ while (length--) {
+ sum += arr[length];
+ }
+ return sum;
}
};
-exports.default = EANReader;
-
/***/ }),
-/* 3 */
+/* 4 */
/***/ (function(module, exports, __webpack_require__) {
-var freeGlobal = __webpack_require__(38);
+"use strict";
-/** Detect free variable `self`. */
-var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
-/** Used as a reference to the global object. */
-var root = freeGlobal || freeSelf || Function('return this')();
+exports.__esModule = true;
-module.exports = root;
+var _merge2 = __webpack_require__(28);
+var _merge3 = _interopRequireDefault(_merge2);
-/***/ }),
-/* 4 */
-/***/ (function(module, exports) {
+var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
-/**
- * Checks if `value` is object-like. A value is object-like if it's not `null`
- * and has a `typeof` result of "object".
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
- * @example
- *
- * _.isObjectLike({});
- * // => true
- *
- * _.isObjectLike([1, 2, 3]);
- * // => true
- *
- * _.isObjectLike(_.noop);
- * // => false
- *
- * _.isObjectLike(null);
- * // => false
- */
-function isObjectLike(value) {
- return value != null && typeof value == 'object';
+var _barcode_reader = __webpack_require__(1);
+
+var _barcode_reader2 = _interopRequireDefault(_barcode_reader);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function EANReader(opts, supplements) {
+ opts = (0, _merge3.default)(getDefaulConfig(), opts);
+ _barcode_reader2.default.call(this, opts, supplements);
+}
+
+function getDefaulConfig() {
+ var config = {};
+
+ Object.keys(EANReader.CONFIG_KEYS).forEach(function (key) {
+ config[key] = EANReader.CONFIG_KEYS[key].default;
+ });
+ return config;
}
-module.exports = isObjectLike;
+var properties = {
+ CODE_L_START: { value: 0 },
+ CODE_G_START: { value: 10 },
+ START_PATTERN: { value: [1, 1, 1] },
+ STOP_PATTERN: { value: [1, 1, 1] },
+ MIDDLE_PATTERN: { value: [1, 1, 1, 1, 1] },
+ EXTENSION_START_PATTERN: { value: [1, 1, 2] },
+ CODE_PATTERN: { value: [[3, 2, 1, 1], [2, 2, 2, 1], [2, 1, 2, 2], [1, 4, 1, 1], [1, 1, 3, 2], [1, 2, 3, 1], [1, 1, 1, 4], [1, 3, 1, 2], [1, 2, 1, 3], [3, 1, 1, 2], [1, 1, 2, 3], [1, 2, 2, 2], [2, 2, 1, 2], [1, 1, 4, 1], [2, 3, 1, 1], [1, 3, 2, 1], [4, 1, 1, 1], [2, 1, 3, 1], [3, 1, 2, 1], [2, 1, 1, 3]] },
+ CODE_FREQUENCY: { value: [0, 11, 13, 14, 19, 25, 28, 21, 22, 26] },
+ SINGLE_CODE_ERROR: { value: 0.70 },
+ AVG_CODE_ERROR: { value: 0.48 },
+ FORMAT: { value: "ean_13", writeable: false }
+};
+
+EANReader.prototype = Object.create(_barcode_reader2.default.prototype, properties);
+EANReader.prototype.constructor = EANReader;
+
+EANReader.prototype._decodeCode = function (start, coderange) {
+ var counter = [0, 0, 0, 0],
+ i,
+ self = this,
+ offset = start,
+ isWhite = !self._row[offset],
+ counterPos = 0,
+ bestMatch = {
+ error: Number.MAX_VALUE,
+ code: -1,
+ start: start,
+ end: start
+ },
+ code,
+ error;
+
+ if (!coderange) {
+ coderange = self.CODE_PATTERN.length;
+ }
+
+ for (i = offset; i < self._row.length; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ if (counterPos === counter.length - 1) {
+ for (code = 0; code < coderange; code++) {
+ error = self._matchPattern(counter, self.CODE_PATTERN[code]);
+ if (error < bestMatch.error) {
+ bestMatch.code = code;
+ bestMatch.error = error;
+ }
+ }
+ bestMatch.end = i;
+ if (bestMatch.error > self.AVG_CODE_ERROR) {
+ return null;
+ }
+ return bestMatch;
+ } else {
+ counterPos++;
+ }
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
+ }
+ }
+ return null;
+};
+
+EANReader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder, epsilon) {
+ var counter = [],
+ self = this,
+ i,
+ counterPos = 0,
+ bestMatch = {
+ error: Number.MAX_VALUE,
+ code: -1,
+ start: 0,
+ end: 0
+ },
+ error,
+ j,
+ sum;
+
+ if (!offset) {
+ offset = self._nextSet(self._row);
+ }
+
+ if (isWhite === undefined) {
+ isWhite = false;
+ }
+
+ if (tryHarder === undefined) {
+ tryHarder = true;
+ }
+
+ if (epsilon === undefined) {
+ epsilon = self.AVG_CODE_ERROR;
+ }
+
+ for (i = 0; i < pattern.length; i++) {
+ counter[i] = 0;
+ }
+
+ for (i = offset; i < self._row.length; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ if (counterPos === counter.length - 1) {
+ sum = 0;
+ for (j = 0; j < counter.length; j++) {
+ sum += counter[j];
+ }
+ error = self._matchPattern(counter, pattern);
+
+ if (error < epsilon) {
+ bestMatch.error = error;
+ bestMatch.start = i - sum;
+ bestMatch.end = i;
+ return bestMatch;
+ }
+ if (tryHarder) {
+ for (j = 0; j < counter.length - 2; j++) {
+ counter[j] = counter[j + 2];
+ }
+ counter[counter.length - 2] = 0;
+ counter[counter.length - 1] = 0;
+ counterPos--;
+ } else {
+ return null;
+ }
+ } else {
+ counterPos++;
+ }
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
+ }
+ }
+ return null;
+};
+
+EANReader.prototype._findStart = function () {
+ var self = this,
+ leadingWhitespaceStart,
+ offset = self._nextSet(self._row),
+ startInfo;
+ while (!startInfo) {
+ startInfo = self._findPattern(self.START_PATTERN, offset);
+ if (!startInfo) {
+ return null;
+ }
+ leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);
+ if (leadingWhitespaceStart >= 0) {
+ if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
+ return startInfo;
+ }
+ }
+ offset = startInfo.end;
+ startInfo = null;
+ }
+};
-/***/ }),
-/* 5 */
-/***/ (function(module, exports, __webpack_require__) {
+EANReader.prototype._verifyTrailingWhitespace = function (endInfo) {
+ var self = this,
+ trailingWhitespaceEnd;
-"use strict";
+ trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);
+ if (trailingWhitespaceEnd < self._row.length) {
+ if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
+ return endInfo;
+ }
+ }
+ return null;
+};
+EANReader.prototype._findEnd = function (offset, isWhite) {
+ var self = this,
+ endInfo = self._findPattern(self.STOP_PATTERN, offset, isWhite, false);
-exports.__esModule = true;
-function BarcodeReader(config, supplements) {
- this._row = [];
- this.config = config || {};
- this.supplements = supplements;
- return this;
-}
+ return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;
+};
-BarcodeReader.prototype._nextUnset = function (line, start) {
- var i;
+EANReader.prototype._calculateFirstDigit = function (codeFrequency) {
+ var i,
+ self = this;
- if (start === undefined) {
- start = 0;
- }
- for (i = start; i < line.length; i++) {
- if (!line[i]) {
+ for (i = 0; i < self.CODE_FREQUENCY.length; i++) {
+ if (codeFrequency === self.CODE_FREQUENCY[i]) {
return i;
}
}
- return line.length;
+ return null;
};
-BarcodeReader.prototype._matchPattern = function (counter, code, maxSingleError) {
+EANReader.prototype._decodePayload = function (code, result, decodedCodes) {
var i,
- error = 0,
- singleError = 0,
- sum = 0,
- modulo = 0,
- barWidth,
- count,
- scaled;
+ self = this,
+ codeFrequency = 0x0,
+ firstDigit;
- maxSingleError = maxSingleError || this.SINGLE_CODE_ERROR || 1;
+ for (i = 0; i < 6; i++) {
+ code = self._decodeCode(code.end);
+ if (!code) {
+ return null;
+ }
+ if (code.code >= self.CODE_G_START) {
+ code.code = code.code - self.CODE_G_START;
+ codeFrequency |= 1 << 5 - i;
+ } else {
+ codeFrequency |= 0 << 5 - i;
+ }
+ result.push(code.code);
+ decodedCodes.push(code);
+ }
- for (i = 0; i < counter.length; i++) {
- sum += counter[i];
- modulo += code[i];
+ firstDigit = self._calculateFirstDigit(codeFrequency);
+ if (firstDigit === null) {
+ return null;
}
- if (sum < modulo) {
- return Number.MAX_VALUE;
+ result.unshift(firstDigit);
+
+ code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);
+ if (code === null) {
+ return null;
}
- barWidth = sum / modulo;
- maxSingleError *= barWidth;
+ decodedCodes.push(code);
- for (i = 0; i < counter.length; i++) {
- count = counter[i];
- scaled = code[i] * barWidth;
- singleError = Math.abs(count - scaled) / scaled;
- if (singleError > maxSingleError) {
- return Number.MAX_VALUE;
+ for (i = 0; i < 6; i++) {
+ code = self._decodeCode(code.end, self.CODE_G_START);
+ if (!code) {
+ return null;
}
- error += singleError;
+ decodedCodes.push(code);
+ result.push(code.code);
}
- return error / modulo;
+
+ return code;
};
-BarcodeReader.prototype._nextSet = function (line, offset) {
- var i;
+EANReader.prototype._decode = function () {
+ var startInfo,
+ self = this,
+ code,
+ result = [],
+ decodedCodes = [],
+ resultInfo = {};
- offset = offset || 0;
- for (i = offset; i < line.length; i++) {
- if (line[i]) {
- return i;
- }
+ startInfo = self._findStart();
+ if (!startInfo) {
+ return null;
}
- return line.length;
-};
-
-BarcodeReader.prototype._correctBars = function (counter, correction, indices) {
- var length = indices.length,
- tmp = 0;
- while (length--) {
- tmp = counter[indices[length]] * (1 - (1 - correction) / 2);
- if (tmp > 1) {
- counter[indices[length]] = tmp;
- }
+ code = {
+ code: startInfo.code,
+ start: startInfo.start,
+ end: startInfo.end
+ };
+ decodedCodes.push(code);
+ code = self._decodePayload(code, result, decodedCodes);
+ if (!code) {
+ return null;
+ }
+ code = self._findEnd(code.end, false);
+ if (!code) {
+ return null;
}
-};
-BarcodeReader.prototype._matchTrace = function (cmpCounter, epsilon) {
- var counter = [],
- i,
- self = this,
- offset = self._nextSet(self._row),
- isWhite = !self._row[offset],
- counterPos = 0,
- bestMatch = {
- error: Number.MAX_VALUE,
- code: -1,
- start: 0
- },
- error;
+ decodedCodes.push(code);
- if (cmpCounter) {
- for (i = 0; i < cmpCounter.length; i++) {
- counter.push(0);
- }
- for (i = offset; i < self._row.length; i++) {
- if (self._row[i] ^ isWhite) {
- counter[counterPos]++;
- } else {
- if (counterPos === counter.length - 1) {
- error = self._matchPattern(counter, cmpCounter);
+ // Checksum
+ if (!self._checksum(result)) {
+ return null;
+ }
- if (error < epsilon) {
- bestMatch.start = i - offset;
- bestMatch.end = i;
- bestMatch.counter = counter;
- return bestMatch;
- } else {
- return null;
- }
- } else {
- counterPos++;
- }
- counter[counterPos] = 1;
- isWhite = !isWhite;
- }
+ if (this.supplements.length > 0) {
+ var ext = this._decodeExtensions(code.end);
+ if (!ext) {
+ return null;
}
- } else {
- counter.push(0);
- for (i = offset; i < self._row.length; i++) {
- if (self._row[i] ^ isWhite) {
- counter[counterPos]++;
- } else {
- counterPos++;
- counter.push(0);
- counter[counterPos] = 1;
- isWhite = !isWhite;
- }
+ var lastCode = ext.decodedCodes[ext.decodedCodes.length - 1],
+ endInfo = {
+ start: lastCode.start + ((lastCode.end - lastCode.start) / 2 | 0),
+ end: lastCode.end
+ };
+ if (!self._verifyTrailingWhitespace(endInfo)) {
+ return null;
}
- }
-
- // if cmpCounter was not given
- bestMatch.start = offset;
- bestMatch.end = self._row.length - 1;
- bestMatch.counter = counter;
- return bestMatch;
+ resultInfo = {
+ supplement: ext,
+ code: result.join("") + ext.code
+ };
+ }
+
+ return _extends({
+ code: result.join(""),
+ start: startInfo.start,
+ end: code.end,
+ codeset: "",
+ startInfo: startInfo,
+ decodedCodes: decodedCodes
+ }, resultInfo);
};
-BarcodeReader.prototype.decodePattern = function (pattern) {
- var self = this,
+EANReader.prototype._decodeExtensions = function (offset) {
+ var i,
+ start = this._nextSet(this._row, offset),
+ startInfo = this._findPattern(this.EXTENSION_START_PATTERN, start, false, false),
result;
- self._row = pattern;
- result = self._decode();
- if (result === null) {
- self._row.reverse();
- result = self._decode();
- if (result) {
- result.direction = BarcodeReader.DIRECTION.REVERSE;
- result.start = self._row.length - result.start;
- result.end = self._row.length - result.end;
- }
- } else {
- result.direction = BarcodeReader.DIRECTION.FORWARD;
- }
- if (result) {
- result.format = self.FORMAT;
+ if (startInfo === null) {
+ return null;
}
- return result;
-};
-BarcodeReader.prototype._matchRange = function (start, end, value) {
- var i;
-
- start = start < 0 ? 0 : start;
- for (i = start; i < end; i++) {
- if (this._row[i] !== value) {
- return false;
+ for (i = 0; i < this.supplements.length; i++) {
+ result = this.supplements[i].decode(this._row, startInfo.end);
+ if (result !== null) {
+ return {
+ code: result.code,
+ start: start,
+ startInfo: startInfo,
+ end: result.end,
+ codeset: "",
+ decodedCodes: result.decodedCodes
+ };
}
}
- return true;
+ return null;
};
-BarcodeReader.prototype._fillCounters = function (offset, end, isWhite) {
- var self = this,
- counterPos = 0,
- i,
- counters = [];
+EANReader.prototype._checksum = function (result) {
+ var sum = 0,
+ i;
- isWhite = typeof isWhite !== 'undefined' ? isWhite : true;
- offset = typeof offset !== 'undefined' ? offset : self._nextUnset(self._row);
- end = end || self._row.length;
+ for (i = result.length - 2; i >= 0; i -= 2) {
+ sum += result[i];
+ }
+ sum *= 3;
+ for (i = result.length - 1; i >= 0; i -= 2) {
+ sum += result[i];
+ }
+ return sum % 10 === 0;
+};
- counters[counterPos] = 0;
- for (i = offset; i < end; i++) {
- if (self._row[i] ^ isWhite) {
- counters[counterPos]++;
- } else {
- counterPos++;
- counters[counterPos] = 1;
- isWhite = !isWhite;
- }
+EANReader.CONFIG_KEYS = {
+ supplements: {
+ 'type': 'arrayOf(string)',
+ 'default': [],
+ 'description': 'Allowed extensions to be decoded (2 and/or 5)'
}
- return counters;
};
-Object.defineProperty(BarcodeReader.prototype, "FORMAT", {
- value: 'unknown',
- writeable: false
-});
+exports.default = EANReader;
-BarcodeReader.DIRECTION = {
- FORWARD: 1,
- REVERSE: -1
-};
+/***/ }),
+/* 5 */
+/***/ (function(module, exports, __webpack_require__) {
-BarcodeReader.Exception = {
- StartNotFoundException: "Start-Info was not found!",
- CodeNotFoundException: "Code could not be found!",
- PatternNotFoundException: "Pattern could not be found!"
-};
+var freeGlobal = __webpack_require__(38);
-BarcodeReader.CONFIG_KEYS = {};
+/** Detect free variable `self`. */
+var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
+
+/** Used as a reference to the global object. */
+var root = freeGlobal || freeSelf || Function('return this')();
+
+module.exports = root;
-exports.default = BarcodeReader;
/***/ }),
/* 6 */
/***/ (function(module, exports) {
+/**
+ * Checks if `value` is object-like. A value is object-like if it's not `null`
+ * and has a `typeof` result of "object".
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
+ * @example
+ *
+ * _.isObjectLike({});
+ * // => true
+ *
+ * _.isObjectLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isObjectLike(_.noop);
+ * // => false
+ *
+ * _.isObjectLike(null);
+ * // => false
+ */
+function isObjectLike(value) {
+ return value != null && typeof value == 'object';
+}
+
+module.exports = isObjectLike;
+
+
+/***/ }),
+/* 7 */
+/***/ (function(module, exports) {
+
module.exports = clone
/**
@@ -823,12 +953,12 @@ function clone(a) {
}
/***/ }),
-/* 7 */
+/* 8 */
/***/ (function(module, exports, __webpack_require__) {
var Symbol = __webpack_require__(11),
- getRawTag = __webpack_require__(115),
- objectToString = __webpack_require__(142);
+ getRawTag = __webpack_require__(117),
+ objectToString = __webpack_require__(144);
/** `Object#toString` result references. */
var nullTag = '[object Null]',
@@ -850,107 +980,11 @@ function baseGetTag(value) {
}
return (symToStringTag && symToStringTag in Object(value))
? getRawTag(value)
- : objectToString(value);
-}
-
-module.exports = baseGetTag;
-
-
-/***/ }),
-/* 8 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-exports.__esModule = true;
-exports.default = {
- init: function init(arr, val) {
- var l = arr.length;
- while (l--) {
- arr[l] = val;
- }
- },
-
- /**
- * Shuffles the content of an array
- * @return {Array} the array itself shuffled
- */
- shuffle: function shuffle(arr) {
- var i = arr.length - 1,
- j,
- x;
- for (i; i >= 0; i--) {
- j = Math.floor(Math.random() * i);
- x = arr[i];
- arr[i] = arr[j];
- arr[j] = x;
- }
- return arr;
- },
-
- toPointList: function toPointList(arr) {
- var i,
- j,
- row = [],
- rows = [];
- for (i = 0; i < arr.length; i++) {
- row = [];
- for (j = 0; j < arr[i].length; j++) {
- row[j] = arr[i][j];
- }
- rows[i] = "[" + row.join(",") + "]";
- }
- return "[" + rows.join(",\r\n") + "]";
- },
-
- /**
- * returns the elements which's score is bigger than the threshold
- * @return {Array} the reduced array
- */
- threshold: function threshold(arr, _threshold, scoreFunc) {
- var i,
- queue = [];
- for (i = 0; i < arr.length; i++) {
- if (scoreFunc.apply(arr, [arr[i]]) >= _threshold) {
- queue.push(arr[i]);
- }
- }
- return queue;
- },
-
- maxIndex: function maxIndex(arr) {
- var i,
- max = 0;
- for (i = 0; i < arr.length; i++) {
- if (arr[i] > arr[max]) {
- max = i;
- }
- }
- return max;
- },
-
- max: function max(arr) {
- var i,
- max = 0;
- for (i = 0; i < arr.length; i++) {
- if (arr[i] > max) {
- max = arr[i];
- }
- }
- return max;
- },
-
- sum: function sum(arr) {
- var length = arr.length,
- sum = 0;
-
- while (length--) {
- sum += arr[length];
- }
- return sum;
- }
-};
+ : objectToString(value);
+}
+
+module.exports = baseGetTag;
+
/***/ }),
/* 9 */
@@ -1006,11 +1040,11 @@ exports.default = {
/* 10 */
/***/ (function(module, exports, __webpack_require__) {
-var listCacheClear = __webpack_require__(129),
- listCacheDelete = __webpack_require__(130),
- listCacheGet = __webpack_require__(131),
- listCacheHas = __webpack_require__(132),
- listCacheSet = __webpack_require__(133);
+var listCacheClear = __webpack_require__(131),
+ listCacheDelete = __webpack_require__(132),
+ listCacheGet = __webpack_require__(133),
+ listCacheHas = __webpack_require__(134),
+ listCacheSet = __webpack_require__(135);
/**
* Creates an list cache object.
@@ -1044,7 +1078,7 @@ module.exports = ListCache;
/* 11 */
/***/ (function(module, exports, __webpack_require__) {
-var root = __webpack_require__(3);
+var root = __webpack_require__(5);
/** Built-in value references. */
var Symbol = root.Symbol;
@@ -1083,10 +1117,10 @@ module.exports = assocIndexOf;
/* 13 */
/***/ (function(module, exports, __webpack_require__) {
-var isArray = __webpack_require__(1),
- isKey = __webpack_require__(126),
- stringToPath = __webpack_require__(150),
- toString = __webpack_require__(161);
+var isArray = __webpack_require__(2),
+ isKey = __webpack_require__(128),
+ stringToPath = __webpack_require__(152),
+ toString = __webpack_require__(163);
/**
* Casts `value` to a path array if it's not one.
@@ -1110,7 +1144,7 @@ module.exports = castPath;
/* 14 */
/***/ (function(module, exports, __webpack_require__) {
-var isKeyable = __webpack_require__(127);
+var isKeyable = __webpack_require__(129);
/**
* Gets the data for `map`.
@@ -1217,8 +1251,8 @@ module.exports = eq;
/* 18 */
/***/ (function(module, exports, __webpack_require__) {
-var baseIsArguments = __webpack_require__(92),
- isObjectLike = __webpack_require__(4);
+var baseIsArguments = __webpack_require__(94),
+ isObjectLike = __webpack_require__(6);
/** Used for built-in method references. */
var objectProto = Object.prototype;
@@ -1296,17 +1330,17 @@ var _cluster = __webpack_require__(52);
var _cluster2 = _interopRequireDefault(_cluster);
-var _array_helper = __webpack_require__(8);
+var _array_helper = __webpack_require__(3);
var _array_helper2 = _interopRequireDefault(_array_helper);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var vec2 = {
- clone: __webpack_require__(6)
+ clone: __webpack_require__(7)
};
var vec3 = {
- clone: __webpack_require__(79)
+ clone: __webpack_require__(81)
};
/**
@@ -1831,7 +1865,7 @@ function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {
while (bottomRowIdx < endIdx) {
for (i = 0; i < outWidth; i++) {
- outArray[outImgIdx] = Math.floor((0.299 * canvasData[topRowIdx * 4 + 0] + 0.587 * canvasData[topRowIdx * 4 + 1] + 0.114 * canvasData[topRowIdx * 4 + 2] + (0.299 * canvasData[(topRowIdx + 1) * 4 + 0] + 0.587 * canvasData[(topRowIdx + 1) * 4 + 1] + 0.114 * canvasData[(topRowIdx + 1) * 4 + 2]) + (0.299 * canvasData[bottomRowIdx * 4 + 0] + 0.587 * canvasData[bottomRowIdx * 4 + 1] + 0.114 * canvasData[bottomRowIdx * 4 + 2]) + (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] + 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] + 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4);
+ outArray[outImgIdx] = (0.299 * canvasData[topRowIdx * 4 + 0] + 0.587 * canvasData[topRowIdx * 4 + 1] + 0.114 * canvasData[topRowIdx * 4 + 2] + (0.299 * canvasData[(topRowIdx + 1) * 4 + 0] + 0.587 * canvasData[(topRowIdx + 1) * 4 + 1] + 0.114 * canvasData[(topRowIdx + 1) * 4 + 2]) + (0.299 * canvasData[bottomRowIdx * 4 + 0] + 0.587 * canvasData[bottomRowIdx * 4 + 1] + 0.114 * canvasData[bottomRowIdx * 4 + 2]) + (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] + 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] + 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4;
outImgIdx++;
topRowIdx = topRowIdx + 2;
bottomRowIdx = bottomRowIdx + 2;
@@ -1852,7 +1886,7 @@ function computeGray(imageData, outArray, config) {
}
} else {
for (i = 0; i < l; i++) {
- outArray[i] = Math.floor(0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2]);
+ outArray[i] = 0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2];
}
}
};
@@ -2093,14 +2127,14 @@ var _subImage2 = _interopRequireDefault(_subImage);
var _cv_utils = __webpack_require__(19);
-var _array_helper = __webpack_require__(8);
+var _array_helper = __webpack_require__(3);
var _array_helper2 = _interopRequireDefault(_array_helper);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var vec2 = {
- clone: __webpack_require__(6)
+ clone: __webpack_require__(7)
};
/**
@@ -2484,8 +2518,8 @@ module.exports = baseAssignValue;
/* 22 */
/***/ (function(module, exports, __webpack_require__) {
-var baseIsNative = __webpack_require__(93),
- getValue = __webpack_require__(116);
+var baseIsNative = __webpack_require__(95),
+ getValue = __webpack_require__(118);
/**
* Gets the native function at `key` of `object`.
@@ -2573,7 +2607,7 @@ module.exports = isArrayLike;
/* 25 */
/***/ (function(module, exports, __webpack_require__) {
-var baseGetTag = __webpack_require__(7),
+var baseGetTag = __webpack_require__(8),
isObject = __webpack_require__(0);
/** `Object#toString` result references. */
@@ -2657,8 +2691,8 @@ module.exports = isLength;
/* 27 */
/***/ (function(module, exports, __webpack_require__) {
-var baseGetTag = __webpack_require__(7),
- isObjectLike = __webpack_require__(4);
+var baseGetTag = __webpack_require__(8),
+ isObjectLike = __webpack_require__(6);
/** `Object#toString` result references. */
var symbolTag = '[object Symbol]';
@@ -2692,8 +2726,8 @@ module.exports = isSymbol;
/* 28 */
/***/ (function(module, exports, __webpack_require__) {
-var baseMerge = __webpack_require__(96),
- createAssigner = __webpack_require__(112);
+var baseMerge = __webpack_require__(98),
+ createAssigner = __webpack_require__(114);
/**
* This method is like `_.assign` except that it recursively merges own and
@@ -2878,11 +2912,11 @@ exports.default = Tracer;
exports.__esModule = true;
-var _barcode_reader = __webpack_require__(5);
+var _barcode_reader = __webpack_require__(1);
var _barcode_reader2 = _interopRequireDefault(_barcode_reader);
-var _array_helper = __webpack_require__(8);
+var _array_helper = __webpack_require__(3);
var _array_helper2 = _interopRequireDefault(_array_helper);
@@ -2903,33 +2937,6 @@ var properties = {
Code39Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties);
Code39Reader.prototype.constructor = Code39Reader;
-Code39Reader.prototype._toCounters = function (start, counter) {
- var self = this,
- numCounters = counter.length,
- end = self._row.length,
- isWhite = !self._row[start],
- i,
- counterPos = 0;
-
- _array_helper2.default.init(counter, 0);
-
- for (i = start; i < end; i++) {
- if (self._row[i] ^ isWhite) {
- counter[counterPos]++;
- } else {
- counterPos++;
- if (counterPos === numCounters) {
- break;
- } else {
- counter[counterPos] = 1;
- isWhite = !isWhite;
- }
- }
- }
-
- return counter;
-};
-
Code39Reader.prototype._decode = function () {
var self = this,
counters = [0, 0, 0, 0, 0, 0, 0, 0, 0],
@@ -3119,7 +3126,7 @@ function dot(a, b) {
/***/ (function(module, exports, __webpack_require__) {
var getNative = __webpack_require__(22),
- root = __webpack_require__(3);
+ root = __webpack_require__(5);
/* Built-in method references that are verified to be native. */
var Map = getNative(root, 'Map');
@@ -3131,11 +3138,11 @@ module.exports = Map;
/* 34 */
/***/ (function(module, exports, __webpack_require__) {
-var mapCacheClear = __webpack_require__(134),
- mapCacheDelete = __webpack_require__(135),
- mapCacheGet = __webpack_require__(136),
- mapCacheHas = __webpack_require__(137),
- mapCacheSet = __webpack_require__(138);
+var mapCacheClear = __webpack_require__(136),
+ mapCacheDelete = __webpack_require__(137),
+ mapCacheGet = __webpack_require__(138),
+ mapCacheHas = __webpack_require__(139),
+ mapCacheSet = __webpack_require__(140);
/**
* Creates a map cache object to store key-value pairs.
@@ -3257,7 +3264,7 @@ module.exports = freeGlobal;
/* 39 */
/***/ (function(module, exports, __webpack_require__) {
-var overArg = __webpack_require__(143);
+var overArg = __webpack_require__(145);
/** Built-in value references. */
var getPrototype = overArg(Object.getPrototypeOf, Object);
@@ -3293,7 +3300,7 @@ module.exports = isPrototype;
/* 41 */
/***/ (function(module, exports, __webpack_require__) {
-var apply = __webpack_require__(83);
+var apply = __webpack_require__(85);
/* Built-in method references for those with the same name as other `lodash` methods. */
var nativeMax = Math.max;
@@ -3335,8 +3342,8 @@ module.exports = overRest;
/* 42 */
/***/ (function(module, exports, __webpack_require__) {
-var baseSetToString = __webpack_require__(102),
- shortOut = __webpack_require__(144);
+var baseSetToString = __webpack_require__(104),
+ shortOut = __webpack_require__(146);
/**
* Sets the `toString` method of `func` to return `string`.
@@ -3382,8 +3389,8 @@ module.exports = identity;
/* 44 */
/***/ (function(module, exports, __webpack_require__) {
-/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(3),
- stubFalse = __webpack_require__(159);
+/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(5),
+ stubFalse = __webpack_require__(161);
/** Detect free variable `exports`. */
var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;
@@ -3427,9 +3434,9 @@ module.exports = isBuffer;
/* 45 */
/***/ (function(module, exports, __webpack_require__) {
-var baseIsTypedArray = __webpack_require__(94),
- baseUnary = __webpack_require__(105),
- nodeUtil = __webpack_require__(141);
+var baseIsTypedArray = __webpack_require__(96),
+ baseUnary = __webpack_require__(107),
+ nodeUtil = __webpack_require__(143);
/* Node.js helper references. */
var nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;
@@ -3460,8 +3467,8 @@ module.exports = isTypedArray;
/* 46 */
/***/ (function(module, exports, __webpack_require__) {
-var arrayLikeKeys = __webpack_require__(84),
- baseKeysIn = __webpack_require__(95),
+var arrayLikeKeys = __webpack_require__(86),
+ baseKeysIn = __webpack_require__(97),
isArrayLike = __webpack_require__(24);
/**
@@ -3584,7 +3591,7 @@ var _frame_grabber2 = _interopRequireDefault(_frame_grabber);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var vec2 = {
- clone: __webpack_require__(6)
+ clone: __webpack_require__(7)
};
var _inputStream,
@@ -4114,8 +4121,8 @@ exports.default = {
var CVUtils = __webpack_require__(19),
- Ndarray = __webpack_require__(163),
- Interp2D = __webpack_require__(164).d2;
+ Ndarray = __webpack_require__(165),
+ Interp2D = __webpack_require__(166).d2;
var FrameGrabber = {};
@@ -4212,7 +4219,7 @@ module.exports = FrameGrabber;
"use strict";
-var GetPixels = __webpack_require__(162);
+var GetPixels = __webpack_require__(164);
var InputStream = {};
@@ -4238,7 +4245,7 @@ InputStream.createImageStream = function () {
function loadImages() {
loaded = false;
- GetPixels(baseUrl, function (err, pixels) {
+ GetPixels(baseUrl, _config.mime, function (err, pixels) {
if (err) {
console.log(err);
exit(1);
@@ -4442,7 +4449,7 @@ exports.default = {
exports.__esModule = true;
var vec2 = {
- clone: __webpack_require__(6),
+ clone: __webpack_require__(7),
dot: __webpack_require__(32)
};
/**
@@ -4860,11 +4867,11 @@ var _image_debug = __webpack_require__(9);
var _image_debug2 = _interopRequireDefault(_image_debug);
-var _code_128_reader = __webpack_require__(66);
+var _code_128_reader = __webpack_require__(67);
var _code_128_reader2 = _interopRequireDefault(_code_128_reader);
-var _ean_reader = __webpack_require__(2);
+var _ean_reader = __webpack_require__(4);
var _ean_reader2 = _interopRequireDefault(_ean_reader);
@@ -4872,38 +4879,46 @@ var _code_39_reader = __webpack_require__(31);
var _code_39_reader2 = _interopRequireDefault(_code_39_reader);
-var _code_39_vin_reader = __webpack_require__(67);
+var _code_39_vin_reader = __webpack_require__(68);
var _code_39_vin_reader2 = _interopRequireDefault(_code_39_vin_reader);
-var _codabar_reader = __webpack_require__(65);
+var _codabar_reader = __webpack_require__(66);
var _codabar_reader2 = _interopRequireDefault(_codabar_reader);
-var _upc_reader = __webpack_require__(73);
+var _upc_reader = __webpack_require__(75);
var _upc_reader2 = _interopRequireDefault(_upc_reader);
-var _ean_8_reader = __webpack_require__(70);
+var _ean_8_reader = __webpack_require__(72);
var _ean_8_reader2 = _interopRequireDefault(_ean_8_reader);
-var _ean_2_reader = __webpack_require__(68);
+var _ean_2_reader = __webpack_require__(70);
var _ean_2_reader2 = _interopRequireDefault(_ean_2_reader);
-var _ean_5_reader = __webpack_require__(69);
+var _ean_5_reader = __webpack_require__(71);
var _ean_5_reader2 = _interopRequireDefault(_ean_5_reader);
-var _upc_e_reader = __webpack_require__(72);
+var _upc_e_reader = __webpack_require__(74);
var _upc_e_reader2 = _interopRequireDefault(_upc_e_reader);
-var _i2of5_reader = __webpack_require__(71);
+var _i2of5_reader = __webpack_require__(73);
var _i2of5_reader2 = _interopRequireDefault(_i2of5_reader);
+var _of5_reader = __webpack_require__(65);
+
+var _of5_reader2 = _interopRequireDefault(_of5_reader);
+
+var _code_93_reader = __webpack_require__(69);
+
+var _code_93_reader2 = _interopRequireDefault(_code_93_reader);
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var READERS = {
@@ -4917,7 +4932,9 @@ var READERS = {
codabar_reader: _codabar_reader2.default,
upc_reader: _upc_reader2.default,
upc_e_reader: _upc_e_reader2.default,
- i2of5_reader: _i2of5_reader2.default
+ i2of5_reader: _i2of5_reader2.default,
+ '2of5_reader': _of5_reader2.default,
+ code_93_reader: _code_93_reader2.default
};
exports.default = {
create: function create(config, inputImageWrapper) {
@@ -5430,7 +5447,7 @@ exports.default = Bresenham;
exports.__esModule = true;
-var _pick2 = __webpack_require__(158);
+var _pick2 = __webpack_require__(160);
var _pick3 = _interopRequireDefault(_pick2);
@@ -5453,7 +5470,7 @@ function waitForVideo(video) {
function checkVideo() {
if (attempts > 0) {
- if (video.videoWidth > 0 && video.videoHeight > 0) {
+ if (video.videoWidth > 10 && video.videoHeight > 10) {
if (false) {
console.log(video.videoWidth + "px x " + video.videoHeight + "px");
}
@@ -5480,7 +5497,9 @@ function initCamera(video, constraints) {
return (0, _mediaDevices.getUserMedia)(constraints).then(function (stream) {
return new Promise(function (resolve) {
streamRef = stream;
- video.setAttribute("autoplay", 'true');
+ video.setAttribute("autoplay", true);
+ video.setAttribute('muted', true);
+ video.setAttribute('playsinline', true);
video.srcObject = stream;
video.addEventListener('loadedmetadata', function () {
video.play();
@@ -5524,6 +5543,15 @@ function enumerateVideoDevices() {
});
}
+function getActiveTrack() {
+ if (streamRef) {
+ var tracks = streamRef.getVideoTracks();
+ if (tracks && tracks.length) {
+ return tracks[0];
+ }
+ }
+}
+
exports.default = {
request: function request(video, videoConstraints) {
return pickConstraints(videoConstraints).then(initCamera.bind(null, video));
@@ -5537,13 +5565,10 @@ exports.default = {
},
enumerateVideoDevices: enumerateVideoDevices,
getActiveStreamLabel: function getActiveStreamLabel() {
- if (streamRef) {
- var tracks = streamRef.getVideoTracks();
- if (tracks && tracks.length) {
- return tracks[0].label;
- }
- }
- }
+ var track = getActiveTrack();
+ return track ? track.label : '';
+ },
+ getActiveTrack: getActiveTrack
};
/***/ }),
@@ -5561,7 +5586,7 @@ var _image_wrapper2 = _interopRequireDefault(_image_wrapper);
var _cv_utils = __webpack_require__(19);
-var _array_helper = __webpack_require__(8);
+var _array_helper = __webpack_require__(3);
var _array_helper2 = _interopRequireDefault(_array_helper);
@@ -5584,15 +5609,15 @@ var _skeletonizer3 = _interopRequireDefault(_skeletonizer2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var vec2 = {
- clone: __webpack_require__(6),
+ clone: __webpack_require__(7),
dot: __webpack_require__(32),
- scale: __webpack_require__(77),
- transformMat2: __webpack_require__(78)
+ scale: __webpack_require__(79),
+ transformMat2: __webpack_require__(80)
};
var mat2 = {
- copy: __webpack_require__(74),
- create: __webpack_require__(75),
- invert: __webpack_require__(76)
+ copy: __webpack_require__(76),
+ create: __webpack_require__(77),
+ invert: __webpack_require__(78)
};
var _config,
@@ -6512,67 +6537,329 @@ function Skeletonizer(stdlib, foreign, buffer) {
length = imul(size, size) | 0;
- while ((length | 0) > 0) {
- length = length - 1 | 0;
- images[dstImagePtr + length | 0] = images[srcImagePtr + length | 0] | 0;
+ while ((length | 0) > 0) {
+ length = length - 1 | 0;
+ images[dstImagePtr + length | 0] = images[srcImagePtr + length | 0] | 0;
+ }
+ }
+
+ function zeroBorder(imagePtr) {
+ imagePtr = imagePtr | 0;
+
+ var x = 0,
+ y = 0;
+
+ for (x = 0; (x | 0) < (size - 1 | 0); x = x + 1 | 0) {
+ images[imagePtr + x | 0] = 0;
+ images[imagePtr + y | 0] = 0;
+ y = y + size - 1 | 0;
+ images[imagePtr + y | 0] = 0;
+ y = y + 1 | 0;
+ }
+ for (x = 0; (x | 0) < (size | 0); x = x + 1 | 0) {
+ images[imagePtr + y | 0] = 0;
+ y = y + 1 | 0;
+ }
+ }
+
+ function skeletonize() {
+ var subImagePtr = 0,
+ erodedImagePtr = 0,
+ tempImagePtr = 0,
+ skelImagePtr = 0,
+ sum = 0,
+ done = 0;
+
+ erodedImagePtr = imul(size, size) | 0;
+ tempImagePtr = erodedImagePtr + erodedImagePtr | 0;
+ skelImagePtr = tempImagePtr + erodedImagePtr | 0;
+
+ // init skel-image
+ init(skelImagePtr, 0);
+ zeroBorder(subImagePtr);
+
+ do {
+ erode(subImagePtr, erodedImagePtr);
+ dilate(erodedImagePtr, tempImagePtr);
+ subtract(subImagePtr, tempImagePtr, tempImagePtr);
+ bitwiseOr(skelImagePtr, tempImagePtr, skelImagePtr);
+ memcpy(erodedImagePtr, subImagePtr);
+ sum = countNonZero(subImagePtr) | 0;
+ done = (sum | 0) == 0 | 0;
+ } while (!done);
+ }
+ return {
+ skeletonize: skeletonize
+ };
+}
+/* @preserve ASM END */
+exports.default = Skeletonizer;
+/* eslint-enable eqeqeq*/
+
+/***/ }),
+/* 65 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = true;
+
+var _barcode_reader = __webpack_require__(1);
+
+var _barcode_reader2 = _interopRequireDefault(_barcode_reader);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function TwoOfFiveReader(opts) {
+ _barcode_reader2.default.call(this, opts);
+ this.barSpaceRatio = [1, 1];
+}
+
+var N = 1,
+ W = 3,
+ properties = {
+ START_PATTERN: { value: [W, N, W, N, N, N] },
+ STOP_PATTERN: { value: [W, N, N, N, W] },
+ CODE_PATTERN: { value: [[N, N, W, W, N], [W, N, N, N, W], [N, W, N, N, W], [W, W, N, N, N], [N, N, W, N, W], [W, N, W, N, N], [N, W, W, N, N], [N, N, N, W, W], [W, N, N, W, N], [N, W, N, W, N]] },
+ SINGLE_CODE_ERROR: { value: 0.78, writable: true },
+ AVG_CODE_ERROR: { value: 0.30, writable: true },
+ FORMAT: { value: "2of5" }
+};
+
+var startPatternLength = properties.START_PATTERN.value.reduce(function (sum, val) {
+ return sum + val;
+}, 0);
+
+TwoOfFiveReader.prototype = Object.create(_barcode_reader2.default.prototype, properties);
+TwoOfFiveReader.prototype.constructor = TwoOfFiveReader;
+
+TwoOfFiveReader.prototype._findPattern = function (pattern, offset, isWhite, tryHarder) {
+ var counter = [],
+ self = this,
+ i,
+ counterPos = 0,
+ bestMatch = {
+ error: Number.MAX_VALUE,
+ code: -1,
+ start: 0,
+ end: 0
+ },
+ error,
+ j,
+ sum,
+ epsilon = self.AVG_CODE_ERROR;
+
+ isWhite = isWhite || false;
+ tryHarder = tryHarder || false;
+
+ if (!offset) {
+ offset = self._nextSet(self._row);
+ }
+
+ for (i = 0; i < pattern.length; i++) {
+ counter[i] = 0;
+ }
+
+ for (i = offset; i < self._row.length; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ if (counterPos === counter.length - 1) {
+ sum = 0;
+ for (j = 0; j < counter.length; j++) {
+ sum += counter[j];
+ }
+ error = self._matchPattern(counter, pattern);
+ if (error < epsilon) {
+ bestMatch.error = error;
+ bestMatch.start = i - sum;
+ bestMatch.end = i;
+ return bestMatch;
+ }
+ if (tryHarder) {
+ for (j = 0; j < counter.length - 2; j++) {
+ counter[j] = counter[j + 2];
+ }
+ counter[counter.length - 2] = 0;
+ counter[counter.length - 1] = 0;
+ counterPos--;
+ } else {
+ return null;
+ }
+ } else {
+ counterPos++;
+ }
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
+ }
+ }
+ return null;
+};
+
+TwoOfFiveReader.prototype._findStart = function () {
+ var self = this,
+ leadingWhitespaceStart,
+ offset = self._nextSet(self._row),
+ startInfo,
+ narrowBarWidth = 1;
+
+ while (!startInfo) {
+ startInfo = self._findPattern(self.START_PATTERN, offset, false, true);
+ if (!startInfo) {
+ return null;
+ }
+ narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / startPatternLength);
+ leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5;
+ if (leadingWhitespaceStart >= 0) {
+ if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
+ return startInfo;
+ }
+ }
+ offset = startInfo.end;
+ startInfo = null;
+ }
+};
+
+TwoOfFiveReader.prototype._verifyTrailingWhitespace = function (endInfo) {
+ var self = this,
+ trailingWhitespaceEnd;
+
+ trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start) / 2;
+ if (trailingWhitespaceEnd < self._row.length) {
+ if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
+ return endInfo;
+ }
+ }
+ return null;
+};
+
+TwoOfFiveReader.prototype._findEnd = function () {
+ var self = this,
+ endInfo,
+ tmp,
+ offset;
+
+ self._row.reverse();
+ offset = self._nextSet(self._row);
+ endInfo = self._findPattern(self.STOP_PATTERN, offset, false, true);
+ self._row.reverse();
+
+ if (endInfo === null) {
+ return null;
+ }
+
+ // reverse numbers
+ tmp = endInfo.start;
+ endInfo.start = self._row.length - endInfo.end;
+ endInfo.end = self._row.length - tmp;
+
+ return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;
+};
+
+TwoOfFiveReader.prototype._decodeCode = function (counter) {
+ var j,
+ self = this,
+ sum = 0,
+ normalized,
+ error,
+ epsilon = self.AVG_CODE_ERROR,
+ code,
+ bestMatch = {
+ error: Number.MAX_VALUE,
+ code: -1,
+ start: 0,
+ end: 0
+ };
+
+ for (j = 0; j < counter.length; j++) {
+ sum += counter[j];
+ }
+ for (code = 0; code < self.CODE_PATTERN.length; code++) {
+ error = self._matchPattern(counter, self.CODE_PATTERN[code]);
+ if (error < bestMatch.error) {
+ bestMatch.code = code;
+ bestMatch.error = error;
}
}
+ if (bestMatch.error < epsilon) {
+ return bestMatch;
+ }
+};
- function zeroBorder(imagePtr) {
- imagePtr = imagePtr | 0;
-
- var x = 0,
- y = 0;
+TwoOfFiveReader.prototype._decodePayload = function (counters, result, decodedCodes) {
+ var i,
+ self = this,
+ pos = 0,
+ counterLength = counters.length,
+ counter = [0, 0, 0, 0, 0],
+ code;
- 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;
+ while (pos < counterLength) {
+ for (i = 0; i < 5; i++) {
+ counter[i] = counters[pos] * this.barSpaceRatio[0];
+ pos += 2;
}
- for (x = 0; (x | 0) < (size | 0); x = x + 1 | 0) {
- images[imagePtr + y | 0] = 0;
- y = y + 1 | 0;
+ code = self._decodeCode(counter);
+ if (!code) {
+ return null;
}
+ result.push(code.code + "");
+ decodedCodes.push(code);
}
+ return code;
+};
- function skeletonize() {
- var subImagePtr = 0,
- erodedImagePtr = 0,
- tempImagePtr = 0,
- skelImagePtr = 0,
- sum = 0,
- done = 0;
+TwoOfFiveReader.prototype._verifyCounterLength = function (counters) {
+ return counters.length % 10 === 0;
+};
- erodedImagePtr = imul(size, size) | 0;
- tempImagePtr = erodedImagePtr + erodedImagePtr | 0;
- skelImagePtr = tempImagePtr + erodedImagePtr | 0;
+TwoOfFiveReader.prototype._decode = function () {
+ var startInfo,
+ endInfo,
+ self = this,
+ code,
+ result = [],
+ decodedCodes = [],
+ counters;
- // init skel-image
- init(skelImagePtr, 0);
- zeroBorder(subImagePtr);
+ startInfo = self._findStart();
+ if (!startInfo) {
+ return null;
+ }
+ decodedCodes.push(startInfo);
- 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);
+ endInfo = self._findEnd();
+ if (!endInfo) {
+ return null;
+ }
+
+ counters = self._fillCounters(startInfo.end, endInfo.start, false);
+ if (!self._verifyCounterLength(counters)) {
+ return null;
+ }
+ code = self._decodePayload(counters, result, decodedCodes);
+ if (!code) {
+ return null;
+ }
+ if (result.length < 5) {
+ return null;
}
+
+ decodedCodes.push(endInfo);
return {
- skeletonize: skeletonize
+ code: result.join(""),
+ start: startInfo.start,
+ end: endInfo.end,
+ startInfo: startInfo,
+ decodedCodes: decodedCodes
};
-}
-/* @preserve ASM END */
-exports.default = Skeletonizer;
-/* eslint-enable eqeqeq*/
+};
+
+exports.default = TwoOfFiveReader;
/***/ }),
-/* 65 */
+/* 66 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -6580,7 +6867,7 @@ exports.default = Skeletonizer;
exports.__esModule = true;
-var _barcode_reader = __webpack_require__(5);
+var _barcode_reader = __webpack_require__(1);
var _barcode_reader2 = _interopRequireDefault(_barcode_reader);
@@ -6870,7 +7157,7 @@ CodabarReader.prototype._findStart = function () {
exports.default = CodabarReader;
/***/ }),
-/* 66 */
+/* 67 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -6878,7 +7165,7 @@ exports.default = CodabarReader;
exports.__esModule = true;
-var _barcode_reader = __webpack_require__(5);
+var _barcode_reader = __webpack_require__(1);
var _barcode_reader2 = _interopRequireDefault(_barcode_reader);
@@ -7229,7 +7516,7 @@ function calculateCorrection(expected, normalized, indices) {
exports.default = Code128Reader;
/***/ }),
-/* 67 */
+/* 68 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -7271,30 +7558,295 @@ Code39VINReader.prototype._decode = function () {
code = code.replace(patterns.IOQ, '');
- if (!code.match(patterns.AZ09)) {
- if (false) {
- console.log('Failed AZ09 pattern code:', code);
+ if (!code.match(patterns.AZ09)) {
+ if (false) {
+ console.log('Failed AZ09 pattern code:', code);
+ }
+ return null;
+ }
+
+ if (!this._checkChecksum(code)) {
+ return null;
+ }
+
+ result.code = code;
+ return result;
+};
+
+Code39VINReader.prototype._checkChecksum = function (code) {
+ // TODO
+ return !!code;
+};
+
+exports.default = Code39VINReader;
+
+/***/ }),
+/* 69 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+exports.__esModule = true;
+
+var _barcode_reader = __webpack_require__(1);
+
+var _barcode_reader2 = _interopRequireDefault(_barcode_reader);
+
+var _array_helper = __webpack_require__(3);
+
+var _array_helper2 = _interopRequireDefault(_array_helper);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function Code93Reader() {
+ _barcode_reader2.default.call(this);
+}
+
+var ALPHABETH_STRING = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*";
+
+var properties = {
+ ALPHABETH_STRING: { value: ALPHABETH_STRING },
+ ALPHABET: { value: ALPHABETH_STRING.split('').map(function (char) {
+ return char.charCodeAt(0);
+ }) },
+ CHARACTER_ENCODINGS: { value: [0x114, 0x148, 0x144, 0x142, 0x128, 0x124, 0x122, 0x150, 0x112, 0x10A, 0x1A8, 0x1A4, 0x1A2, 0x194, 0x192, 0x18A, 0x168, 0x164, 0x162, 0x134, 0x11A, 0x158, 0x14C, 0x146, 0x12C, 0x116, 0x1B4, 0x1B2, 0x1AC, 0x1A6, 0x196, 0x19A, 0x16C, 0x166, 0x136, 0x13A, 0x12E, 0x1D4, 0x1D2, 0x1CA, 0x16E, 0x176, 0x1AE, 0x126, 0x1DA, 0x1D6, 0x132, 0x15E] },
+ ASTERISK: { value: 0x15E },
+ FORMAT: { value: "code_93", writeable: false }
+};
+
+Code93Reader.prototype = Object.create(_barcode_reader2.default.prototype, properties);
+Code93Reader.prototype.constructor = Code93Reader;
+
+Code93Reader.prototype._decode = function () {
+ var self = this,
+ counters = [0, 0, 0, 0, 0, 0],
+ result = [],
+ start = self._findStart(),
+ decodedChar,
+ lastStart,
+ pattern,
+ nextStart;
+
+ if (!start) {
+ return null;
+ }
+ nextStart = self._nextSet(self._row, start.end);
+
+ do {
+ counters = self._toCounters(nextStart, counters);
+ pattern = self._toPattern(counters);
+ if (pattern < 0) {
+ return null;
+ }
+ decodedChar = self._patternToChar(pattern);
+ if (decodedChar < 0) {
+ return null;
+ }
+ result.push(decodedChar);
+ lastStart = nextStart;
+ nextStart += _array_helper2.default.sum(counters);
+ nextStart = self._nextSet(self._row, nextStart);
+ } while (decodedChar !== '*');
+ result.pop();
+
+ if (!result.length) {
+ return null;
+ }
+
+ if (!self._verifyEnd(lastStart, nextStart, counters)) {
+ return null;
+ }
+
+ if (!self._verifyChecksums(result)) {
+ return null;
+ }
+
+ result = result.slice(0, result.length - 2);
+ if ((result = self._decodeExtended(result)) === null) {
+ return null;
+ };
+
+ return {
+ code: result.join(""),
+ start: start.start,
+ end: nextStart,
+ startInfo: start,
+ decodedCodes: result
+ };
+};
+
+Code93Reader.prototype._verifyEnd = function (lastStart, nextStart) {
+ if (lastStart === nextStart || !this._row[nextStart]) {
+ return false;
+ }
+ return true;
+};
+
+Code93Reader.prototype._patternToChar = function (pattern) {
+ var i,
+ self = this;
+
+ for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {
+ if (self.CHARACTER_ENCODINGS[i] === pattern) {
+ return String.fromCharCode(self.ALPHABET[i]);
+ }
+ }
+ return -1;
+};
+
+Code93Reader.prototype._toPattern = function (counters) {
+ var numCounters = counters.length;
+ var pattern = 0;
+ var sum = 0;
+ for (var i = 0; i < numCounters; i++) {
+ sum += counters[i];
+ }
+
+ for (var _i = 0; _i < numCounters; _i++) {
+ var normalized = Math.round(counters[_i] * 9 / sum);
+ if (normalized < 1 || normalized > 4) {
+ return -1;
+ }
+ if ((_i & 1) === 0) {
+ for (var j = 0; j < normalized; j++) {
+ pattern = pattern << 1 | 1;
+ }
+ } else {
+ pattern <<= normalized;
+ }
+ }
+
+ return pattern;
+};
+
+Code93Reader.prototype._findStart = function () {
+ var self = this,
+ offset = self._nextSet(self._row),
+ patternStart = offset,
+ counter = [0, 0, 0, 0, 0, 0],
+ counterPos = 0,
+ isWhite = false,
+ i,
+ j,
+ whiteSpaceMustStart;
+
+ for (i = offset; i < self._row.length; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ if (counterPos === counter.length - 1) {
+ // find start pattern
+ if (self._toPattern(counter) === self.ASTERISK) {
+ whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - (i - patternStart) / 4));
+ if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) {
+ return {
+ start: patternStart,
+ end: i
+ };
+ }
+ }
+
+ patternStart += counter[0] + counter[1];
+ for (j = 0; j < 4; j++) {
+ counter[j] = counter[j + 2];
+ }
+ counter[4] = 0;
+ counter[5] = 0;
+ counterPos--;
+ } else {
+ counterPos++;
+ }
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
}
- return null;
}
+ return null;
+};
- if (!this._checkChecksum(code)) {
- return null;
+Code93Reader.prototype._decodeExtended = function (charArray) {
+ var length = charArray.length;
+ var result = [];
+ for (var i = 0; i < length; i++) {
+ var char = charArray[i];
+ if (char >= 'a' && char <= 'd') {
+ if (i > length - 2) {
+ return null;
+ }
+ var nextChar = charArray[++i];
+ var nextCharCode = nextChar.charCodeAt(0);
+ var decodedChar = void 0;
+ switch (char) {
+ case 'a':
+ if (nextChar >= 'A' && nextChar <= 'Z') {
+ decodedChar = String.fromCharCode(nextCharCode - 64);
+ } else {
+ return null;
+ }
+ break;
+ case 'b':
+ if (nextChar >= 'A' && nextChar <= 'E') {
+ decodedChar = String.fromCharCode(nextCharCode - 38);
+ } else if (nextChar >= 'F' && nextChar <= 'J') {
+ decodedChar = String.fromCharCode(nextCharCode - 11);
+ } else if (nextChar >= 'K' && nextChar <= 'O') {
+ decodedChar = String.fromCharCode(nextCharCode + 16);
+ } else if (nextChar >= 'P' && nextChar <= 'S') {
+ decodedChar = String.fromCharCode(nextCharCode + 43);
+ } else if (nextChar >= 'T' && nextChar <= 'Z') {
+ decodedChar = String.fromCharCode(127);
+ } else {
+ return null;
+ }
+ break;
+ case 'c':
+ if (nextChar >= 'A' && nextChar <= 'O') {
+ decodedChar = String.fromCharCode(nextCharCode - 32);
+ } else if (nextChar === 'Z') {
+ decodedChar = ':';
+ } else {
+ return null;
+ }
+ break;
+ case 'd':
+ if (nextChar >= 'A' && nextChar <= 'Z') {
+ decodedChar = String.fromCharCode(nextCharCode + 32);
+ } else {
+ return null;
+ }
+ break;
+ }
+ result.push(decodedChar);
+ } else {
+ result.push(char);
+ }
}
-
- result.code = code;
return result;
};
-Code39VINReader.prototype._checkChecksum = function (code) {
- // TODO
- return !!code;
+Code93Reader.prototype._verifyChecksums = function (charArray) {
+ return this._matchCheckChar(charArray, charArray.length - 2, 20) && this._matchCheckChar(charArray, charArray.length - 1, 15);
};
-exports.default = Code39VINReader;
+Code93Reader.prototype._matchCheckChar = function (charArray, index, maxWeight) {
+ var _this = this;
+
+ var arrayToCheck = charArray.slice(0, index);
+ var length = arrayToCheck.length;
+ var weightedSums = arrayToCheck.reduce(function (sum, char, i) {
+ var weight = (i * -1 + (length - 1)) % maxWeight + 1;
+ var value = _this.ALPHABET.indexOf(char.charCodeAt(0));
+ return sum + weight * value;
+ }, 0);
+
+ var checkChar = this.ALPHABET[weightedSums % 47];
+ return checkChar === charArray[index].charCodeAt(0);
+};
+
+exports.default = Code93Reader;
/***/ }),
-/* 68 */
+/* 70 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -7302,7 +7854,7 @@ exports.default = Code39VINReader;
exports.__esModule = true;
-var _ean_reader = __webpack_require__(2);
+var _ean_reader = __webpack_require__(4);
var _ean_reader2 = _interopRequireDefault(_ean_reader);
@@ -7359,7 +7911,7 @@ EAN2Reader.prototype.decode = function (row, start) {
exports.default = EAN2Reader;
/***/ }),
-/* 69 */
+/* 71 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -7367,7 +7919,7 @@ exports.default = EAN2Reader;
exports.__esModule = true;
-var _ean_reader = __webpack_require__(2);
+var _ean_reader = __webpack_require__(4);
var _ean_reader2 = _interopRequireDefault(_ean_reader);
@@ -7456,7 +8008,7 @@ function extensionChecksum(result) {
exports.default = EAN5Reader;
/***/ }),
-/* 70 */
+/* 72 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -7464,7 +8016,7 @@ exports.default = EAN5Reader;
exports.__esModule = true;
-var _ean_reader = __webpack_require__(2);
+var _ean_reader = __webpack_require__(4);
var _ean_reader2 = _interopRequireDefault(_ean_reader);
@@ -7515,7 +8067,7 @@ EAN8Reader.prototype._decodePayload = function (code, result, decodedCodes) {
exports.default = EAN8Reader;
/***/ }),
-/* 71 */
+/* 73 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -7527,7 +8079,7 @@ var _merge2 = __webpack_require__(28);
var _merge3 = _interopRequireDefault(_merge2);
-var _barcode_reader = __webpack_require__(5);
+var _barcode_reader = __webpack_require__(1);
var _barcode_reader2 = _interopRequireDefault(_barcode_reader);
@@ -7844,7 +8396,7 @@ I2of5Reader.CONFIG_KEYS = {
exports.default = I2of5Reader;
/***/ }),
-/* 72 */
+/* 74 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -7852,7 +8404,7 @@ exports.default = I2of5Reader;
exports.__esModule = true;
-var _ean_reader = __webpack_require__(2);
+var _ean_reader = __webpack_require__(4);
var _ean_reader2 = _interopRequireDefault(_ean_reader);
@@ -7952,7 +8504,7 @@ UPCEReader.prototype._verifyTrailingWhitespace = function (endInfo) {
exports.default = UPCEReader;
/***/ }),
-/* 73 */
+/* 75 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
@@ -7960,7 +8512,7 @@ exports.default = UPCEReader;
exports.__esModule = true;
-var _ean_reader = __webpack_require__(2);
+var _ean_reader = __webpack_require__(4);
var _ean_reader2 = _interopRequireDefault(_ean_reader);
@@ -7990,7 +8542,7 @@ UPCReader.prototype._decode = function () {
exports.default = UPCReader;
/***/ }),
-/* 74 */
+/* 76 */
/***/ (function(module, exports) {
module.exports = copy
@@ -8013,7 +8565,7 @@ function copy(out, a) {
/***/ }),
-/* 75 */
+/* 77 */
/***/ (function(module, exports) {
module.exports = create
@@ -8035,7 +8587,7 @@ function create() {
/***/ }),
-/* 76 */
+/* 78 */
/***/ (function(module, exports) {
module.exports = invert
@@ -8068,7 +8620,7 @@ function invert(out, a) {
/***/ }),
-/* 77 */
+/* 79 */
/***/ (function(module, exports) {
module.exports = scale
@@ -8088,7 +8640,7 @@ function scale(out, a, b) {
}
/***/ }),
-/* 78 */
+/* 80 */
/***/ (function(module, exports) {
module.exports = transformMat2
@@ -8110,7 +8662,7 @@ function transformMat2(out, a, m) {
}
/***/ }),
-/* 79 */
+/* 81 */
/***/ (function(module, exports) {
module.exports = clone;
@@ -8130,14 +8682,14 @@ function clone(a) {
}
/***/ }),
-/* 80 */
+/* 82 */
/***/ (function(module, exports, __webpack_require__) {
-var hashClear = __webpack_require__(118),
- hashDelete = __webpack_require__(119),
- hashGet = __webpack_require__(120),
- hashHas = __webpack_require__(121),
- hashSet = __webpack_require__(122);
+var hashClear = __webpack_require__(120),
+ hashDelete = __webpack_require__(121),
+ hashGet = __webpack_require__(122),
+ hashHas = __webpack_require__(123),
+ hashSet = __webpack_require__(124);
/**
* Creates a hash object.
@@ -8168,15 +8720,15 @@ module.exports = Hash;
/***/ }),
-/* 81 */
+/* 83 */
/***/ (function(module, exports, __webpack_require__) {
var ListCache = __webpack_require__(10),
- stackClear = __webpack_require__(145),
- stackDelete = __webpack_require__(146),
- stackGet = __webpack_require__(147),
- stackHas = __webpack_require__(148),
- stackSet = __webpack_require__(149);
+ stackClear = __webpack_require__(147),
+ stackDelete = __webpack_require__(148),
+ stackGet = __webpack_require__(149),
+ stackHas = __webpack_require__(150),
+ stackSet = __webpack_require__(151);
/**
* Creates a stack cache object to store key-value pairs.
@@ -8201,10 +8753,10 @@ module.exports = Stack;
/***/ }),
-/* 82 */
+/* 84 */
/***/ (function(module, exports, __webpack_require__) {
-var root = __webpack_require__(3);
+var root = __webpack_require__(5);
/** Built-in value references. */
var Uint8Array = root.Uint8Array;
@@ -8213,7 +8765,7 @@ module.exports = Uint8Array;
/***/ }),
-/* 83 */
+/* 85 */
/***/ (function(module, exports) {
/**
@@ -8240,12 +8792,12 @@ module.exports = apply;
/***/ }),
-/* 84 */
+/* 86 */
/***/ (function(module, exports, __webpack_require__) {
-var baseTimes = __webpack_require__(103),
+var baseTimes = __webpack_require__(105),
isArguments = __webpack_require__(18),
- isArray = __webpack_require__(1),
+ isArray = __webpack_require__(2),
isBuffer = __webpack_require__(44),
isIndex = __webpack_require__(15),
isTypedArray = __webpack_require__(45);
@@ -8295,7 +8847,7 @@ module.exports = arrayLikeKeys;
/***/ }),
-/* 85 */
+/* 87 */
/***/ (function(module, exports) {
/**
@@ -8322,7 +8874,7 @@ module.exports = arrayMap;
/***/ }),
-/* 86 */
+/* 88 */
/***/ (function(module, exports) {
/**
@@ -8348,7 +8900,7 @@ module.exports = arrayPush;
/***/ }),
-/* 87 */
+/* 89 */
/***/ (function(module, exports, __webpack_require__) {
var isObject = __webpack_require__(0);
@@ -8384,11 +8936,11 @@ module.exports = baseCreate;
/***/ }),
-/* 88 */
+/* 90 */
/***/ (function(module, exports, __webpack_require__) {
-var arrayPush = __webpack_require__(86),
- isFlattenable = __webpack_require__(124);
+var arrayPush = __webpack_require__(88),
+ isFlattenable = __webpack_require__(126);
/**
* The base implementation of `_.flatten` with support for restricting flattening.
@@ -8428,10 +8980,10 @@ module.exports = baseFlatten;
/***/ }),
-/* 89 */
+/* 91 */
/***/ (function(module, exports, __webpack_require__) {
-var createBaseFor = __webpack_require__(113);
+var createBaseFor = __webpack_require__(115);
/**
* The base implementation of `baseForOwn` which iterates over `object`
@@ -8450,7 +9002,7 @@ module.exports = baseFor;
/***/ }),
-/* 90 */
+/* 92 */
/***/ (function(module, exports, __webpack_require__) {
var castPath = __webpack_require__(13),
@@ -8480,7 +9032,7 @@ module.exports = baseGet;
/***/ }),
-/* 91 */
+/* 93 */
/***/ (function(module, exports) {
/**
@@ -8499,11 +9051,11 @@ module.exports = baseHasIn;
/***/ }),
-/* 92 */
+/* 94 */
/***/ (function(module, exports, __webpack_require__) {
-var baseGetTag = __webpack_require__(7),
- isObjectLike = __webpack_require__(4);
+var baseGetTag = __webpack_require__(8),
+ isObjectLike = __webpack_require__(6);
/** `Object#toString` result references. */
var argsTag = '[object Arguments]';
@@ -8523,13 +9075,13 @@ module.exports = baseIsArguments;
/***/ }),
-/* 93 */
+/* 95 */
/***/ (function(module, exports, __webpack_require__) {
var isFunction = __webpack_require__(25),
- isMasked = __webpack_require__(128),
+ isMasked = __webpack_require__(130),
isObject = __webpack_require__(0),
- toSource = __webpack_require__(151);
+ toSource = __webpack_require__(153);
/**
* Used to match `RegExp`
@@ -8576,12 +9128,12 @@ module.exports = baseIsNative;
/***/ }),
-/* 94 */
+/* 96 */
/***/ (function(module, exports, __webpack_require__) {
-var baseGetTag = __webpack_require__(7),
+var baseGetTag = __webpack_require__(8),
isLength = __webpack_require__(26),
- isObjectLike = __webpack_require__(4);
+ isObjectLike = __webpack_require__(6);
/** `Object#toString` result references. */
var argsTag = '[object Arguments]',
@@ -8642,12 +9194,12 @@ module.exports = baseIsTypedArray;
/***/ }),
-/* 95 */
+/* 97 */
/***/ (function(module, exports, __webpack_require__) {
var isObject = __webpack_require__(0),
isPrototype = __webpack_require__(40),
- nativeKeysIn = __webpack_require__(140);
+ nativeKeysIn = __webpack_require__(142);
/** Used for built-in method references. */
var objectProto = Object.prototype;
@@ -8681,13 +9233,13 @@ module.exports = baseKeysIn;
/***/ }),
-/* 96 */
+/* 98 */
/***/ (function(module, exports, __webpack_require__) {
-var Stack = __webpack_require__(81),
+var Stack = __webpack_require__(83),
assignMergeValue = __webpack_require__(35),
- baseFor = __webpack_require__(89),
- baseMergeDeep = __webpack_require__(97),
+ baseFor = __webpack_require__(91),
+ baseMergeDeep = __webpack_require__(99),
isObject = __webpack_require__(0),
keysIn = __webpack_require__(46);
@@ -8728,23 +9280,23 @@ module.exports = baseMerge;
/***/ }),
-/* 97 */
+/* 99 */
/***/ (function(module, exports, __webpack_require__) {
var assignMergeValue = __webpack_require__(35),
- cloneBuffer = __webpack_require__(107),
- cloneTypedArray = __webpack_require__(108),
- copyArray = __webpack_require__(109),
- initCloneObject = __webpack_require__(123),
+ cloneBuffer = __webpack_require__(109),
+ cloneTypedArray = __webpack_require__(110),
+ copyArray = __webpack_require__(111),
+ initCloneObject = __webpack_require__(125),
isArguments = __webpack_require__(18),
- isArray = __webpack_require__(1),
- isArrayLikeObject = __webpack_require__(155),
+ isArray = __webpack_require__(2),
+ isArrayLikeObject = __webpack_require__(157),
isBuffer = __webpack_require__(44),
isFunction = __webpack_require__(25),
isObject = __webpack_require__(0),
- isPlainObject = __webpack_require__(156),
+ isPlainObject = __webpack_require__(158),
isTypedArray = __webpack_require__(45),
- toPlainObject = __webpack_require__(160);
+ toPlainObject = __webpack_require__(162);
/**
* A specialized version of `baseMerge` for arrays and objects which performs
@@ -8827,11 +9379,11 @@ module.exports = baseMergeDeep;
/***/ }),
-/* 98 */
+/* 100 */
/***/ (function(module, exports, __webpack_require__) {
-var basePickBy = __webpack_require__(99),
- hasIn = __webpack_require__(154);
+var basePickBy = __webpack_require__(101),
+ hasIn = __webpack_require__(156);
/**
* The base implementation of `_.pick` without support for individual
@@ -8852,11 +9404,11 @@ module.exports = basePick;
/***/ }),
-/* 99 */
+/* 101 */
/***/ (function(module, exports, __webpack_require__) {
-var baseGet = __webpack_require__(90),
- baseSet = __webpack_require__(101),
+var baseGet = __webpack_require__(92),
+ baseSet = __webpack_require__(103),
castPath = __webpack_require__(13);
/**
@@ -8888,7 +9440,7 @@ module.exports = basePickBy;
/***/ }),
-/* 100 */
+/* 102 */
/***/ (function(module, exports, __webpack_require__) {
var identity = __webpack_require__(43),
@@ -8911,7 +9463,7 @@ module.exports = baseRest;
/***/ }),
-/* 101 */
+/* 103 */
/***/ (function(module, exports, __webpack_require__) {
var assignValue = __webpack_require__(36),
@@ -8964,10 +9516,10 @@ module.exports = baseSet;
/***/ }),
-/* 102 */
+/* 104 */
/***/ (function(module, exports, __webpack_require__) {
-var constant = __webpack_require__(152),
+var constant = __webpack_require__(154),
defineProperty = __webpack_require__(37),
identity = __webpack_require__(43);
@@ -8992,7 +9544,7 @@ module.exports = baseSetToString;
/***/ }),
-/* 103 */
+/* 105 */
/***/ (function(module, exports) {
/**
@@ -9018,12 +9570,12 @@ module.exports = baseTimes;
/***/ }),
-/* 104 */
+/* 106 */
/***/ (function(module, exports, __webpack_require__) {
var Symbol = __webpack_require__(11),
- arrayMap = __webpack_require__(85),
- isArray = __webpack_require__(1),
+ arrayMap = __webpack_require__(87),
+ isArray = __webpack_require__(2),
isSymbol = __webpack_require__(27);
/** Used as references for various `Number` constants. */
@@ -9061,7 +9613,7 @@ module.exports = baseToString;
/***/ }),
-/* 105 */
+/* 107 */
/***/ (function(module, exports) {
/**
@@ -9081,10 +9633,10 @@ module.exports = baseUnary;
/***/ }),
-/* 106 */
+/* 108 */
/***/ (function(module, exports, __webpack_require__) {
-var Uint8Array = __webpack_require__(82);
+var Uint8Array = __webpack_require__(84);
/**
* Creates a clone of `arrayBuffer`.
@@ -9103,10 +9655,10 @@ module.exports = cloneArrayBuffer;
/***/ }),
-/* 107 */
+/* 109 */
/***/ (function(module, exports, __webpack_require__) {
-/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(3);
+/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(5);
/** Detect free variable `exports`. */
var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;
@@ -9145,10 +9697,10 @@ module.exports = cloneBuffer;
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(29)(module)))
/***/ }),
-/* 108 */
+/* 110 */
/***/ (function(module, exports, __webpack_require__) {
-var cloneArrayBuffer = __webpack_require__(106);
+var cloneArrayBuffer = __webpack_require__(108);
/**
* Creates a clone of `typedArray`.
@@ -9167,7 +9719,7 @@ module.exports = cloneTypedArray;
/***/ }),
-/* 109 */
+/* 111 */
/***/ (function(module, exports) {
/**
@@ -9193,7 +9745,7 @@ module.exports = copyArray;
/***/ }),
-/* 110 */
+/* 112 */
/***/ (function(module, exports, __webpack_require__) {
var assignValue = __webpack_require__(36),
@@ -9239,10 +9791,10 @@ module.exports = copyObject;
/***/ }),
-/* 111 */
+/* 113 */
/***/ (function(module, exports, __webpack_require__) {
-var root = __webpack_require__(3);
+var root = __webpack_require__(5);
/** Used to detect overreaching core-js shims. */
var coreJsData = root['__core-js_shared__'];
@@ -9251,11 +9803,11 @@ module.exports = coreJsData;
/***/ }),
-/* 112 */
+/* 114 */
/***/ (function(module, exports, __webpack_require__) {
-var baseRest = __webpack_require__(100),
- isIterateeCall = __webpack_require__(125);
+var baseRest = __webpack_require__(102),
+ isIterateeCall = __webpack_require__(127);
/**
* Creates a function like `_.assign`.
@@ -9294,7 +9846,7 @@ module.exports = createAssigner;
/***/ }),
-/* 113 */
+/* 115 */
/***/ (function(module, exports) {
/**
@@ -9325,10 +9877,10 @@ module.exports = createBaseFor;
/***/ }),
-/* 114 */
+/* 116 */
/***/ (function(module, exports, __webpack_require__) {
-var flatten = __webpack_require__(153),
+var flatten = __webpack_require__(155),
overRest = __webpack_require__(41),
setToString = __webpack_require__(42);
@@ -9347,7 +9899,7 @@ module.exports = flatRest;
/***/ }),
-/* 115 */
+/* 117 */
/***/ (function(module, exports, __webpack_require__) {
var Symbol = __webpack_require__(11);
@@ -9399,7 +9951,7 @@ module.exports = getRawTag;
/***/ }),
-/* 116 */
+/* 118 */
/***/ (function(module, exports) {
/**
@@ -9418,12 +9970,12 @@ module.exports = getValue;
/***/ }),
-/* 117 */
+/* 119 */
/***/ (function(module, exports, __webpack_require__) {
var castPath = __webpack_require__(13),
isArguments = __webpack_require__(18),
- isArray = __webpack_require__(1),
+ isArray = __webpack_require__(2),
isIndex = __webpack_require__(15),
isLength = __webpack_require__(26),
toKey = __webpack_require__(23);
@@ -9463,7 +10015,7 @@ module.exports = hasPath;
/***/ }),
-/* 118 */
+/* 120 */
/***/ (function(module, exports, __webpack_require__) {
var nativeCreate = __webpack_require__(16);
@@ -9484,7 +10036,7 @@ module.exports = hashClear;
/***/ }),
-/* 119 */
+/* 121 */
/***/ (function(module, exports) {
/**
@@ -9507,7 +10059,7 @@ module.exports = hashDelete;
/***/ }),
-/* 120 */
+/* 122 */
/***/ (function(module, exports, __webpack_require__) {
var nativeCreate = __webpack_require__(16);
@@ -9543,7 +10095,7 @@ module.exports = hashGet;
/***/ }),
-/* 121 */
+/* 123 */
/***/ (function(module, exports, __webpack_require__) {
var nativeCreate = __webpack_require__(16);
@@ -9572,7 +10124,7 @@ module.exports = hashHas;
/***/ }),
-/* 122 */
+/* 124 */
/***/ (function(module, exports, __webpack_require__) {
var nativeCreate = __webpack_require__(16);
@@ -9601,10 +10153,10 @@ module.exports = hashSet;
/***/ }),
-/* 123 */
+/* 125 */
/***/ (function(module, exports, __webpack_require__) {
-var baseCreate = __webpack_require__(87),
+var baseCreate = __webpack_require__(89),
getPrototype = __webpack_require__(39),
isPrototype = __webpack_require__(40);
@@ -9625,12 +10177,12 @@ module.exports = initCloneObject;
/***/ }),
-/* 124 */
+/* 126 */
/***/ (function(module, exports, __webpack_require__) {
var Symbol = __webpack_require__(11),
isArguments = __webpack_require__(18),
- isArray = __webpack_require__(1);
+ isArray = __webpack_require__(2);
/** Built-in value references. */
var spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;
@@ -9651,7 +10203,7 @@ module.exports = isFlattenable;
/***/ }),
-/* 125 */
+/* 127 */
/***/ (function(module, exports, __webpack_require__) {
var eq = __webpack_require__(17),
@@ -9687,10 +10239,10 @@ module.exports = isIterateeCall;
/***/ }),
-/* 126 */
+/* 128 */
/***/ (function(module, exports, __webpack_require__) {
-var isArray = __webpack_require__(1),
+var isArray = __webpack_require__(2),
isSymbol = __webpack_require__(27);
/** Used to match property names within property paths. */
@@ -9722,7 +10274,7 @@ module.exports = isKey;
/***/ }),
-/* 127 */
+/* 129 */
/***/ (function(module, exports) {
/**
@@ -9743,10 +10295,10 @@ module.exports = isKeyable;
/***/ }),
-/* 128 */
+/* 130 */
/***/ (function(module, exports, __webpack_require__) {
-var coreJsData = __webpack_require__(111);
+var coreJsData = __webpack_require__(113);
/** Used to detect methods masquerading as native. */
var maskSrcKey = (function() {
@@ -9769,7 +10321,7 @@ module.exports = isMasked;
/***/ }),
-/* 129 */
+/* 131 */
/***/ (function(module, exports) {
/**
@@ -9788,7 +10340,7 @@ module.exports = listCacheClear;
/***/ }),
-/* 130 */
+/* 132 */
/***/ (function(module, exports, __webpack_require__) {
var assocIndexOf = __webpack_require__(12);
@@ -9829,7 +10381,7 @@ module.exports = listCacheDelete;
/***/ }),
-/* 131 */
+/* 133 */
/***/ (function(module, exports, __webpack_require__) {
var assocIndexOf = __webpack_require__(12);
@@ -9854,7 +10406,7 @@ module.exports = listCacheGet;
/***/ }),
-/* 132 */
+/* 134 */
/***/ (function(module, exports, __webpack_require__) {
var assocIndexOf = __webpack_require__(12);
@@ -9876,7 +10428,7 @@ module.exports = listCacheHas;
/***/ }),
-/* 133 */
+/* 135 */
/***/ (function(module, exports, __webpack_require__) {
var assocIndexOf = __webpack_require__(12);
@@ -9908,10 +10460,10 @@ module.exports = listCacheSet;
/***/ }),
-/* 134 */
+/* 136 */
/***/ (function(module, exports, __webpack_require__) {
-var Hash = __webpack_require__(80),
+var Hash = __webpack_require__(82),
ListCache = __webpack_require__(10),
Map = __webpack_require__(33);
@@ -9935,7 +10487,7 @@ module.exports = mapCacheClear;
/***/ }),
-/* 135 */
+/* 137 */
/***/ (function(module, exports, __webpack_require__) {
var getMapData = __webpack_require__(14);
@@ -9959,7 +10511,7 @@ module.exports = mapCacheDelete;
/***/ }),
-/* 136 */
+/* 138 */
/***/ (function(module, exports, __webpack_require__) {
var getMapData = __webpack_require__(14);
@@ -9981,7 +10533,7 @@ module.exports = mapCacheGet;
/***/ }),
-/* 137 */
+/* 139 */
/***/ (function(module, exports, __webpack_require__) {
var getMapData = __webpack_require__(14);
@@ -10003,7 +10555,7 @@ module.exports = mapCacheHas;
/***/ }),
-/* 138 */
+/* 140 */
/***/ (function(module, exports, __webpack_require__) {
var getMapData = __webpack_require__(14);
@@ -10031,10 +10583,10 @@ module.exports = mapCacheSet;
/***/ }),
-/* 139 */
+/* 141 */
/***/ (function(module, exports, __webpack_require__) {
-var memoize = __webpack_require__(157);
+var memoize = __webpack_require__(159);
/** Used as the maximum memoize cache size. */
var MAX_MEMOIZE_SIZE = 500;
@@ -10063,7 +10615,7 @@ module.exports = memoizeCapped;
/***/ }),
-/* 140 */
+/* 142 */
/***/ (function(module, exports) {
/**
@@ -10089,7 +10641,7 @@ module.exports = nativeKeysIn;
/***/ }),
-/* 141 */
+/* 143 */
/***/ (function(module, exports, __webpack_require__) {
/* WEBPACK VAR INJECTION */(function(module) {var freeGlobal = __webpack_require__(38);
@@ -10118,7 +10670,7 @@ module.exports = nodeUtil;
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(29)(module)))
/***/ }),
-/* 142 */
+/* 144 */
/***/ (function(module, exports) {
/** Used for built-in method references. */
@@ -10146,7 +10698,7 @@ module.exports = objectToString;
/***/ }),
-/* 143 */
+/* 145 */
/***/ (function(module, exports) {
/**
@@ -10167,7 +10719,7 @@ module.exports = overArg;
/***/ }),
-/* 144 */
+/* 146 */
/***/ (function(module, exports) {
/** Used to detect hot functions by number of calls within a span of milliseconds. */
@@ -10210,7 +10762,7 @@ module.exports = shortOut;
/***/ }),
-/* 145 */
+/* 147 */
/***/ (function(module, exports, __webpack_require__) {
var ListCache = __webpack_require__(10);
@@ -10231,7 +10783,7 @@ module.exports = stackClear;
/***/ }),
-/* 146 */
+/* 148 */
/***/ (function(module, exports) {
/**
@@ -10255,7 +10807,7 @@ module.exports = stackDelete;
/***/ }),
-/* 147 */
+/* 149 */
/***/ (function(module, exports) {
/**
@@ -10275,7 +10827,7 @@ module.exports = stackGet;
/***/ }),
-/* 148 */
+/* 150 */
/***/ (function(module, exports) {
/**
@@ -10295,7 +10847,7 @@ module.exports = stackHas;
/***/ }),
-/* 149 */
+/* 151 */
/***/ (function(module, exports, __webpack_require__) {
var ListCache = __webpack_require__(10),
@@ -10335,10 +10887,10 @@ module.exports = stackSet;
/***/ }),
-/* 150 */
+/* 152 */
/***/ (function(module, exports, __webpack_require__) {
-var memoizeCapped = __webpack_require__(139);
+var memoizeCapped = __webpack_require__(141);
/** Used to match property names within property paths. */
var reLeadingDot = /^\./,
@@ -10369,7 +10921,7 @@ module.exports = stringToPath;
/***/ }),
-/* 151 */
+/* 153 */
/***/ (function(module, exports) {
/** Used for built-in method references. */
@@ -10401,7 +10953,7 @@ module.exports = toSource;
/***/ }),
-/* 152 */
+/* 154 */
/***/ (function(module, exports) {
/**
@@ -10433,10 +10985,10 @@ module.exports = constant;
/***/ }),
-/* 153 */
+/* 155 */
/***/ (function(module, exports, __webpack_require__) {
-var baseFlatten = __webpack_require__(88);
+var baseFlatten = __webpack_require__(90);
/**
* Flattens `array` a single level deep.
@@ -10461,11 +11013,11 @@ module.exports = flatten;
/***/ }),
-/* 154 */
+/* 156 */
/***/ (function(module, exports, __webpack_require__) {
-var baseHasIn = __webpack_require__(91),
- hasPath = __webpack_require__(117);
+var baseHasIn = __webpack_require__(93),
+ hasPath = __webpack_require__(119);
/**
* Checks if `path` is a direct or inherited property of `object`.
@@ -10501,11 +11053,11 @@ module.exports = hasIn;
/***/ }),
-/* 155 */
+/* 157 */
/***/ (function(module, exports, __webpack_require__) {
var isArrayLike = __webpack_require__(24),
- isObjectLike = __webpack_require__(4);
+ isObjectLike = __webpack_require__(6);
/**
* This method is like `_.isArrayLike` except that it also checks if `value`
@@ -10540,12 +11092,12 @@ module.exports = isArrayLikeObject;
/***/ }),
-/* 156 */
+/* 158 */
/***/ (function(module, exports, __webpack_require__) {
-var baseGetTag = __webpack_require__(7),
+var baseGetTag = __webpack_require__(8),
getPrototype = __webpack_require__(39),
- isObjectLike = __webpack_require__(4);
+ isObjectLike = __webpack_require__(6);
/** `Object#toString` result references. */
var objectTag = '[object Object]';
@@ -10608,7 +11160,7 @@ module.exports = isPlainObject;
/***/ }),
-/* 157 */
+/* 159 */
/***/ (function(module, exports, __webpack_require__) {
var MapCache = __webpack_require__(34);
@@ -10687,11 +11239,11 @@ module.exports = memoize;
/***/ }),
-/* 158 */
+/* 160 */
/***/ (function(module, exports, __webpack_require__) {
-var basePick = __webpack_require__(98),
- flatRest = __webpack_require__(114);
+var basePick = __webpack_require__(100),
+ flatRest = __webpack_require__(116);
/**
* Creates an object composed of the picked `object` properties.
@@ -10718,7 +11270,7 @@ module.exports = pick;
/***/ }),
-/* 159 */
+/* 161 */
/***/ (function(module, exports) {
/**
@@ -10742,10 +11294,10 @@ module.exports = stubFalse;
/***/ }),
-/* 160 */
+/* 162 */
/***/ (function(module, exports, __webpack_require__) {
-var copyObject = __webpack_require__(110),
+var copyObject = __webpack_require__(112),
keysIn = __webpack_require__(46);
/**
@@ -10780,10 +11332,10 @@ module.exports = toPlainObject;
/***/ }),
-/* 161 */
+/* 163 */
/***/ (function(module, exports, __webpack_require__) {
-var baseToString = __webpack_require__(104);
+var baseToString = __webpack_require__(106);
/**
* Converts `value` to a string. An empty string is returned for `null`
@@ -10814,25 +11366,25 @@ module.exports = toString;
/***/ }),
-/* 162 */
+/* 164 */
/***/ (function(module, exports) {
-module.exports = __WEBPACK_EXTERNAL_MODULE_162__;
+module.exports = __WEBPACK_EXTERNAL_MODULE_164__;
/***/ }),
-/* 163 */
+/* 165 */
/***/ (function(module, exports) {
-module.exports = __WEBPACK_EXTERNAL_MODULE_163__;
+module.exports = __WEBPACK_EXTERNAL_MODULE_165__;
/***/ }),
-/* 164 */
+/* 166 */
/***/ (function(module, exports) {
-module.exports = __WEBPACK_EXTERNAL_MODULE_164__;
+module.exports = __WEBPACK_EXTERNAL_MODULE_166__;
/***/ }),
-/* 165 */
+/* 167 */
/***/ (function(module, exports, __webpack_require__) {
module.exports = __webpack_require__(48);
@@ -10841,4 +11393,4 @@ module.exports = __webpack_require__(48);
/***/ })
/******/ ]);
});
-//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 8cd55a915b241b5a1992","webpack:///./~/lodash/isObject.js","webpack:///./~/lodash/isArray.js","webpack:///./src/reader/ean_reader.js","webpack:///./~/lodash/_root.js","webpack:///./~/lodash/isObjectLike.js","webpack:///./src/reader/barcode_reader.js","webpack:///./~/gl-vec2/clone.js","webpack:///./~/lodash/_baseGetTag.js","webpack:///./src/common/array_helper.js","webpack:///./src/common/image_debug.js","webpack:///./~/lodash/_ListCache.js","webpack:///./~/lodash/_Symbol.js","webpack:///./~/lodash/_assocIndexOf.js","webpack:///./~/lodash/_castPath.js","webpack:///./~/lodash/_getMapData.js","webpack:///./~/lodash/_isIndex.js","webpack:///./~/lodash/_nativeCreate.js","webpack:///./~/lodash/eq.js","webpack:///./~/lodash/isArguments.js","webpack:///./src/common/cv_utils.js","webpack:///./src/common/image_wrapper.js","webpack:///./~/lodash/_baseAssignValue.js","webpack:///./~/lodash/_getNative.js","webpack:///./~/lodash/_toKey.js","webpack:///./~/lodash/isArrayLike.js","webpack:///./~/lodash/isFunction.js","webpack:///./~/lodash/isLength.js","webpack:///./~/lodash/isSymbol.js","webpack:///./~/lodash/merge.js","webpack:///(webpack)/buildin/module.js","webpack:///./src/locator/tracer.js","webpack:///./src/reader/code_39_reader.js","webpack:///./~/gl-vec2/dot.js","webpack:///./~/lodash/_Map.js","webpack:///./~/lodash/_MapCache.js","webpack:///./~/lodash/_assignMergeValue.js","webpack:///./~/lodash/_assignValue.js","webpack:///./~/lodash/_defineProperty.js","webpack:///./~/lodash/_freeGlobal.js","webpack:///./~/lodash/_getPrototype.js","webpack:///./~/lodash/_isPrototype.js","webpack:///./~/lodash/_overRest.js","webpack:///./~/lodash/_setToString.js","webpack:///./~/lodash/identity.js","webpack:///./~/lodash/isBuffer.js","webpack:///./~/lodash/isTypedArray.js","webpack:///./~/lodash/keysIn.js","webpack:///(webpack)/buildin/global.js","webpack:///./src/quagga.js","webpack:///./lib/frame_grabber.js","webpack:///./lib/input_stream.js","webpack:///./src/analytics/result_collector.js","webpack:///./src/common/cluster.js","webpack:///./src/common/events.js","webpack:///./src/common/mediaDevices.js","webpack:///./src/common/subImage.js","webpack:///./src/common/typedefs.js","webpack:///./src/config/config.js","webpack:///./src/config/config.node.js","webpack:///./src/decoder/barcode_decoder.js","webpack:///./src/decoder/bresenham.js","webpack:///./src/input/camera_access.js","webpack:///./src/locator/barcode_locator.js","webpack:///./src/locator/rasterizer.js","webpack:///./src/locator/skeletonizer.js","webpack:///./src/reader/codabar_reader.js","webpack:///./src/reader/code_128_reader.js","webpack:///./src/reader/code_39_vin_reader.js","webpack:///./src/reader/ean_2_reader.js","webpack:///./src/reader/ean_5_reader.js","webpack:///./src/reader/ean_8_reader.js","webpack:///./src/reader/i2of5_reader.js","webpack:///./src/reader/upc_e_reader.js","webpack:///./src/reader/upc_reader.js","webpack:///./~/gl-mat2/copy.js","webpack:///./~/gl-mat2/create.js","webpack:///./~/gl-mat2/invert.js","webpack:///./~/gl-vec2/scale.js","webpack:///./~/gl-vec2/transformMat2.js","webpack:///./~/gl-vec3/clone.js","webpack:///./~/lodash/_Hash.js","webpack:///./~/lodash/_Stack.js","webpack:///./~/lodash/_Uint8Array.js","webpack:///./~/lodash/_apply.js","webpack:///./~/lodash/_arrayLikeKeys.js","webpack:///./~/lodash/_arrayMap.js","webpack:///./~/lodash/_arrayPush.js","webpack:///./~/lodash/_baseCreate.js","webpack:///./~/lodash/_baseFlatten.js","webpack:///./~/lodash/_baseFor.js","webpack:///./~/lodash/_baseGet.js","webpack:///./~/lodash/_baseHasIn.js","webpack:///./~/lodash/_baseIsArguments.js","webpack:///./~/lodash/_baseIsNative.js","webpack:///./~/lodash/_baseIsTypedArray.js","webpack:///./~/lodash/_baseKeysIn.js","webpack:///./~/lodash/_baseMerge.js","webpack:///./~/lodash/_baseMergeDeep.js","webpack:///./~/lodash/_basePick.js","webpack:///./~/lodash/_basePickBy.js","webpack:///./~/lodash/_baseRest.js","webpack:///./~/lodash/_baseSet.js","webpack:///./~/lodash/_baseSetToString.js","webpack:///./~/lodash/_baseTimes.js","webpack:///./~/lodash/_baseToString.js","webpack:///./~/lodash/_baseUnary.js","webpack:///./~/lodash/_cloneArrayBuffer.js","webpack:///./~/lodash/_cloneBuffer.js","webpack:///./~/lodash/_cloneTypedArray.js","webpack:///./~/lodash/_copyArray.js","webpack:///./~/lodash/_copyObject.js","webpack:///./~/lodash/_coreJsData.js","webpack:///./~/lodash/_createAssigner.js","webpack:///./~/lodash/_createBaseFor.js","webpack:///./~/lodash/_flatRest.js","webpack:///./~/lodash/_getRawTag.js","webpack:///./~/lodash/_getValue.js","webpack:///./~/lodash/_hasPath.js","webpack:///./~/lodash/_hashClear.js","webpack:///./~/lodash/_hashDelete.js","webpack:///./~/lodash/_hashGet.js","webpack:///./~/lodash/_hashHas.js","webpack:///./~/lodash/_hashSet.js","webpack:///./~/lodash/_initCloneObject.js","webpack:///./~/lodash/_isFlattenable.js","webpack:///./~/lodash/_isIterateeCall.js","webpack:///./~/lodash/_isKey.js","webpack:///./~/lodash/_isKeyable.js","webpack:///./~/lodash/_isMasked.js","webpack:///./~/lodash/_listCacheClear.js","webpack:///./~/lodash/_listCacheDelete.js","webpack:///./~/lodash/_listCacheGet.js","webpack:///./~/lodash/_listCacheHas.js","webpack:///./~/lodash/_listCacheSet.js","webpack:///./~/lodash/_mapCacheClear.js","webpack:///./~/lodash/_mapCacheDelete.js","webpack:///./~/lodash/_mapCacheGet.js","webpack:///./~/lodash/_mapCacheHas.js","webpack:///./~/lodash/_mapCacheSet.js","webpack:///./~/lodash/_memoizeCapped.js","webpack:///./~/lodash/_nativeKeysIn.js","webpack:///./~/lodash/_nodeUtil.js","webpack:///./~/lodash/_objectToString.js","webpack:///./~/lodash/_overArg.js","webpack:///./~/lodash/_shortOut.js","webpack:///./~/lodash/_stackClear.js","webpack:///./~/lodash/_stackDelete.js","webpack:///./~/lodash/_stackGet.js","webpack:///./~/lodash/_stackHas.js","webpack:///./~/lodash/_stackSet.js","webpack:///./~/lodash/_stringToPath.js","webpack:///./~/lodash/_toSource.js","webpack:///./~/lodash/constant.js","webpack:///./~/lodash/flatten.js","webpack:///./~/lodash/hasIn.js","webpack:///./~/lodash/isArrayLikeObject.js","webpack:///./~/lodash/isPlainObject.js","webpack:///./~/lodash/memoize.js","webpack:///./~/lodash/pick.js","webpack:///./~/lodash/stubFalse.js","webpack:///./~/lodash/toPlainObject.js","webpack:///./~/lodash/toString.js","webpack:///external \"get-pixels\"","webpack:///external \"ndarray\"","webpack:///external \"ndarray-linear-interpolate\""],"names":["EANReader","opts","supplements","getDefaulConfig","call","config","Object","keys","CONFIG_KEYS","forEach","key","default","properties","CODE_L_START","value","CODE_G_START","START_PATTERN","STOP_PATTERN","MIDDLE_PATTERN","EXTENSION_START_PATTERN","CODE_PATTERN","CODE_FREQUENCY","SINGLE_CODE_ERROR","AVG_CODE_ERROR","FORMAT","writeable","prototype","create","constructor","_decodeCode","start","coderange","counter","i","self","offset","isWhite","_row","counterPos","bestMatch","error","Number","MAX_VALUE","code","end","length","_matchPattern","_findPattern","pattern","tryHarder","epsilon","j","sum","_nextSet","undefined","_findStart","leadingWhitespaceStart","startInfo","_matchRange","_verifyTrailingWhitespace","endInfo","trailingWhitespaceEnd","_findEnd","_calculateFirstDigit","codeFrequency","_decodePayload","result","decodedCodes","firstDigit","push","unshift","_decode","resultInfo","_checksum","ext","_decodeExtensions","lastCode","supplement","join","codeset","decode","BarcodeReader","_nextUnset","line","maxSingleError","singleError","modulo","barWidth","count","scaled","Math","abs","_correctBars","correction","indices","tmp","_matchTrace","cmpCounter","decodePattern","reverse","direction","DIRECTION","REVERSE","FORWARD","format","_fillCounters","counters","defineProperty","Exception","StartNotFoundException","CodeNotFoundException","PatternNotFoundException","init","arr","val","l","shuffle","x","floor","random","toPointList","row","rows","threshold","scoreFunc","queue","apply","maxIndex","max","drawRect","pos","size","ctx","style","strokeStyle","color","fillStyle","lineWidth","beginPath","strokeRect","y","drawPath","path","def","moveTo","lineTo","closePath","stroke","drawImage","imageData","canvasData","getImageData","data","imageDataPos","canvasDataPos","putImageData","imageRef","computeIntegralImage2","computeIntegralImage","thresholdImage","computeHistogram","sharpenLine","determineOtsuThreshold","otsuThreshold","computeBinaryImage","cluster","dilate","erode","subtract","bitwiseOr","countNonZero","topGeneric","grayArrayFromImage","grayArrayFromContext","grayAndHalfSampleFromCanvasData","computeGray","loadImageArray","halfSample","hsv2rgb","_computeDivisors","calculatePatchSize","_parseCSSDimensionValues","computeImageArea","vec2","clone","require","vec3","that","toVec2","toVec3","round","imageWrapper","integralWrapper","width","height","integralImageData","posA","posB","posC","posD","v","u","targetWrapper","targetData","bitsPerPixel","bitShift","bucketCnt","hist","Int32Array","left","center","right","px","mx","determineThreshold","vet","p1","p2","p12","k","m1","m2","m12","kernel","A","B","C","D","avg","points","property","point","clusters","addToCluster","newPoint","found","fits","add","createPoint","Tracer","trace","vec","iteration","maxIterations","top","centerPos","currentPos","idx","forward","from","to","toIdx","predictedPos","thresholdX","thresholdY","match","predicted","DILATE","ERODE","inImageWrapper","outImageWrapper","inImageData","outImageData","yStart1","yStart2","xStart1","xStart2","aImageWrapper","bImageWrapper","resultImageWrapper","aImageData","bImageData","cImageData","list","minIdx","min","score","hit","item","htmlImage","offsetX","array","ctxData","outArray","topRowIdx","bottomRowIdx","endIdx","outWidth","outImgIdx","inWidth","singleChannel","src","callback","canvas","document","createElement","img","Image","onload","getContext","Uint8Array","inImgWrapper","outImgWrapper","inImg","outImg","hsv","rgb","h","s","c","m","r","g","b","n","largeDivisors","divisors","sqrt","concat","_computeIntersection","arr1","arr2","patchSize","imgSize","divisorsX","divisorsY","wideSide","common","nrOfPatchesList","nrOfPatchesMap","nrOfPatchesIdx","medium","nrOfPatches","desiredPatchSize","optimalPatchSize","findPatchSizeForDivisors","dimension","parseFloat","unit","indexOf","_dimensionsConverters","context","bottom","inputWidth","inputHeight","area","parsedArea","reduce","parsed","calculated","sx","sy","sw","sh","ImageWrapper","ArrayType","initialize","Array","inImageWithBorder","imgRef","border","sample","lx","ly","w","base","a","d","e","clearArray","subImage","subImageAsCopy","sizeY","sizeX","copyTo","srcData","dstData","get","getSafe","indexMapping","set","zeroBorder","invert","convolve","kx","ky","kSize","accu","moments","labelcount","ysq","labelsum","label","mu11","mu02","mu20","x_","y_","PI","PI_4","m00","m01","m10","m11","m02","m20","theta","rad","isNaN","atan","cos","sin","show","scale","frame","current","pixel","overlay","whiteRgb","blackRgb","searchDirections","labelWrapper","labelData","edgelabel","cy","dir","cx","vertex2D","next","prev","contourTracing","Fv","Cv","P","ldir","Code39Reader","ALPHABETH_STRING","ALPHABET","CHARACTER_ENCODINGS","ASTERISK","_toCounters","numCounters","decodedChar","lastStart","nextStart","_toPattern","_patternToChar","pop","patternSize","String","fromCharCode","_findNextWidth","minWidth","maxNarrowWidth","numWideBars","wideBarWidth","patternStart","whiteSpaceMustStart","_inputStream","_framegrabber","_stopped","_canvasContainer","image","dom","_inputImageWrapper","_boxSize","_decoder","_workerPool","_onUIThread","_resultCollector","_config","initializeData","initBuffers","decoder","initInputStream","cb","video","inputStream","type","createVideoStream","createImageStream","$viewport","getViewPort","querySelector","appendChild","createLiveStream","request","constraints","then","trigger","catch","err","setAttribute","setInputStream","addEventListener","canRecord","bind","target","nodeName","nodeType","selector","checkImageConstraints","locator","initCanvas","adjustWorkerPool","numOfWorkers","ready","play","className","getCanvasSize","clearFix","getWidth","getHeight","console","log","getBoundingBoxes","locate","transformResult","topRight","getTopRight","xOffset","yOffset","barcodes","moveLine","box","moveBox","boxes","corner","addResult","filter","barcode","codeResult","hasCodeResult","some","publishResult","resultToPublish","publish","locateAndDecode","decodeFromBoundingBoxes","update","availableWorker","workerThread","busy","attachData","grab","worker","postMessage","cmd","buffer","startContinuousUpdate","delay","frequency","timestamp","window","requestAnimFrame","performance","now","initWorker","blobURL","generateWorkerBlob","Worker","onmessage","event","URL","revokeObjectURL","message","configForWorker","workerInterface","factory","Quagga","onProcessed","setReaders","readers","blob","factorySource","__factorySource__","Blob","toString","createObjectURL","capacity","increaseBy","workersToTerminate","slice","terminate","workerInitialized","stop","release","clearEventHandlers","pause","onDetected","subscribe","offDetected","unsubscribe","offProcessed","registerResultCollector","resultCollector","decodeSingle","resultCallback","sequence","once","ImageDebug","ResultCollector","CameraAccess","CVUtils","Ndarray","Interp2D","d2","FrameGrabber","_that","_streamConfig","getConfig","_video_size","getRealWidth","getRealHeight","_canvasSize","_size","_topRight","_data","_grayData","_canvasData","_grayImageArray","transpose","_canvasImageArray","_targetImageArray","hi","lo","_stepSizeX","_stepSizeY","JSON","stringify","videoSize","shape","canvasSize","stepSize","getData","getFrame","scaleAndCrop","Error","getSize","module","exports","GetPixels","InputStream","frameIdx","paused","loaded","baseUrl","ended","calculatedWidth","calculatedHeight","_eventNames","_eventHandlers","loadImages","pixels","exit","setTimeout","publishEvent","eventName","args","handlers","setWidth","setHeight","stream","setCurrentTime","time","f","setTopRight","setCanvasSize","contains","every","passesFilter","results","capture","matchesConstraints","blacklist","imageSize","toDataURL","getResults","dot","pointMap","updateCenter","pointToAdd","id","otherPoint","similarity","getPoints","getCenter","events","getEvent","subscribers","clearEvents","publishSubscription","subscription","async","subscriber","enumerateDevices","getUserMedia","navigator","mediaDevices","Promise","reject","SubImage","I","originalSize","updateData","updateFrom","requestAnimationFrame","webkitRequestAnimationFrame","mozRequestAnimationFrame","oRequestAnimationFrame","msRequestAnimationFrame","imul","ah","al","bh","bl","assign","TypeError","index","arguments","nextSource","nextKey","hasOwnProperty","READERS","code_128_reader","ean_reader","ean_5_reader","ean_2_reader","ean_8_reader","code_39_reader","code_39_vin_reader","codabar_reader","upc_reader","upc_e_reader","i2of5_reader","inputImageWrapper","_canvas","_barcodeReaders","initReaders","initConfig","$debug","readerConfig","reader","configuration","map","vis","node","prop","debug","showFrequency","showPattern","display","getExtendedLine","angle","extendLine","amount","extension","ceil","getLine","tryDecode","barcodeLine","getBarcodeLine","printFrequency","toBinaryLine","printPattern","tryDecodeBruteForce","lineAngle","sideLength","pow","slices","xdir","ydir","getLineLength","decodeFromBoundingBox","lineLength","drawBoundingBox","atan2","multiple","Bresenham","Slope","DIR","UP","DOWN","x0","y0","x1","y1","steep","deltax","deltay","ystep","read","slope","slope2","extrema","currentDir","rThreshold","fillColor","fillRect","pickConstraints","facingMatching","streamRef","waitForVideo","resolve","attempts","checkVideo","videoWidth","videoHeight","initCamera","srcObject","deprecatedConstraints","videoConstraints","normalized","minAspectRatio","aspectRatio","facing","facingMode","normalizedConstraints","audio","deviceId","enumerateVideoDevices","devices","device","kind","tracks","getVideoTracks","getActiveStreamLabel","transformMat2","mat2","copy","_currentImageWrapper","_skelImageWrapper","_subImageWrapper","_labelImageWrapper","_patchGrid","_patchLabelGrid","_imageToPatchGrid","_binaryImageWrapper","_patchSize","binary","_numPatches","_skeletonizer","skeletonImageData","ArrayBuffer","global","useWorker","boxFromPatches","patches","overAvg","patch","transMat","minx","miny","maxx","maxy","binarizeImage","findPatches","patchesFound","rasterizer","rasterResult","skeletonize","rasterize","describePatch","findBiggestConnectedAreas","maxLabel","labelHist","topLabels","sort","el","findBoxes","similarMoments","topCluster","patchPos","eligibleMoments","matchingMoments","minComponentWeight","rasterizeAngularSimilarity","currIdx","notYetProcessed","currentIdx","currentPatch","Rasterizer","createContour2D","firstVertex","insideContours","nextpeer","prevpeer","CONTOUR_DIR","CW_DIR","CCW_DIR","UNKNOWN_DIR","OUTSIDE_EDGE","INSIDE_EDGE","tracer","depthlabel","bc","lc","labelindex","colorMap","vertex","p","cc","sc","connectedCount","drawContour","firstContour","pq","iq","q","Skeletonizer","stdlib","foreign","images","inImagePtr","outImagePtr","aImagePtr","bImagePtr","imagePtr","memcpy","srcImagePtr","dstImagePtr","subImagePtr","erodedImagePtr","tempImagePtr","skelImagePtr","done","CodabarReader","_counters","START_END","MIN_ENCODED_CHARS","MAX_ACCEPTABLE","PADDING","startCounter","_isStartEnd","_verifyWhitespace","_validateResult","_sumCounters","endCounter","_calculatePatternLength","_thresholdResultPattern","categorization","space","narrow","counts","wide","bar","cat","_charToPattern","newkind","char","charCode","charCodeAt","thresholds","_computeAlternatingThreshold","barThreshold","spaceThreshold","bitmask","Code128Reader","CODE_SHIFT","CODE_C","CODE_B","CODE_A","START_CODE_A","START_CODE_B","START_CODE_C","STOP_CODE","MODULE_INDICES","_correct","calculateCorrection","multiplier","checksum","rawResult","shiftNext","removeLastCharacter","splice","expected","sumNormalized","sumExpected","Code39VINReader","patterns","IOQ","AZ09","replace","_checkChecksum","EAN2Reader","parseInt","EAN5Reader","CHECK_DIGIT_ENCODINGS","extensionChecksum","determineCheckDigit","EAN8Reader","I2of5Reader","barSpaceRatio","normalizeBarSpaceWidth","N","W","writable","MAX_CORRECTION_FACTOR","counterSum","codeSum","correctionRatio","correctionRatioInverse","narrowBarWidth","_decodePair","counterPair","codes","counterLength","_verifyCounterLength","UPCEReader","_determineParity","nrSystem","_convertToUPCA","upca","lastDigit","UPCReader","charAt","substring"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA,mDAA2C,cAAc;;AAEzD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAK;AACL;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;AAEA;AACA;;;;;;;AChEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;;;;;;;ACzBA;;;;;;AAGA,SAASA,SAAT,CAAmBC,IAAnB,EAAyBC,WAAzB,EAAsC;AAClCD,WAAO,qBAAME,iBAAN,EAAyBF,IAAzB,CAAP;AACA,6BAAcG,IAAd,CAAmB,IAAnB,EAAyBH,IAAzB,EAA+BC,WAA/B;AACH;;AAED,SAASC,eAAT,GAA2B;AACvB,QAAIE,SAAS,EAAb;;AAEAC,WAAOC,IAAP,CAAYP,UAAUQ,WAAtB,EAAmCC,OAAnC,CAA2C,UAASC,GAAT,EAAc;AACrDL,eAAOK,GAAP,IAAcV,UAAUQ,WAAV,CAAsBE,GAAtB,EAA2BC,OAAzC;AACH,KAFD;AAGA,WAAON,MAAP;AACH;;AAED,IAAIO,aAAa;AACbC,kBAAc,EAACC,OAAO,CAAR,EADD;AAEbC,kBAAc,EAACD,OAAO,EAAR,E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;AACA;;AAEA;;;;;;;AC/BA;;AAEA;AACA;;AAEA;;;;;;;ACLA;;AAEA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA,iBAAiB;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA,6BAA6B,kBAAkB,EAAE;AACjD;AACA;AACA;AACA;AACA;AACA,8CAA8C,kBAAkB,EAAE;AAClE;AACA;AACA;;AAEA;;;;;;;;;;;;QCrBgBM,Q,GAAAA,Q;QAuBAC,qB,GAAAA,qB;QA2CAC,oB,GAAAA,oB;QAsBAC,c,GAAAA,c;QAWAC,gB,GAAAA,gB;QAgBAC,W,GAAAA,W;QAiBAC,sB,GAAAA,sB;Q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AAEA;;;;;;;AChCA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClCA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,UAAU;AACrB,aAAa,OAAO;AACpB;AACA;AACA;AACA,YAAY,SAAS,GAAG,SAAS;AACjC;AACA;AACA;AACA,YAAY,SAAS,GAAG,SAAS;AACjC;AACA;AACA;AACA,UAAU,QAAQ,iBAAiB,GAAG,iBAAiB;AACvD;AACA;AACA;AACA,CAAC;;AAED;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;;;;;;;;;;ACrBA;;;AAGA,IAAInH,SAAS;AACTqL,sBAAkB,CAAC,CAAC,CAAD,EAAI,CAAJ,CAAD,EAAS,CAAC,CAAD,EAAI,CAAJ,CAAT,EAAiB,CAAC,CAAD,EAAI,CAAJ,CAAjB,EAAyB,CAAC,CAAD,EAAI,CAAC,CAAL,CAAzB,EAAkC,CAAC,CAAD,EAAI,CAAC,CAA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AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB;AACA,GAAG;AACH,CAAC;;AAED;;;;;;;ACVA;AACA;;AAEA;;;;;;;;ACHA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnCA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,EAAE;AACf;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;ACrCA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;A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AAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,C;;;;;;AChBA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,C;;;;;;ACdA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,EAAE;AACb,WAAW,MAAM;AACjB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,QAAQ;AACnB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChDA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,SAAS;AACpB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;;;;;;;AC7BA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,EAAE;AACf;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvBA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oCAAoC;;AAEpC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC9CA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3DA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5FA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;AClBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,WAAW,EAAE;AACb,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC9CA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;;AAEA;AACA;AACA;AACA;AACA,WAAW,YAAY;AACvB,aAAa,YAAY;AACzB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;;AClCA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,MAAM;AACjB,WAAW,OAAO,WAAW;AAC7B,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA,wBAAwB;;AAExB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvCA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACpCA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7CA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,WAAW,SAAS;AACpB,aAAa,QAAQ;AACrB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,EAAE;AACb,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,CAAC;;AAED;;;;;;;;ACrBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjCA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,CAAC;;AAED;;;;;;;AC3BA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,SAAS;AACtB;AACA;AACA,wCAAwC,SAAS;AACjD;AACA;AACA,WAAW,SAAS,GAAG,SAAS;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACA;AACA,0BAA0B,gBAAgB,SAAS,GAAG;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjCA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7DA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA,iBAAiB;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACxEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,qBAAqB;AAChC,aAAa,OAAO;AACpB;AACA;AACA,iBAAiB;AACjB;AACA;AACA,UAAU;AACV;AACA;AACA,4BAA4B;AAC5B,CAAC;;AAED;;;;;;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS;AACtB,UAAU;AACV;AACA,aAAa,SAAS;AACtB,UAAU;AACV;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA,iD;;;;;;ACAA,iD;;;;;;ACAA,iD","file":"quagga.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"get-pixels\"), require(\"ndarray\"), require(\"ndarray-linear-interpolate\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"get-pixels\", \"ndarray\", \"ndarray-linear-interpolate\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Quagga\"] = factory(require(\"get-pixels\"), require(\"ndarray\"), require(\"ndarray-linear-interpolate\"));\n\telse\n\t\troot[\"Quagga\"] = factory(root[\"get-pixels\"], root[\"ndarray\"], root[\"ndarray-linear-interpolate\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE_162__, __WEBPACK_EXTERNAL_MODULE_163__, __WEBPACK_EXTERNAL_MODULE_164__) {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 165);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 8cd55a915b241b5a1992","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n  var type = typeof value;\n  return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isObject.js\n// module id = 0\n// module chunks = 0","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArray.js\n// module id = 1\n// module chunks = 0","import BarcodeReader from './barcode_reader';\nimport {merge} from 'lodash';\n\nfunction EANReader(opts, supplements) {\n    opts = merge(getDefaulConfig(), opts);\n    BarcodeReader.call(this, opts, supplements);\n}\n\nfunction getDefaulConfig() {\n    var config = {};\n\n    Object.keys(EANReader.CONFIG_KEYS).forEach(function(key) {\n        config[key] = EANReader.CONFIG_KEYS[key].default;\n    });\n    return config;\n}\n\nvar properties = {\n    CODE_L_START: {value: 0},\n    CODE_G_START: {value: 10},\n    START_PATTERN: {value: [1, 1, 1]},\n    STOP_PATTERN: {value: [1, 1, 1]},\n    MIDDLE_PATTERN: {value: [1, 1, 1, 1, 1]},\n    EXTENSION_START_PATTERN: {value: [1, 1, 2]},\n    CODE_PATTERN: {value: [\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    ]},\n    CODE_FREQUENCY: {value: [0, 11, 13, 14, 19, 25, 28, 21, 22, 26]},\n    SINGLE_CODE_ERROR: {value: 0.70},\n    AVG_CODE_ERROR: {value: 0.48},\n    FORMAT: {value: \"ean_13\", writeable: false}\n};\n\nEANReader.prototype = Object.create(BarcodeReader.prototype, properties);\nEANReader.prototype.constructor = EANReader;\n\nEANReader.prototype._decodeCode = function(start, coderange) {\n    var counter = [0, 0, 0, 0],\n        i,\n        self = this,\n        offset = start,\n        isWhite = !self._row[offset],\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: start,\n            end: start\n        },\n        code,\n        error;\n\n    if (!coderange) {\n        coderange = self.CODE_PATTERN.length;\n    }\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                for (code = 0; code < coderange; code++) {\n                    error = self._matchPattern(counter, self.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 > self.AVG_CODE_ERROR) {\n                    return null;\n                }\n                return bestMatch;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder, epsilon) {\n    var counter = [],\n        self = this,\n        i,\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        },\n        error,\n        j,\n        sum;\n\n    if (!offset) {\n        offset = self._nextSet(self._row);\n    }\n\n    if (isWhite === undefined) {\n        isWhite = false;\n    }\n\n    if (tryHarder === undefined) {\n        tryHarder = true;\n    }\n\n    if ( epsilon === undefined) {\n        epsilon = self.AVG_CODE_ERROR;\n    }\n\n    for ( i = 0; i < pattern.length; i++) {\n        counter[i] = 0;\n    }\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                sum = 0;\n                for ( j = 0; j < counter.length; j++) {\n                    sum += counter[j];\n                }\n                error = self._matchPattern(counter, pattern);\n\n                if (error < epsilon) {\n                    bestMatch.error = error;\n                    bestMatch.start = i - sum;\n                    bestMatch.end = i;\n                    return bestMatch;\n                }\n                if (tryHarder) {\n                    for ( j = 0; j < counter.length - 2; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[counter.length - 2] = 0;\n                    counter[counter.length - 1] = 0;\n                    counterPos--;\n                } else {\n                    return null;\n                }\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._findStart = function() {\n    var self = this,\n        leadingWhitespaceStart,\n        offset = self._nextSet(self._row),\n        startInfo;\n\n    while (!startInfo) {\n        startInfo = self._findPattern(self.START_PATTERN, offset);\n        if (!startInfo) {\n            return null;\n        }\n        leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);\n        if (leadingWhitespaceStart >= 0) {\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                return startInfo;\n            }\n        }\n        offset = startInfo.end;\n        startInfo = null;\n    }\n};\n\nEANReader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._findEnd = function(offset, isWhite) {\n    var self = this,\n        endInfo = self._findPattern(self.STOP_PATTERN, offset, isWhite, false);\n\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\n};\n\nEANReader.prototype._calculateFirstDigit = function(codeFrequency) {\n    var i,\n        self = this;\n\n    for ( i = 0; i < self.CODE_FREQUENCY.length; i++) {\n        if (codeFrequency === self.CODE_FREQUENCY[i]) {\n            return i;\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._decodePayload = function(code, result, decodedCodes) {\n    var i,\n        self = this,\n        codeFrequency = 0x0,\n        firstDigit;\n\n    for ( i = 0; i < 6; i++) {\n        code = self._decodeCode(code.end);\n        if (!code) {\n            return null;\n        }\n        if (code.code >= self.CODE_G_START) {\n            code.code = code.code - self.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    firstDigit = self._calculateFirstDigit(codeFrequency);\n    if (firstDigit === null) {\n        return null;\n    }\n    result.unshift(firstDigit);\n\n    code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);\n    if (code === null) {\n        return null;\n    }\n    decodedCodes.push(code);\n\n    for ( i = 0; i < 6; i++) {\n        code = self._decodeCode(code.end, self.CODE_G_START);\n        if (!code) {\n            return null;\n        }\n        decodedCodes.push(code);\n        result.push(code.code);\n    }\n\n    return code;\n};\n\nEANReader.prototype._decode = function() {\n    var startInfo,\n        self = this,\n        code,\n        result = [],\n        decodedCodes = [],\n        resultInfo = {};\n\n    startInfo = self._findStart();\n    if (!startInfo) {\n        return null;\n    }\n    code = {\n        code: startInfo.code,\n        start: startInfo.start,\n        end: startInfo.end\n    };\n    decodedCodes.push(code);\n    code = self._decodePayload(code, result, decodedCodes);\n    if (!code) {\n        return null;\n    }\n    code = self._findEnd(code.end, false);\n    if (!code){\n        return null;\n    }\n\n    decodedCodes.push(code);\n\n    // Checksum\n    if (!self._checksum(result)) {\n        return null;\n    }\n\n    if (this.supplements.length > 0) {\n        let ext = this._decodeExtensions(code.end);\n        if (!ext) {\n            return null;\n        }\n        let lastCode = ext.decodedCodes[ext.decodedCodes.length-1],\n            endInfo = {\n                start: lastCode.start + (((lastCode.end - lastCode.start) / 2) | 0),\n                end: lastCode.end\n            };\n        if(!self._verifyTrailingWhitespace(endInfo)) {\n            return null;\n        }\n        resultInfo = {\n            supplement: ext,\n            code: result.join(\"\") + ext.code\n        }\n    }\n\n    return {\n        code: result.join(\"\"),\n        start: startInfo.start,\n        end: code.end,\n        codeset: \"\",\n        startInfo: startInfo,\n        decodedCodes: decodedCodes,\n        ...resultInfo\n    };\n};\n\nEANReader.prototype._decodeExtensions = function(offset) {\n    var i,\n        start = this._nextSet(this._row, offset),\n        startInfo = this._findPattern(this.EXTENSION_START_PATTERN, start, false, false),\n        result;\n\n    if (startInfo === null) {\n        return null;\n    }\n\n    for (i = 0; i < this.supplements.length; i++) {\n        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                codeset: \"\",\n                decodedCodes: result.decodedCodes\n            }\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._checksum = function(result) {\n    var sum = 0, i;\n\n    for ( i = result.length - 2; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    sum *= 3;\n    for ( i = result.length - 1; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    return sum % 10 === 0;\n};\n\nEANReader.CONFIG_KEYS = {\n    supplements: {\n        'type': 'arrayOf(string)',\n        'default': [],\n        'description': 'Allowed extensions to be decoded (2 and/or 5)'\n    }\n};\n\nexport default (EANReader);\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_reader.js","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_root.js\n// module id = 3\n// module chunks = 0","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isObjectLike.js\n// module id = 4\n// module chunks = 0","function BarcodeReader(config, supplements) {\n    this._row = [];\n    this.config = config || {};\n    this.supplements = supplements;\n    return this;\n}\n\nBarcodeReader.prototype._nextUnset = function(line, start) {\n    var i;\n\n    if (start === undefined) {\n        start = 0;\n    }\n    for (i = start; i < line.length; i++) {\n        if (!line[i]) {\n            return i;\n        }\n    }\n    return line.length;\n};\n\nBarcodeReader.prototype._matchPattern = function(counter, code, maxSingleError) {\n    var i,\n        error = 0,\n        singleError = 0,\n        sum = 0,\n        modulo = 0,\n        barWidth,\n        count,\n        scaled;\n\n    maxSingleError = maxSingleError || this.SINGLE_CODE_ERROR || 1;\n\n    for (i = 0; i < counter.length; i++) {\n        sum += counter[i];\n        modulo += code[i];\n    }\n    if (sum < modulo) {\n        return Number.MAX_VALUE;\n    }\n    barWidth = sum / modulo;\n    maxSingleError *= barWidth;\n\n    for (i = 0; i < counter.length; i++) {\n        count = counter[i];\n        scaled = code[i] * barWidth;\n        singleError = Math.abs(count - scaled) / scaled;\n        if (singleError > maxSingleError) {\n            return Number.MAX_VALUE;\n        }\n        error += singleError;\n    }\n    return error / modulo;\n};\n\nBarcodeReader.prototype._nextSet = function(line, offset) {\n    var i;\n\n    offset = offset || 0;\n    for (i = offset; i < line.length; i++) {\n        if (line[i]) {\n            return i;\n        }\n    }\n    return line.length;\n};\n\nBarcodeReader.prototype._correctBars = function(counter, correction, indices) {\n    var length = indices.length,\n        tmp = 0;\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\nBarcodeReader.prototype._matchTrace = function(cmpCounter, epsilon) {\n    var counter = [],\n        i,\n        self = this,\n        offset = self._nextSet(self._row),\n        isWhite = !self._row[offset],\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0\n        },\n        error;\n\n    if (cmpCounter) {\n        for ( i = 0; i < cmpCounter.length; i++) {\n            counter.push(0);\n        }\n        for ( i = offset; i < self._row.length; i++) {\n            if (self._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    error = self._matchPattern(counter, cmpCounter);\n\n                    if (error < epsilon) {\n                        bestMatch.start = i - offset;\n                        bestMatch.end = i;\n                        bestMatch.counter = counter;\n                        return bestMatch;\n                    } else {\n                        return null;\n                    }\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n    } else {\n        counter.push(0);\n        for ( i = offset; i < self._row.length; i++) {\n            if (self._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                counterPos++;\n                counter.push(0);\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n    }\n\n    // if cmpCounter was not given\n    bestMatch.start = offset;\n    bestMatch.end = self._row.length - 1;\n    bestMatch.counter = counter;\n    return bestMatch;\n};\n\nBarcodeReader.prototype.decodePattern = function(pattern) {\n    var self = this,\n        result;\n\n    self._row = pattern;\n    result = self._decode();\n    if (result === null) {\n        self._row.reverse();\n        result = self._decode();\n        if (result) {\n            result.direction = BarcodeReader.DIRECTION.REVERSE;\n            result.start = self._row.length - result.start;\n            result.end = self._row.length - result.end;\n        }\n    } else {\n        result.direction = BarcodeReader.DIRECTION.FORWARD;\n    }\n    if (result) {\n        result.format = self.FORMAT;\n    }\n    return result;\n};\n\nBarcodeReader.prototype._matchRange = function(start, end, value) {\n    var i;\n\n    start = start < 0 ? 0 : start;\n    for (i = start; i < end; i++) {\n        if (this._row[i] !== value) {\n            return false;\n        }\n    }\n    return true;\n};\n\nBarcodeReader.prototype._fillCounters = function(offset, end, isWhite) {\n    var self = this,\n        counterPos = 0,\n        i,\n        counters = [];\n\n    isWhite = (typeof isWhite !== 'undefined') ? isWhite : true;\n    offset = (typeof offset !== 'undefined') ? offset : self._nextUnset(self._row);\n    end = end || self._row.length;\n\n    counters[counterPos] = 0;\n    for (i = offset; i < end; i++) {\n        if (self._row[i] ^ isWhite) {\n            counters[counterPos]++;\n        } else {\n            counterPos++;\n            counters[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return counters;\n};\n\nObject.defineProperty(BarcodeReader.prototype, \"FORMAT\", {\n    value: 'unknown',\n    writeable: false\n});\n\nBarcodeReader.DIRECTION = {\n    FORWARD: 1,\n    REVERSE: -1\n};\n\nBarcodeReader.Exception = {\n    StartNotFoundException: \"Start-Info was not found!\",\n    CodeNotFoundException: \"Code could not be found!\",\n    PatternNotFoundException: \"Pattern could not be found!\"\n};\n\nBarcodeReader.CONFIG_KEYS = {};\n\nexport default BarcodeReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/barcode_reader.js","module.exports = clone\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nfunction clone(a) {\n    var out = new Float32Array(2)\n    out[0] = a[0]\n    out[1] = a[1]\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/clone.js\n// module id = 6\n// module chunks = 0","var Symbol = require('./_Symbol'),\n    getRawTag = require('./_getRawTag'),\n    objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n    undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n  if (value == null) {\n    return value === undefined ? undefinedTag : nullTag;\n  }\n  return (symToStringTag && symToStringTag in Object(value))\n    ? getRawTag(value)\n    : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseGetTag.js\n// module id = 7\n// module chunks = 0","export default {\n    init: function(arr, val) {\n        var l = arr.length;\n        while (l--) {\n            arr[l] = val;\n        }\n    },\n\n    /**\n     * Shuffles the content of an array\n     * @return {Array} the array itself shuffled\n     */\n    shuffle: function(arr) {\n        var i = arr.length - 1, j, x;\n        for (i; i >= 0; i--) {\n            j = Math.floor(Math.random() * i);\n            x = arr[i];\n            arr[i] = arr[j];\n            arr[j] = x;\n        }\n        return arr;\n    },\n\n    toPointList: function(arr) {\n        var i, j, row = [], rows = [];\n        for ( i = 0; i < arr.length; i++) {\n            row = [];\n            for ( j = 0; j < arr[i].length; j++) {\n                row[j] = arr[i][j];\n            }\n            rows[i] = \"[\" + row.join(\",\") + \"]\";\n        }\n        return \"[\" + rows.join(\",\\r\\n\") + \"]\";\n    },\n\n    /**\n     * returns the elements which's score is bigger than the threshold\n     * @return {Array} the reduced array\n     */\n    threshold: function(arr, threshold, scoreFunc) {\n        var i, queue = [];\n        for ( i = 0; i < arr.length; i++) {\n            if (scoreFunc.apply(arr, [arr[i]]) >= threshold) {\n                queue.push(arr[i]);\n            }\n        }\n        return queue;\n    },\n\n    maxIndex: function(arr) {\n        var i, max = 0;\n        for ( i = 0; i < arr.length; i++) {\n            if (arr[i] > arr[max]) {\n                max = i;\n            }\n        }\n        return max;\n    },\n\n    max: function(arr) {\n        var i, max = 0;\n        for ( i = 0; i < arr.length; i++) {\n            if (arr[i] > max) {\n                max = arr[i];\n            }\n        }\n        return max;\n    },\n\n    sum: function(arr) {\n        var length = arr.length,\n            sum = 0;\n\n        while (length--) {\n            sum += arr[length];\n        }\n        return sum;\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/array_helper.js","export default {\n    drawRect: function(pos, size, ctx, style){\n        ctx.strokeStyle = style.color;\n        ctx.fillStyle = style.color;\n        ctx.lineWidth = 1;\n        ctx.beginPath();\n        ctx.strokeRect(pos.x, pos.y, size.x, size.y);\n    },\n    drawPath: function(path, def, ctx, style) {\n        ctx.strokeStyle = style.color;\n        ctx.fillStyle = style.color;\n        ctx.lineWidth = style.lineWidth;\n        ctx.beginPath();\n        ctx.moveTo(path[0][def.x], path[0][def.y]);\n        for (var j = 1; j < path.length; j++) {\n            ctx.lineTo(path[j][def.x], path[j][def.y]);\n        }\n        ctx.closePath();\n        ctx.stroke();\n    },\n    drawImage: function(imageData, size, ctx) {\n        var canvasData = ctx.getImageData(0, 0, size.x, size.y),\n            data = canvasData.data,\n            imageDataPos = imageData.length,\n            canvasDataPos = data.length,\n            value;\n\n        if (canvasDataPos / imageDataPos !== 4) {\n            return false;\n        }\n        while (imageDataPos--){\n            value = imageData[imageDataPos];\n            data[--canvasDataPos] = 255;\n            data[--canvasDataPos] = value;\n            data[--canvasDataPos] = value;\n            data[--canvasDataPos] = value;\n        }\n        ctx.putImageData(canvasData, 0, 0);\n        return true;\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/image_debug.js","var listCacheClear = require('./_listCacheClear'),\n    listCacheDelete = require('./_listCacheDelete'),\n    listCacheGet = require('./_listCacheGet'),\n    listCacheHas = require('./_listCacheHas'),\n    listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_ListCache.js\n// module id = 10\n// module chunks = 0","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Symbol.js\n// module id = 11\n// module chunks = 0","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n  var length = array.length;\n  while (length--) {\n    if (eq(array[length][0], key)) {\n      return length;\n    }\n  }\n  return -1;\n}\n\nmodule.exports = assocIndexOf;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assocIndexOf.js\n// module id = 12\n// module chunks = 0","var isArray = require('./isArray'),\n    isKey = require('./_isKey'),\n    stringToPath = require('./_stringToPath'),\n    toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n  if (isArray(value)) {\n    return value;\n  }\n  return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_castPath.js\n// module id = 13\n// module chunks = 0","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n  var data = map.__data__;\n  return isKeyable(key)\n    ? data[typeof key == 'string' ? 'string' : 'hash']\n    : data.map;\n}\n\nmodule.exports = getMapData;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getMapData.js\n// module id = 14\n// module chunks = 0","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return !!length &&\n    (typeof value == 'number' || reIsUint.test(value)) &&\n    (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isIndex.js\n// module id = 15\n// module chunks = 0","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nativeCreate.js\n// module id = 16\n// module chunks = 0","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/eq.js\n// module id = 17\n// module chunks = 0","var baseIsArguments = require('./_baseIsArguments'),\n    isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n *  else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n  return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n    !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArguments.js\n// module id = 18\n// module chunks = 0","import Cluster2 from './cluster';\nimport ArrayHelper from './array_helper';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n};\nconst vec3 = {\n    clone: require('gl-vec3/clone'),\n};\n\n/**\n * @param x x-coordinate\n * @param y y-coordinate\n * @return ImageReference {x,y} Coordinate\n */\nexport function imageRef(x, y) {\n    var that = {\n        x: x,\n        y: y,\n        toVec2: function() {\n            return vec2.clone([this.x, this.y]);\n        },\n        toVec3: function() {\n            return vec3.clone([this.x, this.y, 1]);\n        },\n        round: function() {\n            this.x = this.x > 0.0 ? Math.floor(this.x + 0.5) : Math.floor(this.x - 0.5);\n            this.y = this.y > 0.0 ? Math.floor(this.y + 0.5) : Math.floor(this.y - 0.5);\n            return this;\n        }\n    };\n    return that;\n};\n\n/**\n * Computes an integral image of a given grayscale image.\n * @param imageDataContainer {ImageDataContainer} the image to be integrated\n */\nexport function computeIntegralImage2(imageWrapper, integralWrapper) {\n    var imageData = imageWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0, posA = 0, posB = 0, posC = 0, posD = 0, x, y;\n\n    // sum up first column\n    posB = width;\n    sum = 0;\n    for ( y = 1; y < height; y++) {\n        sum += imageData[posA];\n        integralImageData[posB] += sum;\n        posA += width;\n        posB += width;\n    }\n\n    posA = 0;\n    posB = 1;\n    sum = 0;\n    for ( x = 1; x < width; x++) {\n        sum += imageData[posA];\n        integralImageData[posB] += sum;\n        posA++;\n        posB++;\n    }\n\n    for ( y = 1; y < height; y++) {\n        posA = y * width + 1;\n        posB = (y - 1) * width + 1;\n        posC = y * width;\n        posD = (y - 1) * width;\n        for ( x = 1; x < width; x++) {\n            integralImageData[posA] +=\n                imageData[posA] + integralImageData[posB] + integralImageData[posC] - integralImageData[posD];\n            posA++;\n            posB++;\n            posC++;\n            posD++;\n        }\n    }\n};\n\nexport function computeIntegralImage(imageWrapper, integralWrapper) {\n    var imageData = imageWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0;\n\n    // sum up first row\n    for (var i = 0; i < width; i++) {\n        sum += imageData[i];\n        integralImageData[i] = sum;\n    }\n\n    for (var v = 1; v < height; v++) {\n        sum = 0;\n        for (var u = 0; u < width; u++) {\n            sum += imageData[v * width + u];\n            integralImageData[((v) * width) + u] = sum + integralImageData[(v - 1) * width + u];\n        }\n    }\n};\n\nexport function thresholdImage(imageWrapper, threshold, targetWrapper) {\n    if (!targetWrapper) {\n        targetWrapper = imageWrapper;\n    }\n    var imageData = imageWrapper.data, length = imageData.length, targetData = targetWrapper.data;\n\n    while (length--) {\n        targetData[length] = imageData[length] < threshold ? 1 : 0;\n    }\n};\n\nexport function computeHistogram(imageWrapper, bitsPerPixel) {\n    if (!bitsPerPixel) {\n        bitsPerPixel = 8;\n    }\n    var imageData = imageWrapper.data,\n        length = imageData.length,\n        bitShift = 8 - bitsPerPixel,\n        bucketCnt = 1 << bitsPerPixel,\n        hist = new Int32Array(bucketCnt);\n\n    while (length--) {\n        hist[imageData[length] >> bitShift]++;\n    }\n    return hist;\n};\n\nexport function sharpenLine(line) {\n    var i,\n        length = line.length,\n        left = line[0],\n        center = line[1],\n        right;\n\n    for (i = 1; i < length - 1; i++) {\n        right = line[i + 1];\n        //  -1 4 -1 kernel\n        line[i - 1] = (((center * 2) - left - right)) & 255;\n        left = center;\n        center = right;\n    }\n    return line;\n};\n\nexport function determineOtsuThreshold(imageWrapper, bitsPerPixel) {\n    if (!bitsPerPixel) {\n        bitsPerPixel = 8;\n    }\n    var hist,\n        threshold,\n        bitShift = 8 - bitsPerPixel;\n\n    function px(init, end) {\n        var sum = 0, i;\n        for ( i = init; i <= end; i++) {\n            sum += hist[i];\n        }\n        return sum;\n    }\n\n    function mx(init, end) {\n        var i, sum = 0;\n\n        for ( i = init; i <= end; i++) {\n            sum += i * hist[i];\n        }\n\n        return sum;\n    }\n\n    function determineThreshold() {\n        var vet = [0], p1, p2, p12, k, m1, m2, m12,\n            max = (1 << bitsPerPixel) - 1;\n\n        hist = computeHistogram(imageWrapper, bitsPerPixel);\n        for ( k = 1; k < max; k++) {\n            p1 = px(0, k);\n            p2 = px(k + 1, max);\n            p12 = p1 * p2;\n            if (p12 === 0) {\n                p12 = 1;\n            }\n            m1 = mx(0, k) * p2;\n            m2 = mx(k + 1, max) * p1;\n            m12 = m1 - m2;\n            vet[k] = m12 * m12 / p12;\n        }\n        return ArrayHelper.maxIndex(vet);\n    }\n\n    threshold = determineThreshold();\n    return threshold << bitShift;\n};\n\nexport function otsuThreshold(imageWrapper, targetWrapper) {\n    var threshold = determineOtsuThreshold(imageWrapper);\n\n    thresholdImage(imageWrapper, threshold, targetWrapper);\n    return threshold;\n};\n\n// local thresholding\nexport function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) {\n    computeIntegralImage(imageWrapper, integralWrapper);\n\n    if (!targetWrapper) {\n        targetWrapper = imageWrapper;\n    }\n    var imageData = imageWrapper.data;\n    var targetData = targetWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0, v, u, kernel = 3, A, B, C, D, avg, size = (kernel * 2 + 1) * (kernel * 2 + 1);\n\n    // clear out top & bottom-border\n    for ( v = 0; v <= kernel; v++) {\n        for ( u = 0; u < width; u++) {\n            targetData[((v) * width) + u] = 0;\n            targetData[(((height - 1) - v) * width) + u] = 0;\n        }\n    }\n\n    // clear out left & right border\n    for ( v = kernel; v < height - kernel; v++) {\n        for ( u = 0; u <= kernel; u++) {\n            targetData[((v) * width) + u] = 0;\n            targetData[((v) * width) + (width - 1 - u)] = 0;\n        }\n    }\n\n    for ( v = kernel + 1; v < height - kernel - 1; v++) {\n        for ( u = kernel + 1; u < width - kernel; u++) {\n            A = integralImageData[(v - kernel - 1) * width + (u - kernel - 1)];\n            B = integralImageData[(v - kernel - 1) * width + (u + kernel)];\n            C = integralImageData[(v + kernel) * width + (u - kernel - 1)];\n            D = integralImageData[(v + kernel) * width + (u + kernel)];\n            sum = D - C - B + A;\n            avg = sum / (size);\n            targetData[v * width + u] = imageData[v * width + u] > (avg + 5) ? 0 : 1;\n        }\n    }\n};\n\nexport function cluster(points, threshold, property) {\n    var i, k, cluster, point, clusters = [];\n\n    if (!property) {\n        property = \"rad\";\n    }\n\n    function addToCluster(newPoint) {\n        var found = false;\n        for ( k = 0; k < clusters.length; k++) {\n            cluster = clusters[k];\n            if (cluster.fits(newPoint)) {\n                cluster.add(newPoint);\n                found = true;\n            }\n        }\n        return found;\n    }\n\n    // iterate over each cloud\n    for ( i = 0; i < points.length; i++) {\n        point = Cluster2.createPoint(points[i], i, property);\n        if (!addToCluster(point)) {\n            clusters.push(Cluster2.create(point, threshold));\n        }\n    }\n    return clusters;\n};\n\nexport const Tracer = {\n    trace: function(points, vec) {\n        var iteration, maxIterations = 10, top = [], result = [], centerPos = 0, currentPos = 0;\n\n        function trace(idx, forward) {\n            var from, to, toIdx, predictedPos, thresholdX = 1, thresholdY = Math.abs(vec[1] / 10), found = false;\n\n            function match(pos, predicted) {\n                if (pos.x > (predicted.x - thresholdX)\n                        && pos.x < (predicted.x + thresholdX)\n                        && pos.y > (predicted.y - thresholdY)\n                        && pos.y < (predicted.y + thresholdY)) {\n                    return true;\n                } else {\n                    return false;\n                }\n            }\n\n            // check if the next index is within the vec specifications\n            // if not, check as long as the threshold is met\n\n            from = points[idx];\n            if (forward) {\n                predictedPos = {\n                    x: from.x + vec[0],\n                    y: from.y + vec[1]\n                };\n            } else {\n                predictedPos = {\n                    x: from.x - vec[0],\n                    y: from.y - vec[1]\n                };\n            }\n\n            toIdx = forward ? idx + 1 : idx - 1;\n            to = points[toIdx];\n            while (to && ( found = match(to, predictedPos)) !== true && (Math.abs(to.y - from.y) < vec[1])) {\n                toIdx = forward ? toIdx + 1 : toIdx - 1;\n                to = points[toIdx];\n            }\n\n            return found ? toIdx : null;\n        }\n\n        for ( iteration = 0; iteration < maxIterations; iteration++) {\n            // randomly select point to start with\n            centerPos = Math.floor(Math.random() * points.length);\n\n            // trace forward\n            top = [];\n            currentPos = centerPos;\n            top.push(points[currentPos]);\n            while (( currentPos = trace(currentPos, true)) !== null) {\n                top.push(points[currentPos]);\n            }\n            if (centerPos > 0) {\n                currentPos = centerPos;\n                while (( currentPos = trace(currentPos, false)) !== null) {\n                    top.push(points[currentPos]);\n                }\n            }\n\n            if (top.length > result.length) {\n                result = top;\n            }\n        }\n        return result;\n    }\n};\n\nexport const DILATE = 1;\nexport const ERODE = 2;\n\nexport function dilate(inImageWrapper, outImageWrapper) {\n    var v,\n        u,\n        inImageData = inImageWrapper.data,\n        outImageData = outImageWrapper.data,\n        height = inImageWrapper.size.y,\n        width = inImageWrapper.size.x,\n        sum,\n        yStart1,\n        yStart2,\n        xStart1,\n        xStart2;\n\n    for ( v = 1; v < height - 1; v++) {\n        for ( u = 1; u < width - 1; u++) {\n            yStart1 = v - 1;\n            yStart2 = v + 1;\n            xStart1 = u - 1;\n            xStart2 = u + 1;\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] +\n            inImageData[v * width + u] +\n            inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\n            outImageData[v * width + u] = sum > 0 ? 1 : 0;\n        }\n    }\n};\n\nexport function erode(inImageWrapper, outImageWrapper) {\n    var v,\n        u,\n        inImageData = inImageWrapper.data,\n        outImageData = outImageWrapper.data,\n        height = inImageWrapper.size.y,\n        width = inImageWrapper.size.x,\n        sum,\n        yStart1,\n        yStart2,\n        xStart1,\n        xStart2;\n\n    for ( v = 1; v < height - 1; v++) {\n        for ( u = 1; u < width - 1; u++) {\n            yStart1 = v - 1;\n            yStart2 = v + 1;\n            xStart1 = u - 1;\n            xStart2 = u + 1;\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] +\n            inImageData[v * width + u] +\n            inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\n            outImageData[v * width + u] = sum === 5 ? 1 : 0;\n        }\n    }\n};\n\nexport function subtract(aImageWrapper, bImageWrapper, resultImageWrapper) {\n    if (!resultImageWrapper) {\n        resultImageWrapper = aImageWrapper;\n    }\n    var length = aImageWrapper.data.length,\n        aImageData = aImageWrapper.data,\n        bImageData = bImageWrapper.data,\n        cImageData = resultImageWrapper.data;\n\n    while (length--) {\n        cImageData[length] = aImageData[length] - bImageData[length];\n    }\n};\n\nexport function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) {\n    if (!resultImageWrapper) {\n        resultImageWrapper = aImageWrapper;\n    }\n    var length = aImageWrapper.data.length,\n        aImageData = aImageWrapper.data,\n        bImageData = bImageWrapper.data,\n        cImageData = resultImageWrapper.data;\n\n    while (length--) {\n        cImageData[length] = aImageData[length] || bImageData[length];\n    }\n};\n\nexport function countNonZero(imageWrapper) {\n    var length = imageWrapper.data.length, data = imageWrapper.data, sum = 0;\n\n    while (length--) {\n        sum += data[length];\n    }\n    return sum;\n};\n\nexport function topGeneric(list, top, scoreFunc) {\n    var i, minIdx = 0, min = 0, queue = [], score, hit, pos;\n\n    for ( i = 0; i < top; i++) {\n        queue[i] = {\n            score: 0,\n            item: null\n        };\n    }\n\n    for ( i = 0; i < list.length; i++) {\n        score = scoreFunc.apply(this, [list[i]]);\n        if (score > min) {\n            hit = queue[minIdx];\n            hit.score = score;\n            hit.item = list[i];\n            min = Number.MAX_VALUE;\n            for ( pos = 0; pos < top; pos++) {\n                if (queue[pos].score < min) {\n                    min = queue[pos].score;\n                    minIdx = pos;\n                }\n            }\n        }\n    }\n\n    return queue;\n};\n\nexport function grayArrayFromImage(htmlImage, offsetX, ctx, array) {\n    ctx.drawImage(htmlImage, offsetX, 0, htmlImage.width, htmlImage.height);\n    var ctxData = ctx.getImageData(offsetX, 0, htmlImage.width, htmlImage.height).data;\n    computeGray(ctxData, array);\n};\n\nexport function grayArrayFromContext(ctx, size, offset, array) {\n    var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data;\n    computeGray(ctxData, array);\n};\n\nexport function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {\n    var topRowIdx = 0;\n    var bottomRowIdx = size.x;\n    var endIdx = Math.floor(canvasData.length / 4);\n    var outWidth = size.x / 2;\n    var outImgIdx = 0;\n    var inWidth = size.x;\n    var i;\n\n    while (bottomRowIdx < endIdx) {\n        for ( i = 0; i < outWidth; i++) {\n            outArray[outImgIdx] = Math.floor((\n                (0.299 * canvasData[topRowIdx * 4 + 0] +\n                 0.587 * canvasData[topRowIdx * 4 + 1] +\n                 0.114 * canvasData[topRowIdx * 4 + 2]) +\n                (0.299 * canvasData[(topRowIdx + 1) * 4 + 0] +\n                 0.587 * canvasData[(topRowIdx + 1) * 4 + 1] +\n                 0.114 * canvasData[(topRowIdx + 1) * 4 + 2]) +\n                (0.299 * canvasData[(bottomRowIdx) * 4 + 0] +\n                 0.587 * canvasData[(bottomRowIdx) * 4 + 1] +\n                 0.114 * canvasData[(bottomRowIdx) * 4 + 2]) +\n                (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] +\n                 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] +\n                 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4);\n            outImgIdx++;\n            topRowIdx = topRowIdx + 2;\n            bottomRowIdx = bottomRowIdx + 2;\n        }\n        topRowIdx = topRowIdx + inWidth;\n        bottomRowIdx = bottomRowIdx + inWidth;\n    }\n};\n\nexport function computeGray(imageData, outArray, config) {\n    var l = (imageData.length / 4) | 0,\n        i,\n        singleChannel = config && config.singleChannel === true;\n\n    if (singleChannel) {\n        for (i = 0; i < l; i++) {\n            outArray[i] = imageData[i * 4 + 0];\n        }\n    } else {\n        for (i = 0; i < l; i++) {\n            outArray[i] = Math.floor(\n                0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2]);\n        }\n    }\n};\n\nexport function loadImageArray(src, callback, canvas) {\n    if (!canvas) {\n        canvas = document.createElement('canvas');\n    }\n    var img = new Image();\n    img.callback = callback;\n    img.onload = function() {\n        canvas.width = this.width;\n        canvas.height = this.height;\n        var ctx = canvas.getContext('2d');\n        ctx.drawImage(this, 0, 0);\n        var array = new Uint8Array(this.width * this.height);\n        ctx.drawImage(this, 0, 0);\n        var data = ctx.getImageData(0, 0, this.width, this.height).data;\n        computeGray(data, array);\n        this.callback(array, {\n            x: this.width,\n            y: this.height\n        }, this);\n    };\n    img.src = src;\n};\n\n/**\n * @param inImg {ImageWrapper} input image to be sampled\n * @param outImg {ImageWrapper} to be stored in\n */\nexport function halfSample(inImgWrapper, outImgWrapper) {\n    var inImg = inImgWrapper.data;\n    var inWidth = inImgWrapper.size.x;\n    var outImg = outImgWrapper.data;\n    var topRowIdx = 0;\n    var bottomRowIdx = inWidth;\n    var endIdx = inImg.length;\n    var outWidth = inWidth / 2;\n    var outImgIdx = 0;\n    while (bottomRowIdx < endIdx) {\n        for (var i = 0; i < outWidth; i++) {\n            outImg[outImgIdx] = Math.floor(\n                (inImg[topRowIdx] + inImg[topRowIdx + 1] + inImg[bottomRowIdx] + inImg[bottomRowIdx + 1]) / 4);\n            outImgIdx++;\n            topRowIdx = topRowIdx + 2;\n            bottomRowIdx = bottomRowIdx + 2;\n        }\n        topRowIdx = topRowIdx + inWidth;\n        bottomRowIdx = bottomRowIdx + inWidth;\n    }\n};\n\nexport function hsv2rgb(hsv, rgb) {\n    var h = hsv[0],\n        s = hsv[1],\n        v = hsv[2],\n        c = v * s,\n        x = c * (1 - Math.abs((h / 60) % 2 - 1)),\n        m = v - c,\n        r = 0,\n        g = 0,\n        b = 0;\n\n    rgb = rgb || [0, 0, 0];\n\n    if (h < 60) {\n        r = c;\n        g = x;\n    } else if (h < 120) {\n        r = x;\n        g = c;\n    } else if (h < 180) {\n        g = c;\n        b = x;\n    } else if (h < 240) {\n        g = x;\n        b = c;\n    } else if (h < 300) {\n        r = x;\n        b = c;\n    } else if (h < 360) {\n        r = c;\n        b = x;\n    }\n    rgb[0] = ((r + m) * 255) | 0;\n    rgb[1] = ((g + m) * 255) | 0;\n    rgb[2] = ((b + m) * 255) | 0;\n    return rgb;\n};\n\nexport function _computeDivisors(n) {\n    var largeDivisors = [],\n        divisors = [],\n        i;\n\n    for (i = 1; i < Math.sqrt(n) + 1; i++) {\n        if (n % i === 0) {\n            divisors.push(i);\n            if (i !== n / i) {\n                largeDivisors.unshift(Math.floor(n / i));\n            }\n        }\n    }\n    return divisors.concat(largeDivisors);\n};\n\nfunction _computeIntersection(arr1, arr2) {\n    var i = 0,\n        j = 0,\n        result = [];\n\n    while (i < arr1.length && j < arr2.length) {\n        if (arr1[i] === arr2[j]) {\n            result.push(arr1[i]);\n            i++;\n            j++;\n        } else if (arr1[i] > arr2[j]) {\n            j++;\n        } else {\n            i++;\n        }\n    }\n    return result;\n};\n\nexport function calculatePatchSize(patchSize, imgSize) {\n    var divisorsX = _computeDivisors(imgSize.x),\n        divisorsY = _computeDivisors(imgSize.y),\n        wideSide = Math.max(imgSize.x, imgSize.y),\n        common = _computeIntersection(divisorsX, divisorsY),\n        nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80],\n        nrOfPatchesMap = {\n            \"x-small\": 5,\n            \"small\": 4,\n            \"medium\": 3,\n            \"large\": 2,\n            \"x-large\": 1\n        },\n        nrOfPatchesIdx = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium,\n        nrOfPatches = nrOfPatchesList[nrOfPatchesIdx],\n        desiredPatchSize = Math.floor(wideSide / nrOfPatches),\n        optimalPatchSize;\n\n    function findPatchSizeForDivisors(divisors) {\n        var i = 0,\n            found = divisors[Math.floor(divisors.length / 2)];\n\n        while (i < (divisors.length - 1) && divisors[i] < desiredPatchSize) {\n            i++;\n        }\n        if (i > 0) {\n            if (Math.abs(divisors[i] - desiredPatchSize) > Math.abs(divisors[i - 1] - desiredPatchSize)) {\n                found = divisors[i - 1];\n            } else {\n                found = divisors[i];\n            }\n        }\n        if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIdx + 1] / nrOfPatchesList[nrOfPatchesIdx] &&\n            desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIdx - 1] / nrOfPatchesList[nrOfPatchesIdx] ) {\n            return {x: found, y: found};\n        }\n        return null;\n    }\n\n    optimalPatchSize = findPatchSizeForDivisors(common);\n    if (!optimalPatchSize) {\n        optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide));\n        if (!optimalPatchSize) {\n            optimalPatchSize = findPatchSizeForDivisors((_computeDivisors(desiredPatchSize * nrOfPatches)));\n        }\n    }\n    return optimalPatchSize;\n};\n\nexport function _parseCSSDimensionValues(value) {\n    var dimension = {\n        value: parseFloat(value),\n        unit: value.indexOf(\"%\") === value.length - 1 ? \"%\" : \"%\"\n    };\n\n    return dimension;\n};\n\nexport const _dimensionsConverters = {\n    top: function(dimension, context) {\n        if (dimension.unit === \"%\") {\n            return Math.floor(context.height * (dimension.value / 100));\n        }\n    },\n    right: function(dimension, context) {\n        if (dimension.unit === \"%\") {\n            return Math.floor(context.width - (context.width * (dimension.value / 100)));\n        }\n    },\n    bottom: function(dimension, context) {\n        if (dimension.unit === \"%\") {\n            return Math.floor(context.height - (context.height * (dimension.value / 100)));\n        }\n    },\n    left: function(dimension, context) {\n        if (dimension.unit === \"%\") {\n            return Math.floor(context.width * (dimension.value / 100));\n        }\n    }\n};\n\nexport function computeImageArea(inputWidth, inputHeight, area) {\n    var context = {width: inputWidth, height: inputHeight};\n\n    var parsedArea = Object.keys(area).reduce(function(result, key) {\n        var value = area[key],\n            parsed = _parseCSSDimensionValues(value),\n            calculated = _dimensionsConverters[key](parsed, context);\n\n        result[key] = calculated;\n        return result;\n    }, {});\n\n    return {\n        sx: parsedArea.left,\n        sy: parsedArea.top,\n        sw: parsedArea.right - parsedArea.left,\n        sh: parsedArea.bottom - parsedArea.top\n    };\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/cv_utils.js","import SubImage from './subImage';\nimport {hsv2rgb} from '../common/cv_utils';\nimport ArrayHelper from '../common/array_helper';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n};\n\n/**\n * Represents a basic image combining the data and size.\n * In addition, some methods for manipulation are contained.\n * @param size {x,y} The size of the image in pixel\n * @param data {Array} If given, a flat array containing the pixel data\n * @param ArrayType {Type} If given, the desired DataType of the Array (may be typed/non-typed)\n * @param initialize {Boolean} Indicating if the array should be initialized on creation.\n * @returns {ImageWrapper}\n */\nfunction ImageWrapper(size, data, ArrayType, initialize) {\n    if (!data) {\n        if (ArrayType) {\n            this.data = new ArrayType(size.x * size.y);\n            if (ArrayType === Array && initialize) {\n                ArrayHelper.init(this.data, 0);\n            }\n        } else {\n            this.data = new Uint8Array(size.x * size.y);\n            if (Uint8Array === Array && initialize) {\n                ArrayHelper.init(this.data, 0);\n            }\n        }\n    } else {\n        this.data = data;\n    }\n    this.size = size;\n}\n\n/**\n * tests if a position is within the image with a given offset\n * @param imgRef {x, y} The location to test\n * @param border Number the padding value in pixel\n * @returns {Boolean} true if location inside the image's border, false otherwise\n * @see cvd/image.h\n */\nImageWrapper.prototype.inImageWithBorder = function(imgRef, border) {\n    return (imgRef.x >= border)\n        && (imgRef.y >= border)\n        && (imgRef.x < (this.size.x - border))\n        && (imgRef.y < (this.size.y - border));\n};\n\n/**\n * Performs bilinear sampling\n * @param inImg Image to extract sample from\n * @param x the x-coordinate\n * @param y the y-coordinate\n * @returns the sampled value\n * @see cvd/vision.h\n */\nImageWrapper.sample = function(inImg, x, y) {\n    var lx = Math.floor(x);\n    var ly = Math.floor(y);\n    var w = inImg.size.x;\n    var base = ly * inImg.size.x + lx;\n    var a = inImg.data[base + 0];\n    var b = inImg.data[base + 1];\n    var c = inImg.data[base + w];\n    var d = inImg.data[base + w + 1];\n    var e = a - b;\n    x -= lx;\n    y -= ly;\n\n    var result = Math.floor(x * (y * (e - c + d) - e) + y * (c - a) + a);\n    return result;\n};\n\n/**\n * Initializes a given array. Sets each element to zero.\n * @param array {Array} The array to initialize\n */\nImageWrapper.clearArray = function(array) {\n    var l = array.length;\n    while (l--) {\n        array[l] = 0;\n    }\n};\n\n/**\n * Creates a {SubImage} from the current image ({this}).\n * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner)\n * @param size {ImageRef} The size of the resulting image\n * @returns {SubImage} A shared part of the original image\n */\nImageWrapper.prototype.subImage = function(from, size) {\n    return new SubImage(from, size, this);\n};\n\n/**\n * Creates an {ImageWrapper) and copies the needed underlying image-data area\n * @param imageWrapper {ImageWrapper} The target {ImageWrapper} where the data should be copied\n * @param from {ImageRef} The location where to copy from (top-left location)\n */\nImageWrapper.prototype.subImageAsCopy = function(imageWrapper, from) {\n    var sizeY = imageWrapper.size.y, sizeX = imageWrapper.size.x;\n    var x, y;\n    for ( x = 0; x < sizeX; x++) {\n        for ( y = 0; y < sizeY; y++) {\n            imageWrapper.data[y * sizeX + x] = this.data[(from.y + y) * this.size.x + from.x + x];\n        }\n    }\n};\n\nImageWrapper.prototype.copyTo = function(imageWrapper) {\n    var length = this.data.length, srcData = this.data, dstData = imageWrapper.data;\n\n    while (length--) {\n        dstData[length] = srcData[length];\n    }\n};\n\n/**\n * Retrieves a given pixel position from the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @returns {Number} The grayscale value at the pixel-position\n */\nImageWrapper.prototype.get = function(x, y) {\n    return this.data[y * this.size.x + x];\n};\n\n/**\n * Retrieves a given pixel position from the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @returns {Number} The grayscale value at the pixel-position\n */\nImageWrapper.prototype.getSafe = function(x, y) {\n    var i;\n\n    if (!this.indexMapping) {\n        this.indexMapping = {\n            x: [],\n            y: []\n        };\n        for (i = 0; i < this.size.x; i++) {\n            this.indexMapping.x[i] = i;\n            this.indexMapping.x[i + this.size.x] = i;\n        }\n        for (i = 0; i < this.size.y; i++) {\n            this.indexMapping.y[i] = i;\n            this.indexMapping.y[i + this.size.y] = i;\n        }\n    }\n    return this.data[(this.indexMapping.y[y + this.size.y]) * this.size.x + this.indexMapping.x[x + this.size.x]];\n};\n\n/**\n * Sets a given pixel position in the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @param value {Number} The grayscale value to set\n * @returns {ImageWrapper} The Image itself (for possible chaining)\n */\nImageWrapper.prototype.set = function(x, y, value) {\n    this.data[y * this.size.x + x] = value;\n    return this;\n};\n\n/**\n * Sets the border of the image (1 pixel) to zero\n */\nImageWrapper.prototype.zeroBorder = function() {\n    var i, width = this.size.x, height = this.size.y, data = this.data;\n    for ( i = 0; i < width; i++) {\n        data[i] = data[(height - 1) * width + i] = 0;\n    }\n    for ( i = 1; i < height - 1; i++) {\n        data[i * width] = data[i * width + (width - 1)] = 0;\n    }\n};\n\n/**\n * Inverts a binary image in place\n */\nImageWrapper.prototype.invert = function() {\n    var data = this.data, length = data.length;\n\n    while (length--) {\n        data[length] = data[length] ? 0 : 1;\n    }\n};\n\nImageWrapper.prototype.convolve = function(kernel) {\n    var x, y, kx, ky, kSize = (kernel.length / 2) | 0, accu = 0;\n    for ( y = 0; y < this.size.y; y++) {\n        for ( x = 0; x < this.size.x; x++) {\n            accu = 0;\n            for ( ky = -kSize; ky <= kSize; ky++) {\n                for ( kx = -kSize; kx <= kSize; kx++) {\n                    accu += kernel[ky + kSize][kx + kSize] * this.getSafe(x + kx, y + ky);\n                }\n            }\n            this.data[y * this.size.x + x] = accu;\n        }\n    }\n};\n\nImageWrapper.prototype.moments = function(labelcount) {\n    var data = this.data,\n        x,\n        y,\n        height = this.size.y,\n        width = this.size.x,\n        val,\n        ysq,\n        labelsum = [],\n        i,\n        label,\n        mu11,\n        mu02,\n        mu20,\n        x_,\n        y_,\n        tmp,\n        result = [],\n        PI = Math.PI,\n        PI_4 = PI / 4;\n\n    if (labelcount <= 0) {\n        return result;\n    }\n\n    for ( i = 0; i < labelcount; i++) {\n        labelsum[i] = {\n            m00: 0,\n            m01: 0,\n            m10: 0,\n            m11: 0,\n            m02: 0,\n            m20: 0,\n            theta: 0,\n            rad: 0\n        };\n    }\n\n    for ( y = 0; y < height; y++) {\n        ysq = y * y;\n        for ( x = 0; x < width; x++) {\n            val = data[y * width + x];\n            if (val > 0) {\n                label = labelsum[val - 1];\n                label.m00 += 1;\n                label.m01 += y;\n                label.m10 += x;\n                label.m11 += x * y;\n                label.m02 += ysq;\n                label.m20 += x * x;\n            }\n        }\n    }\n\n    for ( i = 0; i < labelcount; i++) {\n        label = labelsum[i];\n        if (!isNaN(label.m00) && label.m00 !== 0) {\n            x_ = label.m10 / label.m00;\n            y_ = label.m01 / label.m00;\n            mu11 = label.m11 / label.m00 - x_ * y_;\n            mu02 = label.m02 / label.m00 - y_ * y_;\n            mu20 = label.m20 / label.m00 - x_ * x_;\n            tmp = (mu02 - mu20) / (2 * mu11);\n            tmp = 0.5 * Math.atan(tmp) + (mu11 >= 0 ? PI_4 : -PI_4 ) + PI;\n            label.theta = (tmp * 180 / PI + 90) % 180 - 90;\n            if (label.theta < 0) {\n                label.theta += 180;\n            }\n            label.rad = tmp > PI ? tmp - PI : tmp;\n            label.vec = vec2.clone([Math.cos(tmp), Math.sin(tmp)]);\n            result.push(label);\n        }\n    }\n\n    return result;\n};\n\n/**\n * Displays the {ImageWrapper} in a given canvas\n * @param canvas {Canvas} The canvas element to write to\n * @param scale {Number} Scale which is applied to each pixel-value\n */\nImageWrapper.prototype.show = function(canvas, scale) {\n    var ctx,\n        frame,\n        data,\n        current,\n        pixel,\n        x,\n        y;\n\n    if (!scale) {\n        scale = 1.0;\n    }\n    ctx = canvas.getContext('2d');\n    canvas.width = this.size.x;\n    canvas.height = this.size.y;\n    frame = ctx.getImageData(0, 0, canvas.width, canvas.height);\n    data = frame.data;\n    current = 0;\n    for (y = 0; y < this.size.y; y++) {\n        for (x = 0; x < this.size.x; x++) {\n            pixel = y * this.size.x + x;\n            current = this.get(x, y) * scale;\n            data[pixel * 4 + 0] = current;\n            data[pixel * 4 + 1] = current;\n            data[pixel * 4 + 2] = current;\n            data[pixel * 4 + 3] = 255;\n        }\n    }\n    //frame.data = data;\n    ctx.putImageData(frame, 0, 0);\n};\n\n/**\n * Displays the {SubImage} in a given canvas\n * @param canvas {Canvas} The canvas element to write to\n * @param scale {Number} Scale which is applied to each pixel-value\n */\nImageWrapper.prototype.overlay = function(canvas, scale, from) {\n    if (!scale || scale < 0 || scale > 360) {\n        scale = 360;\n    }\n    var hsv = [0, 1, 1];\n    var rgb = [0, 0, 0];\n    var whiteRgb = [255, 255, 255];\n    var blackRgb = [0, 0, 0];\n    var result = [];\n    var ctx = canvas.getContext('2d');\n    var frame = ctx.getImageData(from.x, from.y, this.size.x, this.size.y);\n    var data = frame.data;\n    var length = this.data.length;\n    while (length--) {\n        hsv[0] = this.data[length] * scale;\n        result = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : hsv2rgb(hsv, rgb);\n        data[length * 4 + 0] = result[0];\n        data[length * 4 + 1] = result[1];\n        data[length * 4 + 2] = result[2];\n        data[length * 4 + 3] = 255;\n    }\n    ctx.putImageData(frame, from.x, from.y);\n};\n\nexport default ImageWrapper;\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/image_wrapper.js","var defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n  if (key == '__proto__' && defineProperty) {\n    defineProperty(object, key, {\n      'configurable': true,\n      'enumerable': true,\n      'value': value,\n      'writable': true\n    });\n  } else {\n    object[key] = value;\n  }\n}\n\nmodule.exports = baseAssignValue;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseAssignValue.js\n// module id = 21\n// module chunks = 0","var baseIsNative = require('./_baseIsNative'),\n    getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n  var value = getValue(object, key);\n  return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getNative.js\n// module id = 22\n// module chunks = 0","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n  if (typeof value == 'string' || isSymbol(value)) {\n    return value;\n  }\n  var result = (value + '');\n  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_toKey.js\n// module id = 23\n// module chunks = 0","var isFunction = require('./isFunction'),\n    isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArrayLike.js\n// module id = 24\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  if (!isObject(value)) {\n    return false;\n  }\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 9 which returns 'object' for typed arrays and other constructors.\n  var tag = baseGetTag(value);\n  return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isFunction.js\n// module id = 25\n// module chunks = 0","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n  return typeof value == 'number' &&\n    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isLength.js\n// module id = 26\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n  return typeof value == 'symbol' ||\n    (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isSymbol.js\n// module id = 27\n// module chunks = 0","var baseMerge = require('./_baseMerge'),\n    createAssigner = require('./_createAssigner');\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n *   'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n *   'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\nvar merge = createAssigner(function(object, source, srcIndex) {\n  baseMerge(object, source, srcIndex);\n});\n\nmodule.exports = merge;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/merge.js\n// module id = 28\n// module chunks = 0","module.exports = function(module) {\r\n\tif(!module.webpackPolyfill) {\r\n\t\tmodule.deprecate = function() {};\r\n\t\tmodule.paths = [];\r\n\t\t// module.parent = undefined by default\r\n\t\tif(!module.children) module.children = [];\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.l;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.i;\r\n\t\t\t}\r\n\t\t});\r\n\t\tmodule.webpackPolyfill = 1;\r\n\t}\r\n\treturn module;\r\n};\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/module.js\n// module id = 29\n// module chunks = 0","/**\n * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\n */\nvar Tracer = {\n    searchDirections: [[0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [-1, -1], [-1, 0], [-1, 1]],\n    create: function(imageWrapper, labelWrapper) {\n        var imageData = imageWrapper.data,\n            labelData = labelWrapper.data,\n            searchDirections = this.searchDirections,\n            width = imageWrapper.size.x,\n            pos;\n\n        function trace(current, color, label, edgelabel) {\n            var i,\n                y,\n                x;\n\n            for ( i = 0; i < 7; i++) {\n                y = current.cy + searchDirections[current.dir][0];\n                x = current.cx + searchDirections[current.dir][1];\n                pos = y * width + x;\n                if ((imageData[pos] === color) && ((labelData[pos] === 0) || (labelData[pos] === label))) {\n                    labelData[pos] = label;\n                    current.cy = y;\n                    current.cx = x;\n                    return true;\n                } else {\n                    if (labelData[pos] === 0) {\n                        labelData[pos] = edgelabel;\n                    }\n                    current.dir = (current.dir + 1) % 8;\n                }\n            }\n            return false;\n        }\n\n        function vertex2D(x, y, dir) {\n            return {\n                dir: dir,\n                x: x,\n                y: y,\n                next: null,\n                prev: null\n            };\n        }\n\n        function contourTracing(sy, sx, label, color, edgelabel) {\n            var Fv = null,\n                Cv,\n                P,\n                ldir,\n                current = {\n                    cx: sx,\n                    cy: sy,\n                    dir: 0\n                };\n\n            if (trace(current, color, label, edgelabel)) {\n                Fv = vertex2D(sx, sy, current.dir);\n                Cv = Fv;\n                ldir = current.dir;\n                P = vertex2D(current.cx, current.cy, 0);\n                P.prev = Cv;\n                Cv.next = P;\n                P.next = null;\n                Cv = P;\n                do {\n                    current.dir = (current.dir + 6) % 8;\n                    trace(current, color, label, edgelabel);\n                    if (ldir !== current.dir) {\n                        Cv.dir = current.dir;\n                        P = vertex2D(current.cx, current.cy, 0);\n                        P.prev = Cv;\n                        Cv.next = P;\n                        P.next = null;\n                        Cv = P;\n                    } else {\n                        Cv.dir = ldir;\n                        Cv.x = current.cx;\n                        Cv.y = current.cy;\n                    }\n                    ldir = current.dir;\n                } while (current.cx !== sx || current.cy !== sy);\n                Fv.prev = Cv.prev;\n                Cv.prev.next = Fv;\n            }\n            return Fv;\n        }\n\n        return {\n            trace: function(current, color, label, edgelabel) {\n                return trace(current, color, label, edgelabel);\n            },\n            contourTracing: function(sy, sx, label, color, edgelabel) {\n                return contourTracing(sy, sx, label, color, edgelabel);\n            }\n        };\n    }\n};\n\nexport default (Tracer);\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/tracer.js","import BarcodeReader from './barcode_reader';\nimport ArrayHelper from '../common/array_helper';\n\nfunction Code39Reader() {\n    BarcodeReader.call(this);\n}\n\nvar properties = {\n    ALPHABETH_STRING: {value: \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%\"},\n    ALPHABET: {value: [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78,\n        79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 45, 46, 32, 42, 36, 47, 43, 37]},\n    CHARACTER_ENCODINGS: {value: [0x034, 0x121, 0x061, 0x160, 0x031, 0x130, 0x070, 0x025, 0x124, 0x064, 0x109, 0x049,\n        0x148, 0x019, 0x118, 0x058, 0x00D, 0x10C, 0x04C, 0x01C, 0x103, 0x043, 0x142, 0x013, 0x112, 0x052, 0x007, 0x106,\n        0x046, 0x016, 0x181, 0x0C1, 0x1C0, 0x091, 0x190, 0x0D0, 0x085, 0x184, 0x0C4, 0x094, 0x0A8, 0x0A2, 0x08A, 0x02A\n    ]},\n    ASTERISK: {value: 0x094},\n    FORMAT: {value: \"code_39\", writeable: false}\n};\n\nCode39Reader.prototype = Object.create(BarcodeReader.prototype, properties);\nCode39Reader.prototype.constructor = Code39Reader;\n\nCode39Reader.prototype._toCounters = function(start, counter) {\n    var self = this,\n        numCounters = counter.length,\n        end = self._row.length,\n        isWhite = !self._row[start],\n        i,\n        counterPos = 0;\n\n    ArrayHelper.init(counter, 0);\n\n    for ( i = start; i < end; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            counterPos++;\n            if (counterPos === numCounters) {\n                break;\n            } else {\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n    }\n\n    return counter;\n};\n\nCode39Reader.prototype._decode = function() {\n    var self = this,\n        counters = [0, 0, 0, 0, 0, 0, 0, 0, 0],\n        result = [],\n        start = self._findStart(),\n        decodedChar,\n        lastStart,\n        pattern,\n        nextStart;\n\n    if (!start) {\n        return null;\n    }\n    nextStart = self._nextSet(self._row, start.end);\n\n    do {\n        counters = self._toCounters(nextStart, counters);\n        pattern = self._toPattern(counters);\n        if (pattern < 0) {\n            return null;\n        }\n        decodedChar = self._patternToChar(pattern);\n        if (decodedChar < 0){\n            return null;\n        }\n        result.push(decodedChar);\n        lastStart = nextStart;\n        nextStart += ArrayHelper.sum(counters);\n        nextStart = self._nextSet(self._row, nextStart);\n    } while (decodedChar !== '*');\n    result.pop();\n\n    if (!result.length) {\n        return null;\n    }\n\n    if (!self._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\nCode39Reader.prototype._verifyTrailingWhitespace = function(lastStart, nextStart, counters) {\n    var trailingWhitespaceEnd,\n        patternSize = ArrayHelper.sum(counters);\n\n    trailingWhitespaceEnd = nextStart - lastStart - patternSize;\n    if ((trailingWhitespaceEnd * 3) >= patternSize) {\n        return true;\n    }\n    return false;\n};\n\nCode39Reader.prototype._patternToChar = function(pattern) {\n    var i,\n        self = this;\n\n    for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {\n        if (self.CHARACTER_ENCODINGS[i] === pattern) {\n            return String.fromCharCode(self.ALPHABET[i]);\n        }\n    }\n    return -1;\n};\n\nCode39Reader.prototype._findNextWidth = function(counters, current) {\n    var i,\n        minWidth = Number.MAX_VALUE;\n\n    for (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\nCode39Reader.prototype._toPattern = function(counters) {\n    var numCounters = counters.length,\n        maxNarrowWidth = 0,\n        numWideBars = numCounters,\n        wideBarWidth = 0,\n        self = this,\n        pattern,\n        i;\n\n    while (numWideBars > 3) {\n        maxNarrowWidth = self._findNextWidth(counters, maxNarrowWidth);\n        numWideBars = 0;\n        pattern = 0;\n        for (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 (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\nCode39Reader.prototype._findStart = function() {\n    var self = this,\n        offset = self._nextSet(self._row),\n        patternStart = offset,\n        counter = [0, 0, 0, 0, 0, 0, 0, 0, 0],\n        counterPos = 0,\n        isWhite = false,\n        i,\n        j,\n        whiteSpaceMustStart;\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                // find start pattern\n                if (self._toPattern(counter) === self.ASTERISK) {\n                    whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - ((i - patternStart) / 4)));\n                    if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) {\n                        return {\n                            start: patternStart,\n                            end: i\n                        };\n                    }\n                }\n\n                patternStart += counter[0] + counter[1];\n                for ( j = 0; j < 7; j++) {\n                    counter[j] = counter[j + 2];\n                }\n                counter[7] = 0;\n                counter[8] = 0;\n                counterPos--;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nexport default Code39Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_39_reader.js","module.exports = dot\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nfunction dot(a, b) {\n    return a[0] * b[0] + a[1] * b[1]\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/dot.js\n// module id = 32\n// module chunks = 0","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Map.js\n// module id = 33\n// module chunks = 0","var mapCacheClear = require('./_mapCacheClear'),\n    mapCacheDelete = require('./_mapCacheDelete'),\n    mapCacheGet = require('./_mapCacheGet'),\n    mapCacheHas = require('./_mapCacheHas'),\n    mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_MapCache.js\n// module id = 34\n// module chunks = 0","var baseAssignValue = require('./_baseAssignValue'),\n    eq = require('./eq');\n\n/**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignMergeValue(object, key, value) {\n  if ((value !== undefined && !eq(object[key], value)) ||\n      (value === undefined && !(key in object))) {\n    baseAssignValue(object, key, value);\n  }\n}\n\nmodule.exports = assignMergeValue;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assignMergeValue.js\n// module id = 35\n// module chunks = 0","var baseAssignValue = require('./_baseAssignValue'),\n    eq = require('./eq');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n  var objValue = object[key];\n  if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n      (value === undefined && !(key in object))) {\n    baseAssignValue(object, key, value);\n  }\n}\n\nmodule.exports = assignValue;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assignValue.js\n// module id = 36\n// module chunks = 0","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n  try {\n    var func = getNative(Object, 'defineProperty');\n    func({}, '', {});\n    return func;\n  } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_defineProperty.js\n// module id = 37\n// module chunks = 0","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_freeGlobal.js\n// module id = 38\n// module chunks = 0","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getPrototype.js\n// module id = 39\n// module chunks = 0","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\nmodule.exports = isPrototype;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isPrototype.js\n// module id = 40\n// module chunks = 0","var apply = require('./_apply');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\nfunction overRest(func, start, transform) {\n  start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n  return function() {\n    var args = arguments,\n        index = -1,\n        length = nativeMax(args.length - start, 0),\n        array = Array(length);\n\n    while (++index < length) {\n      array[index] = args[start + index];\n    }\n    index = -1;\n    var otherArgs = Array(start + 1);\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = transform(array);\n    return apply(func, this, otherArgs);\n  };\n}\n\nmodule.exports = overRest;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_overRest.js\n// module id = 41\n// module chunks = 0","var baseSetToString = require('./_baseSetToString'),\n    shortOut = require('./_shortOut');\n\n/**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar setToString = shortOut(baseSetToString);\n\nmodule.exports = setToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_setToString.js\n// module id = 42\n// module chunks = 0","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n  return value;\n}\n\nmodule.exports = identity;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/identity.js\n// module id = 43\n// module chunks = 0","var root = require('./_root'),\n    stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isBuffer.js\n// module id = 44\n// module chunks = 0","var baseIsTypedArray = require('./_baseIsTypedArray'),\n    baseUnary = require('./_baseUnary'),\n    nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isTypedArray.js\n// module id = 45\n// module chunks = 0","var arrayLikeKeys = require('./_arrayLikeKeys'),\n    baseKeysIn = require('./_baseKeysIn'),\n    isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nmodule.exports = keysIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/keysIn.js\n// module id = 46\n// module chunks = 0","var g;\r\n\r\n// This works in non-strict mode\r\ng = (function() {\r\n\treturn this;\r\n})();\r\n\r\ntry {\r\n\t// This works if eval is allowed (see CSP)\r\n\tg = g || Function(\"return this\")() || (1,eval)(\"this\");\r\n} catch(e) {\r\n\t// This works if the window reference is available\r\n\tif(typeof window === \"object\")\r\n\t\tg = window;\r\n}\r\n\r\n// g can still be undefined, but nothing to do about it...\r\n// We return undefined, instead of nothing here, so it's\r\n// easier to handle this case. if(!global) { ...}\r\n\r\nmodule.exports = g;\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/global.js\n// module id = 47\n// module chunks = 0","import TypeDefs from './common/typedefs'; // eslint-disable-line no-unused-vars\nimport ImageWrapper from './common/image_wrapper';\nimport BarcodeLocator from './locator/barcode_locator';\nimport BarcodeDecoder from './decoder/barcode_decoder';\nimport Events from './common/events';\nimport CameraAccess from './input/camera_access';\nimport ImageDebug from './common/image_debug';\nimport ResultCollector from './analytics/result_collector';\nimport Config from './config/config';\nimport InputStream from 'input_stream';\nimport FrameGrabber from 'frame_grabber';\nimport {merge} from 'lodash';\nconst vec2 = {\n    clone: require('gl-vec2/clone')\n};\n\nvar _inputStream,\n    _framegrabber,\n    _stopped,\n    _canvasContainer = {\n        ctx: {\n            image: null,\n            overlay: null\n        },\n        dom: {\n            image: null,\n            overlay: null\n        }\n    },\n    _inputImageWrapper,\n    _boxSize,\n    _decoder,\n    _workerPool = [],\n    _onUIThread = true,\n    _resultCollector,\n    _config = {};\n\nfunction initializeData(imageWrapper) {\n    initBuffers(imageWrapper);\n    _decoder = BarcodeDecoder.create(_config.decoder, _inputImageWrapper);\n}\n\nfunction initInputStream(cb) {\n    var video;\n    if (_config.inputStream.type === \"VideoStream\") {\n        video = document.createElement(\"video\");\n        _inputStream = InputStream.createVideoStream(video);\n    } else if (_config.inputStream.type === \"ImageStream\") {\n        _inputStream = InputStream.createImageStream();\n    } else if (_config.inputStream.type === \"LiveStream\") {\n        var $viewport = getViewPort();\n        if ($viewport) {\n            video = $viewport.querySelector(\"video\");\n            if (!video) {\n                video = document.createElement(\"video\");\n                $viewport.appendChild(video);\n            }\n        }\n        _inputStream = InputStream.createLiveStream(video);\n        CameraAccess.request(video, _config.inputStream.constraints)\n        .then(() => {\n            _inputStream.trigger(\"canrecord\");\n        }).catch((err) => {\n            return cb(err);\n        });\n    }\n\n    _inputStream.setAttribute(\"preload\", \"auto\");\n    _inputStream.setInputStream(_config.inputStream);\n    _inputStream.addEventListener(\"canrecord\", canRecord.bind(undefined, cb));\n}\n\nfunction getViewPort() {\n    var target = _config.inputStream.target;\n    // Check if target is already a DOM element\n    if (target && target.nodeName && target.nodeType === 1) {\n        return target;\n    } else {\n        // Use '#interactive.viewport' as a fallback selector (backwards compatibility)\n        var selector = typeof target === 'string' ? target : '#interactive.viewport';\n        return document.querySelector(selector);\n    }\n}\n\nfunction canRecord(cb) {\n    BarcodeLocator.checkImageConstraints(_inputStream, _config.locator);\n    initCanvas(_config);\n    _framegrabber = FrameGrabber.create(_inputStream, _canvasContainer.dom.image);\n\n    adjustWorkerPool(_config.numOfWorkers, function() {\n        if (_config.numOfWorkers === 0) {\n            initializeData();\n        }\n        ready(cb);\n    });\n}\n\nfunction ready(cb){\n    _inputStream.play();\n    cb();\n}\n\nfunction initCanvas() {\n    if (typeof document !== \"undefined\") {\n        var $viewport = getViewPort();\n        _canvasContainer.dom.image = document.querySelector(\"canvas.imgBuffer\");\n        if (!_canvasContainer.dom.image) {\n            _canvasContainer.dom.image = document.createElement(\"canvas\");\n            _canvasContainer.dom.image.className = \"imgBuffer\";\n            if ($viewport && _config.inputStream.type === \"ImageStream\") {\n                $viewport.appendChild(_canvasContainer.dom.image);\n            }\n        }\n        _canvasContainer.ctx.image = _canvasContainer.dom.image.getContext(\"2d\");\n        _canvasContainer.dom.image.width = _inputStream.getCanvasSize().x;\n        _canvasContainer.dom.image.height = _inputStream.getCanvasSize().y;\n\n        _canvasContainer.dom.overlay = document.querySelector(\"canvas.drawingBuffer\");\n        if (!_canvasContainer.dom.overlay) {\n            _canvasContainer.dom.overlay = document.createElement(\"canvas\");\n            _canvasContainer.dom.overlay.className = \"drawingBuffer\";\n            if ($viewport) {\n                $viewport.appendChild(_canvasContainer.dom.overlay);\n            }\n            var clearFix = document.createElement(\"br\");\n            clearFix.setAttribute(\"clear\", \"all\");\n            if ($viewport) {\n                $viewport.appendChild(clearFix);\n            }\n        }\n        _canvasContainer.ctx.overlay = _canvasContainer.dom.overlay.getContext(\"2d\");\n        _canvasContainer.dom.overlay.width = _inputStream.getCanvasSize().x;\n        _canvasContainer.dom.overlay.height = _inputStream.getCanvasSize().y;\n    }\n}\n\nfunction initBuffers(imageWrapper) {\n    if (imageWrapper) {\n        _inputImageWrapper = imageWrapper;\n    } else {\n        _inputImageWrapper = new ImageWrapper({\n            x: _inputStream.getWidth(),\n            y: _inputStream.getHeight()\n        });\n    }\n\n    if (ENV.development) {\n        console.log(_inputImageWrapper.size);\n    }\n    _boxSize = [\n        vec2.clone([0, 0]),\n        vec2.clone([0, _inputImageWrapper.size.y]),\n        vec2.clone([_inputImageWrapper.size.x, _inputImageWrapper.size.y]),\n        vec2.clone([_inputImageWrapper.size.x, 0])\n    ];\n    BarcodeLocator.init(_inputImageWrapper, _config.locator);\n}\n\nfunction getBoundingBoxes() {\n    if (_config.locate) {\n        return BarcodeLocator.locate();\n    } else {\n        return [[\n            vec2.clone(_boxSize[0]),\n            vec2.clone(_boxSize[1]),\n            vec2.clone(_boxSize[2]),\n            vec2.clone(_boxSize[3])]];\n    }\n}\n\nfunction transformResult(result) {\n    var topRight = _inputStream.getTopRight(),\n        xOffset = topRight.x,\n        yOffset = topRight.y,\n        i;\n\n    if (xOffset === 0 && yOffset === 0) {\n        return;\n    }\n\n    if (result.barcodes) {\n        for (i = 0; i < result.barcodes.length; i++) {\n            transformResult(result.barcodes[i]);\n        }\n    }\n\n    if (result.line && result.line.length === 2) {\n        moveLine(result.line);\n    }\n\n    if (result.box) {\n        moveBox(result.box);\n    }\n\n    if (result.boxes && result.boxes.length > 0) {\n        for (i = 0; i < result.boxes.length; i++) {\n            moveBox(result.boxes[i]);\n        }\n    }\n\n    function moveBox(box) {\n        var corner = box.length;\n\n        while (corner--) {\n            box[corner][0] += xOffset;\n            box[corner][1] += yOffset;\n        }\n    }\n\n    function moveLine(line) {\n        line[0].x += xOffset;\n        line[0].y += yOffset;\n        line[1].x += xOffset;\n        line[1].y += yOffset;\n    }\n}\n\nfunction addResult (result, imageData) {\n    if (!imageData || !_resultCollector) {\n        return;\n    }\n\n    if (result.barcodes) {\n        result.barcodes.filter(barcode => barcode.codeResult)\n            .forEach(barcode => addResult(barcode, imageData));\n    } else if (result.codeResult) {\n        _resultCollector.addResult(imageData, _inputStream.getCanvasSize(), result.codeResult);\n    }\n}\n\nfunction hasCodeResult (result) {\n    return result && (result.barcodes ?\n      result.barcodes.some(barcode => barcode.codeResult) :\n      result.codeResult);\n}\n\nfunction publishResult(result, imageData) {\n    let resultToPublish = result;\n\n    if (result && _onUIThread) {\n        transformResult(result);\n        addResult(result, imageData);\n        resultToPublish = result.barcodes || result;\n    }\n\n    Events.publish(\"processed\", resultToPublish);\n    if (hasCodeResult(result)) {\n        Events.publish(\"detected\", resultToPublish);\n    }\n}\n\nfunction locateAndDecode() {\n    var result,\n        boxes;\n\n    boxes = getBoundingBoxes();\n    if (boxes) {\n        result = _decoder.decodeFromBoundingBoxes(boxes);\n        result = result || {};\n        result.boxes = boxes;\n        publishResult(result, _inputImageWrapper.data);\n    } else {\n        publishResult();\n    }\n}\n\nfunction update() {\n    var availableWorker;\n\n    if (_onUIThread) {\n        if (_workerPool.length > 0) {\n            availableWorker = _workerPool.filter(function(workerThread) {\n                return !workerThread.busy;\n            })[0];\n            if (availableWorker) {\n                _framegrabber.attachData(availableWorker.imageData);\n            } else {\n                return; // all workers are busy\n            }\n        } else {\n            _framegrabber.attachData(_inputImageWrapper.data);\n        }\n        if (_framegrabber.grab()) {\n            if (availableWorker) {\n                availableWorker.busy = true;\n                availableWorker.worker.postMessage({\n                    cmd: 'process',\n                    imageData: availableWorker.imageData\n                }, [availableWorker.imageData.buffer]);\n            } else {\n                locateAndDecode();\n            }\n        }\n    } else {\n        locateAndDecode();\n    }\n}\n\nfunction startContinuousUpdate() {\n    var next = null,\n        delay = 1000 / (_config.frequency || 60);\n\n    _stopped = false;\n    (function frame(timestamp) {\n        next = next || timestamp;\n        if (!_stopped) {\n            if (timestamp >= next) {\n                next += delay;\n                update();\n            }\n            window.requestAnimFrame(frame);\n        }\n    }(performance.now()));\n}\n\nfunction start() {\n    if (_onUIThread && _config.inputStream.type === \"LiveStream\") {\n        startContinuousUpdate();\n    } else {\n        update();\n    }\n}\n\nfunction initWorker(cb) {\n    var blobURL,\n        workerThread = {\n            worker: undefined,\n            imageData: new Uint8Array(_inputStream.getWidth() * _inputStream.getHeight()),\n            busy: true\n        };\n\n    blobURL = generateWorkerBlob();\n    workerThread.worker = new Worker(blobURL);\n\n    workerThread.worker.onmessage = function(e) {\n        if (e.data.event === 'initialized') {\n            URL.revokeObjectURL(blobURL);\n            workerThread.busy = false;\n            workerThread.imageData = new Uint8Array(e.data.imageData);\n            if (ENV.development) {\n                console.log(\"Worker initialized\");\n            }\n            return cb(workerThread);\n        } else if (e.data.event === 'processed') {\n            workerThread.imageData = new Uint8Array(e.data.imageData);\n            workerThread.busy = false;\n            publishResult(e.data.result, workerThread.imageData);\n        } else if (e.data.event === 'error') {\n            if (ENV.development) {\n                console.log(\"Worker error: \" + e.data.message);\n            }\n        }\n    };\n\n    workerThread.worker.postMessage({\n        cmd: 'init',\n        size: {x: _inputStream.getWidth(), y: _inputStream.getHeight()},\n        imageData: workerThread.imageData,\n        config: configForWorker(_config)\n    }, [workerThread.imageData.buffer]);\n}\n\nfunction configForWorker(config) {\n    return {\n        ...config,\n        inputStream: {\n            ...config.inputStream,\n            target: null\n        }\n    };\n}\n\nfunction workerInterface(factory) {\n    /* eslint-disable no-undef*/\n    if (factory) {\n        var Quagga = factory().default;\n        if (!Quagga) {\n            self.postMessage({'event': 'error', message: 'Quagga could not be created'});\n            return;\n        }\n    }\n    var imageWrapper;\n\n    self.onmessage = function(e) {\n        if (e.data.cmd === 'init') {\n            var config = e.data.config;\n            config.numOfWorkers = 0;\n            imageWrapper = new Quagga.ImageWrapper({\n                x: e.data.size.x,\n                y: e.data.size.y\n            }, new Uint8Array(e.data.imageData));\n            Quagga.init(config, ready, imageWrapper);\n            Quagga.onProcessed(onProcessed);\n        } else if (e.data.cmd === 'process') {\n            imageWrapper.data = new Uint8Array(e.data.imageData);\n            Quagga.start();\n        } else if (e.data.cmd === 'setReaders') {\n            Quagga.setReaders(e.data.readers);\n        }\n    };\n\n    function onProcessed(result) {\n        self.postMessage({\n            'event': 'processed',\n            imageData: imageWrapper.data,\n            result: result\n        }, [imageWrapper.data.buffer]);\n    }\n\n    function ready() { // eslint-disable-line\n        self.postMessage({'event': 'initialized', imageData: imageWrapper.data}, [imageWrapper.data.buffer]);\n    }\n\n    /* eslint-enable */\n}\n\nfunction generateWorkerBlob() {\n    var blob,\n        factorySource;\n\n    /* jshint ignore:start */\n    if (typeof __factorySource__ !== 'undefined') {\n        factorySource = __factorySource__; // eslint-disable-line no-undef\n    }\n    /* jshint ignore:end */\n\n    blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'],\n        {type: 'text/javascript'});\n\n    return window.URL.createObjectURL(blob);\n}\n\nfunction setReaders(readers) {\n    if (_decoder) {\n        _decoder.setReaders(readers);\n    } else if (_onUIThread && _workerPool.length > 0) {\n        _workerPool.forEach(function(workerThread) {\n            workerThread.worker.postMessage({cmd: 'setReaders', readers: readers});\n        });\n    }\n}\n\nfunction adjustWorkerPool(capacity, cb) {\n    const increaseBy = capacity - _workerPool.length;\n    if (increaseBy === 0) {\n        return cb && cb();\n    }\n    if (increaseBy < 0) {\n        const workersToTerminate = _workerPool.slice(increaseBy);\n        workersToTerminate.forEach(function(workerThread) {\n            workerThread.worker.terminate();\n            if (ENV.development) {\n                console.log(\"Worker terminated!\");\n            }\n        });\n        _workerPool = _workerPool.slice(0, increaseBy);\n        return cb && cb();\n    } else {\n        for (var i = 0; i < increaseBy; i++) {\n            initWorker(workerInitialized);\n        }\n\n        function workerInitialized(workerThread) {\n            _workerPool.push(workerThread);\n            if (_workerPool.length >= capacity){\n                cb && cb();\n            }\n        }\n    }\n}\n\nexport default {\n    init: function(config, cb, imageWrapper) {\n        _config = merge({}, Config, config);\n        if (imageWrapper) {\n            _onUIThread = false;\n            initializeData(imageWrapper);\n            return cb();\n        } else {\n            initInputStream(cb);\n        }\n    },\n    start: function() {\n        start();\n    },\n    stop: function() {\n        _stopped = true;\n        adjustWorkerPool(0);\n        if (_config.inputStream.type === \"LiveStream\") {\n            CameraAccess.release();\n            _inputStream.clearEventHandlers();\n        }\n    },\n    pause: function() {\n        _stopped = true;\n    },\n    onDetected: function(callback) {\n        Events.subscribe(\"detected\", callback);\n    },\n    offDetected: function(callback) {\n        Events.unsubscribe(\"detected\", callback);\n    },\n    onProcessed: function(callback) {\n        Events.subscribe(\"processed\", callback);\n    },\n    offProcessed: function(callback) {\n        Events.unsubscribe(\"processed\", callback);\n    },\n    setReaders: function(readers) {\n        setReaders(readers);\n    },\n    registerResultCollector: function(resultCollector) {\n        if (resultCollector && typeof resultCollector.addResult === 'function') {\n            _resultCollector = resultCollector;\n        }\n    },\n    canvas: _canvasContainer,\n    decodeSingle: function(config, resultCallback) {\n        config = merge({\n            inputStream: {\n                type: \"ImageStream\",\n                sequence: false,\n                size: 800,\n                src: config.src\n            },\n            numOfWorkers: (ENV.development && config.debug) ? 0 : 1,\n            locator: {\n                halfSample: false\n            }\n        }, config);\n        this.init(config, () => {\n            Events.once(\"processed\", (result) => {\n                this.stop();\n                resultCallback.call(null, result);\n            }, true);\n            start();\n        });\n    },\n    ImageWrapper: ImageWrapper,\n    ImageDebug: ImageDebug,\n    ResultCollector: ResultCollector,\n    CameraAccess: CameraAccess,\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/quagga.js","const CVUtils = require('../src/common/cv_utils'),\n      Ndarray = require(\"ndarray\"),\n      Interp2D = require(\"ndarray-linear-interpolate\").d2;\n\nvar FrameGrabber = {};\n\nFrameGrabber.create = function(inputStream) {\n    var _that = {},\n        _streamConfig = inputStream.getConfig(),\n        _video_size = CVUtils.imageRef(inputStream.getRealWidth(), inputStream.getRealHeight()),\n        _canvasSize = inputStream.getCanvasSize(),\n        _size = CVUtils.imageRef(inputStream.getWidth(), inputStream.getHeight()),\n        _topRight = inputStream.getTopRight(),\n        _data = new Uint8Array(_size.x * _size.y),\n        _grayData = new Uint8Array(_video_size.x * _video_size.y),\n        _canvasData = new Uint8Array(_canvasSize.x * _canvasSize.y),\n        _grayImageArray = Ndarray(_grayData, [_video_size.y, _video_size.x]).transpose(1, 0),\n        _canvasImageArray = Ndarray(_canvasData, [_canvasSize.y, _canvasSize.x]).transpose(1, 0),\n        _targetImageArray = _canvasImageArray.hi(_topRight.x + _size.x, _topRight.y + _size.y).lo(_topRight.x, _topRight.y),\n        _stepSizeX = _video_size.x/_canvasSize.x,\n        _stepSizeY = _video_size.y/_canvasSize.y;\n\n    console.log(\"FrameGrabber\", JSON.stringify({\n        videoSize: _grayImageArray.shape,\n        canvasSize: _canvasImageArray.shape,\n        stepSize: [_stepSizeX, _stepSizeY],\n        size: _targetImageArray.shape,\n        topRight: _topRight\n    }));\n\n    /**\n     * Uses the given array as frame-buffer\n     */\n    _that.attachData = function(data) {\n        _data = data;\n    };\n\n    /**\n     * Returns the used frame-buffer\n     */\n    _that.getData = function() {\n        return _data;\n    };\n\n    /**\n     * Fetches a frame from the input-stream and puts into the frame-buffer.\n     * The image-data is converted to gray-scale and then half-sampled if configured.\n     */\n    _that.grab = function() {\n        var frame = inputStream.getFrame();\n\n        if (frame) {\n            this.scaleAndCrop(frame);\n            return true;\n        } else {\n            return false;\n        }\n    };\n\n    _that.scaleAndCrop = function(frame) {\n        var x,\n            y;\n\n        // 1. compute full-sized gray image\n        CVUtils.computeGray(frame.data, _grayData);\n\n        // 2. interpolate\n        for (y = 0; y < _canvasSize.y; y++) {\n            for (x = 0; x < _canvasSize.x; x++) {\n                _canvasImageArray.set(x, y, (Interp2D(_grayImageArray, x * _stepSizeX, y * _stepSizeY)) | 0);\n            }\n        }\n\n        // targetImageArray must be equal to targetSize\n        if (_targetImageArray.shape[0] !== _size.x ||\n            _targetImageArray.shape[1] !== _size.y) {\n            throw new Error(\"Shapes do not match!\");\n        }\n\n        // 3. crop\n        for (y = 0; y < _size.y; y++) {\n            for (x = 0; x < _size.x; x++) {\n                _data[y * _size.x + x] = _targetImageArray.get(x, y);\n            }\n        }\n    },\n\n    _that.getSize = function() {\n        return _size;\n    };\n\n    return _that;\n};\n\nmodule.exports = FrameGrabber;\n\n\n\n// WEBPACK FOOTER //\n// ./lib/frame_grabber.js","const GetPixels = require(\"get-pixels\");\n\nvar InputStream = {};\n\nInputStream.createImageStream = function() {\n    var that = {};\n    var _config = null;\n\n    var width = 0,\n        height = 0,\n        frameIdx = 0,\n        paused = true,\n        loaded = false,\n        frame = null,\n        baseUrl,\n        ended = false,\n        size,\n        calculatedWidth,\n        calculatedHeight,\n        _eventNames = ['canrecord', 'ended'],\n        _eventHandlers = {},\n        _topRight = {x: 0, y: 0},\n        _canvasSize = {x: 0, y: 0};\n\n    function loadImages() {\n        loaded = false;\n        GetPixels(baseUrl, function(err, pixels) {\n            if (err) {\n                console.log(err);\n                exit(1);\n            }\n            loaded = true;\n            console.log(pixels.shape);\n            frame = pixels;\n            width = pixels.shape[0];\n            height = pixels.shape[1];\n            calculatedWidth = _config.size ? width/height > 1 ? _config.size : Math.floor((width/height) * _config.size) : width;\n            calculatedHeight = _config.size ? width/height > 1 ? Math.floor((height/width) * _config.size) : _config.size : height;\n\n            _canvasSize.x = calculatedWidth;\n            _canvasSize.y = calculatedHeight;\n\n            setTimeout(function() {\n                publishEvent(\"canrecord\", []);\n            }, 0);\n        });\n    }\n\n    function publishEvent(eventName, args) {\n        var j,\n            handlers = _eventHandlers[eventName];\n\n        if (handlers && handlers.length > 0) {\n            for ( j = 0; j < handlers.length; j++) {\n                handlers[j].apply(that, args);\n            }\n        }\n    }\n\n\n    that.trigger = publishEvent;\n\n    that.getWidth = function() {\n        return calculatedWidth;\n    };\n\n    that.getHeight = function() {\n        return calculatedHeight;\n    };\n\n    that.setWidth = function(width) {\n        calculatedWidth = width;\n    };\n\n    that.setHeight = function(height) {\n        calculatedHeight = height;\n    };\n\n    that.getRealWidth = function() {\n        return width;\n    };\n\n    that.getRealHeight = function() {\n        return height;\n    };\n\n    that.setInputStream = function(stream) {\n        _config = stream;\n        baseUrl = _config.src;\n        size = 1;\n        loadImages();\n    };\n\n    that.ended = function() {\n        return ended;\n    };\n\n    that.setAttribute = function() {};\n\n    that.getConfig = function() {\n        return _config;\n    };\n\n    that.pause = function() {\n        paused = true;\n    };\n\n    that.play = function() {\n        paused = false;\n    };\n\n    that.setCurrentTime = function(time) {\n        frameIdx = time;\n    };\n\n    that.addEventListener = function(event, f) {\n        if (_eventNames.indexOf(event) !== -1) {\n            if (!_eventHandlers[event]) {\n                _eventHandlers[event] = [];\n            }\n            _eventHandlers[event].push(f);\n        }\n    };\n\n    that.setTopRight = function(topRight) {\n        _topRight.x = topRight.x;\n        _topRight.y = topRight.y;\n    };\n\n    that.getTopRight = function() {\n        return _topRight;\n    };\n\n    that.setCanvasSize = function(size) {\n        _canvasSize.x = size.x;\n        _canvasSize.y = size.y;\n    };\n\n    that.getCanvasSize = function() {\n        return _canvasSize;\n    };\n\n    that.getFrame = function() {\n        if (!loaded){\n            return null;\n        }\n        return frame;\n    };\n\n    return that;\n};\n\nmodule.exports = InputStream;\n\n\n\n// WEBPACK FOOTER //\n// ./lib/input_stream.js","import ImageDebug from '../common/image_debug';\n\nfunction contains(codeResult, list) {\n    if (list) {\n        return list.some(function (item) {\n            return Object.keys(item).every(function (key) {\n                return item[key] === codeResult[key];\n            });\n        });\n    }\n    return false;\n}\n\nfunction passesFilter(codeResult, filter) {\n    if (typeof filter === 'function') {\n        return filter(codeResult);\n    }\n    return true;\n}\n\nexport default {\n    create: function(config) {\n        var canvas = document.createElement(\"canvas\"),\n            ctx = canvas.getContext(\"2d\"),\n            results = [],\n            capacity = config.capacity || 20,\n            capture = config.capture === true;\n\n        function matchesConstraints(codeResult) {\n            return capacity\n                && codeResult\n                && !contains(codeResult, config.blacklist)\n                && passesFilter(codeResult, config.filter);\n        }\n\n        return {\n            addResult: function(data, imageSize, codeResult) {\n                var result = {};\n\n                if (matchesConstraints(codeResult)) {\n                    capacity--;\n                    result.codeResult = codeResult;\n                    if (capture) {\n                        canvas.width = imageSize.x;\n                        canvas.height = imageSize.y;\n                        ImageDebug.drawImage(data, imageSize, ctx);\n                        result.frame = canvas.toDataURL();\n                    }\n                    results.push(result);\n                }\n            },\n            getResults: function() {\n                return results;\n            }\n        };\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/analytics/result_collector.js","const vec2 = {\n    clone: require('gl-vec2/clone'),\n    dot: require('gl-vec2/dot')\n}\n    /**\n     * Creates a cluster for grouping similar orientations of datapoints\n     */\nexport default {\n    create: function(point, threshold) {\n        var points = [],\n            center = {\n                rad: 0,\n                vec: vec2.clone([0, 0])\n            },\n            pointMap = {};\n\n        function init() {\n            add(point);\n            updateCenter();\n        }\n\n        function add(pointToAdd) {\n            pointMap[pointToAdd.id] = pointToAdd;\n            points.push(pointToAdd);\n        }\n\n        function updateCenter() {\n            var i, sum = 0;\n            for ( i = 0; i < points.length; i++) {\n                sum += points[i].rad;\n            }\n            center.rad = sum / points.length;\n            center.vec = vec2.clone([Math.cos(center.rad), Math.sin(center.rad)]);\n        }\n\n        init();\n\n        return {\n            add: function(pointToAdd) {\n                if (!pointMap[pointToAdd.id]) {\n                    add(pointToAdd);\n                    updateCenter();\n                }\n            },\n            fits: function(otherPoint) {\n                // check cosine similarity to center-angle\n                var similarity = Math.abs(vec2.dot(otherPoint.point.vec, center.vec));\n                if (similarity > threshold) {\n                    return true;\n                }\n                return false;\n            },\n            getPoints: function() {\n                return points;\n            },\n            getCenter: function() {\n                return center;\n            }\n        };\n    },\n    createPoint: function(newPoint, id, property) {\n        return {\n            rad: newPoint[property],\n            point: newPoint,\n            id: id\n        };\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/cluster.js","export default (function() {\n    var events = {};\n\n    function getEvent(eventName) {\n        if (!events[eventName]) {\n            events[eventName] = {\n                subscribers: []\n            };\n        }\n        return events[eventName];\n    }\n\n    function clearEvents(){\n        events = {};\n    }\n\n    function publishSubscription(subscription, data) {\n        if (subscription.async) {\n            setTimeout(function() {\n                subscription.callback(data);\n            }, 4);\n        } else {\n            subscription.callback(data);\n        }\n    }\n\n    function subscribe(event, callback, async) {\n        var subscription;\n\n        if ( typeof callback === \"function\") {\n            subscription = {\n                callback: callback,\n                async: 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).subscribers.push(subscription);\n    }\n\n    return {\n        subscribe: function(event, callback, async) {\n            return subscribe(event, callback, async);\n        },\n        publish: function(eventName, data) {\n            var event = getEvent(eventName),\n                subscribers = event.subscribers;\n\n            // Publish one-time subscriptions\n            subscribers.filter(function(subscriber) {\n                return !!subscriber.once;\n            }).forEach((subscriber) => {\n                publishSubscription(subscriber, data);\n            });\n\n            // remove them from the subscriber\n            event.subscribers = subscribers.filter(function(subscriber) {\n                return !subscriber.once;\n            });\n\n            // publish the rest\n            event.subscribers.forEach((subscriber) => {\n                publishSubscription(subscriber, data);\n            });\n        },\n        once: function(event, callback, async) {\n            subscribe(event, {\n                callback: callback,\n                async: async,\n                once: true\n            });\n        },\n        unsubscribe: function(eventName, callback) {\n            var event;\n\n            if (eventName) {\n                event = getEvent(eventName);\n                if (event && callback) {\n                    event.subscribers = event.subscribers.filter(function(subscriber){\n                        return subscriber.callback !== callback;\n                    });\n                } else {\n                    event.subscribers = [];\n                }\n            } else {\n                clearEvents();\n            }\n        }\n    };\n})();\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/events.js","\nexport function enumerateDevices() {\n    if (navigator.mediaDevices\n            && 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) {\n    if (navigator.mediaDevices\n            && typeof navigator.mediaDevices.getUserMedia === 'function') {\n        return navigator.mediaDevices\n            .getUserMedia(constraints);\n    }\n    return Promise.reject(new Error('getUserMedia is not defined'));\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/mediaDevices.js","/**\n * Construct representing a part of another {ImageWrapper}. Shares data\n * between the parent and the child.\n * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner)\n * @param size {ImageRef} The size of the resulting image\n * @param I {ImageWrapper} The {ImageWrapper} to share from\n * @returns {SubImage} A shared part of the original image\n */\nfunction SubImage(from, size, I) {\n    if (!I) {\n        I = {\n            data: null,\n            size: size\n        };\n    }\n    this.data = I.data;\n    this.originalSize = I.size;\n    this.I = I;\n\n    this.from = from;\n    this.size = size;\n}\n\n/**\n * Displays the {SubImage} in a given canvas\n * @param canvas {Canvas} The canvas element to write to\n * @param scale {Number} Scale which is applied to each pixel-value\n */\nSubImage.prototype.show = function(canvas, scale) {\n    var ctx,\n        frame,\n        data,\n        current,\n        y,\n        x,\n        pixel;\n\n    if (!scale) {\n        scale = 1.0;\n    }\n    ctx = canvas.getContext('2d');\n    canvas.width = this.size.x;\n    canvas.height = this.size.y;\n    frame = ctx.getImageData(0, 0, canvas.width, canvas.height);\n    data = frame.data;\n    current = 0;\n    for (y = 0; y < this.size.y; y++) {\n        for (x = 0; x < this.size.x; x++) {\n            pixel = y * this.size.x + x;\n            current = this.get(x, y) * scale;\n            data[pixel * 4 + 0] = current;\n            data[pixel * 4 + 1] = current;\n            data[pixel * 4 + 2] = current;\n            data[pixel * 4 + 3] = 255;\n        }\n    }\n    frame.data = data;\n    ctx.putImageData(frame, 0, 0);\n};\n\n/**\n * Retrieves a given pixel position from the {SubImage}\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @returns {Number} The grayscale value at the pixel-position\n */\nSubImage.prototype.get = function(x, y) {\n    return this.data[(this.from.y + y) * this.originalSize.x + this.from.x + x];\n};\n\n/**\n * Updates the underlying data from a given {ImageWrapper}\n * @param image {ImageWrapper} The updated image\n */\nSubImage.prototype.updateData = function(image) {\n    this.originalSize = image.size;\n    this.data = image.data;\n};\n\n/**\n * Updates the position of the shared area\n * @param from {x,y} The new location\n * @returns {SubImage} returns {this} for possible chaining\n */\nSubImage.prototype.updateFrom = function(from) {\n    this.from = from;\n    return this;\n};\n\nexport default (SubImage);\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/subImage.js","/*\n * typedefs.js\n * Normalizes browser-specific prefixes\n */\n\nif (typeof window !== 'undefined') {\n    window.requestAnimFrame = (function () {\n        return window.requestAnimationFrame ||\n            window.webkitRequestAnimationFrame ||\n            window.mozRequestAnimationFrame ||\n            window.oRequestAnimationFrame ||\n            window.msRequestAnimationFrame ||\n            function (/* function FrameRequestCallback */ callback) {\n                window.setTimeout(callback, 1000 / 60);\n            };\n    })();\n}\nMath.imul = Math.imul || function(a, b) {\n    var ah = (a >>> 16) & 0xffff,\n        al = a & 0xffff,\n        bh = (b >>> 16) & 0xffff,\n        bl = b & 0xffff;\n    // the shift by 0 fixes the sign on the high part\n    // the final |0 converts the unsigned value into a signed value\n    return ((al * bl) + (((ah * bl + al * bh) << 16) >>> 0) | 0);\n};\n\nif (typeof Object.assign !== 'function') {\n    Object.assign = function(target) { // .length of function is 2\n        'use strict';\n        if (target === null) { // TypeError if undefined or null\n            throw new TypeError('Cannot convert undefined or null to object');\n        }\n\n        var to = Object(target);\n\n        for (var index = 1; index < arguments.length; index++) {\n            var nextSource = arguments[index];\n\n            if (nextSource !== null) { // Skip over if undefined or null\n                for (var nextKey in nextSource) {\n                    // Avoid bugs when hasOwnProperty is shadowed\n                    if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {\n                        to[nextKey] = nextSource[nextKey];\n                    }\n                }\n            }\n        }\n        return to;\n    };\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/typedefs.js","let config;\n\nif (ENV.development){\n    config = require('./config.dev.js');\n} else if (ENV.node) {\n    config = require('./config.node.js');\n} else {\n    config = require('./config.prod.js');\n}\n\nexport default config;\n\n\n\n// WEBPACK FOOTER //\n// ./src/config/config.js","module.exports = {\n    inputStream: {\n        type: \"ImageStream\",\n        sequence: false,\n        size: 800,\n        area: {\n            top: \"0%\",\n            right: \"0%\",\n            left: \"0%\",\n            bottom: \"0%\"\n        },\n        singleChannel: false // true: only the red color-channel is read\n    },\n    locate: true,\n    numOfWorkers: 0,\n    decoder: {\n        readers: [\n            'code_128_reader'\n        ]\n    },\n    locator: {\n        halfSample: true,\n        patchSize: \"medium\" // x-small, small, medium, large, x-large\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/config/config.node.js","import Bresenham from './bresenham';\nimport ImageDebug from '../common/image_debug';\nimport Code128Reader from '../reader/code_128_reader';\nimport EANReader from '../reader/ean_reader';\nimport Code39Reader from '../reader/code_39_reader';\nimport Code39VINReader from '../reader/code_39_vin_reader';\nimport CodabarReader from '../reader/codabar_reader';\nimport UPCReader from '../reader/upc_reader';\nimport EAN8Reader from '../reader/ean_8_reader';\nimport EAN2Reader from '../reader/ean_2_reader';\nimport EAN5Reader from '../reader/ean_5_reader';\nimport UPCEReader from '../reader/upc_e_reader';\nimport I2of5Reader from '../reader/i2of5_reader';\n\nconst READERS = {\n    code_128_reader: Code128Reader,\n    ean_reader: EANReader,\n    ean_5_reader: EAN5Reader,\n    ean_2_reader: EAN2Reader,\n    ean_8_reader: EAN8Reader,\n    code_39_reader: Code39Reader,\n    code_39_vin_reader: Code39VINReader,\n    codabar_reader: CodabarReader,\n    upc_reader: UPCReader,\n    upc_e_reader: UPCEReader,\n    i2of5_reader: I2of5Reader\n};\nexport default {\n    create: function(config, inputImageWrapper) {\n        var _canvas = {\n                ctx: {\n                    frequency: null,\n                    pattern: null,\n                    overlay: null\n                },\n                dom: {\n                    frequency: null,\n                    pattern: null,\n                    overlay: null\n                }\n            },\n            _barcodeReaders = [];\n\n        initCanvas();\n        initReaders();\n        initConfig();\n\n        function initCanvas() {\n            if (ENV.development && typeof document !== 'undefined') {\n                var $debug = document.querySelector(\"#debug.detection\");\n                _canvas.dom.frequency = document.querySelector(\"canvas.frequency\");\n                if (!_canvas.dom.frequency) {\n                    _canvas.dom.frequency = document.createElement(\"canvas\");\n                    _canvas.dom.frequency.className = \"frequency\";\n                    if ($debug) {\n                        $debug.appendChild(_canvas.dom.frequency);\n                    }\n                }\n                _canvas.ctx.frequency = _canvas.dom.frequency.getContext(\"2d\");\n\n                _canvas.dom.pattern = document.querySelector(\"canvas.patternBuffer\");\n                if (!_canvas.dom.pattern) {\n                    _canvas.dom.pattern = document.createElement(\"canvas\");\n                    _canvas.dom.pattern.className = \"patternBuffer\";\n                    if ($debug) {\n                        $debug.appendChild(_canvas.dom.pattern);\n                    }\n                }\n                _canvas.ctx.pattern = _canvas.dom.pattern.getContext(\"2d\");\n\n                _canvas.dom.overlay = document.querySelector(\"canvas.drawingBuffer\");\n                if (_canvas.dom.overlay) {\n                    _canvas.ctx.overlay = _canvas.dom.overlay.getContext(\"2d\");\n                }\n            }\n        }\n\n        function initReaders() {\n            config.readers.forEach(function(readerConfig) {\n                var reader,\n                    configuration = {},\n                    supplements = [];\n\n                if (typeof readerConfig === 'object') {\n                    reader = readerConfig.format;\n                    configuration = readerConfig.config;\n                } else if (typeof readerConfig === 'string') {\n                    reader = readerConfig;\n                }\n                if (ENV.development) {\n                    console.log(\"Before registering reader: \", reader);\n                }\n                if (configuration.supplements) {\n                    supplements = configuration\n                        .supplements.map((supplement) => {\n                            return new READERS[supplement]();\n                        });\n                }\n                _barcodeReaders.push(new READERS[reader](configuration, supplements));\n            });\n            if (ENV.development) {\n                console.log(\"Registered Readers: \" + _barcodeReaders\n                    .map((reader) => JSON.stringify({format: reader.FORMAT, config: reader.config}))\n                    .join(', '));\n            }\n        }\n\n        function initConfig() {\n            if (ENV.development && typeof document !== 'undefined') {\n                var i,\n                    vis = [{\n                        node: _canvas.dom.frequency,\n                        prop: config.debug.showFrequency\n                    }, {\n                        node: _canvas.dom.pattern,\n                        prop: config.debug.showPattern\n                    }];\n\n                for (i = 0; i < vis.length; i++) {\n                    if (vis[i].prop === true) {\n                        vis[i].node.style.display = \"block\";\n                    } else {\n                        vis[i].node.style.display = \"none\";\n                    }\n                }\n            }\n        }\n\n        /**\n         * extend the line on both ends\n         * @param {Array} line\n         * @param {Number} angle\n         */\n        function getExtendedLine(line, angle, ext) {\n            function extendLine(amount) {\n                var 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            // check if inside image\n            extendLine(ext);\n            while (ext > 1 && (!inputImageWrapper.inImageWithBorder(line[0], 0)\n                    || !inputImageWrapper.inImageWithBorder(line[1], 0))) {\n                ext -= Math.ceil(ext / 2);\n                extendLine(-ext);\n            }\n            return line;\n        }\n\n        function getLine(box) {\n            return [{\n                x: (box[1][0] - box[0][0]) / 2 + box[0][0],\n                y: (box[1][1] - box[0][1]) / 2 + box[0][1]\n            }, {\n                x: (box[3][0] - box[2][0]) / 2 + box[2][0],\n                y: (box[3][1] - box[2][1]) / 2 + box[2][1]\n            }];\n        }\n\n        function tryDecode(line) {\n            var result = null,\n                i,\n                barcodeLine = Bresenham.getBarcodeLine(inputImageWrapper, line[0], line[1]);\n\n            if (ENV.development && config.debug.showFrequency) {\n                ImageDebug.drawPath(line, {x: 'x', y: 'y'}, _canvas.ctx.overlay, {color: 'red', lineWidth: 3});\n                Bresenham.debug.printFrequency(barcodeLine.line, _canvas.dom.frequency);\n            }\n\n            Bresenham.toBinaryLine(barcodeLine);\n\n            if (ENV.development && config.debug.showPattern) {\n                Bresenham.debug.printPattern(barcodeLine.line, _canvas.dom.pattern);\n            }\n\n            for ( i = 0; i < _barcodeReaders.length && result === null; i++) {\n                result = _barcodeReaders[i].decodePattern(barcodeLine.line);\n            }\n            if (result === null){\n                return null;\n            }\n            return {\n                codeResult: result,\n                barcodeLine: barcodeLine\n            };\n        }\n\n        /**\n         * This method slices the given area apart and tries to detect a barcode-pattern\n         * for each slice. It returns the decoded barcode, or null if nothing was found\n         * @param {Array} box\n         * @param {Array} line\n         * @param {Number} lineAngle\n         */\n        function tryDecodeBruteForce(box, line, lineAngle) {\n            var sideLength = Math.sqrt(Math.pow(box[1][0] - box[0][0], 2) + Math.pow((box[1][1] - box[0][1]), 2)),\n                i,\n                slices = 16,\n                result = null,\n                dir,\n                extension,\n                xdir = Math.sin(lineAngle),\n                ydir = Math.cos(lineAngle);\n\n            for ( i = 1; i < slices && result === null; i++) {\n                // move line perpendicular to angle\n                dir = sideLength / slices * i * (i % 2 === 0 ? -1 : 1);\n                extension = {\n                    y: dir * xdir,\n                    x: dir * ydir\n                };\n                line[0].y += extension.x;\n                line[0].x -= extension.y;\n                line[1].y += extension.x;\n                line[1].x -= extension.y;\n\n                result = tryDecode(line);\n            }\n            return result;\n        }\n\n        function getLineLength(line) {\n            return Math.sqrt(\n                Math.pow(Math.abs(line[1].y - line[0].y), 2) +\n                Math.pow(Math.abs(line[1].x - line[0].x), 2));\n        }\n\n        /**\n         * With the help of the configured readers (Code128 or EAN) this function tries to detect a\n         * valid barcode pattern within the given area.\n         * @param {Object} box The area to search in\n         * @returns {Object} the result {codeResult, line, angle, pattern, threshold}\n         */\n        function decodeFromBoundingBox(box) {\n            var line,\n                lineAngle,\n                ctx = _canvas.ctx.overlay,\n                result,\n                lineLength;\n\n            if (ENV.development) {\n                if (config.debug.drawBoundingBox && ctx) {\n                    ImageDebug.drawPath(box, {x: 0, y: 1}, ctx, {color: \"blue\", lineWidth: 2});\n                }\n            }\n\n            line = getLine(box);\n            lineLength = getLineLength(line);\n            lineAngle = Math.atan2(line[1].y - line[0].y, line[1].x - line[0].x);\n            line = getExtendedLine(line, lineAngle, Math.floor(lineLength * 0.1));\n            if (line === null){\n                return null;\n            }\n\n            result = tryDecode(line);\n            if (result === null) {\n                result = tryDecodeBruteForce(box, line, lineAngle);\n            }\n\n            if (result === null) {\n                return null;\n            }\n\n            if (ENV.development && result && config.debug.drawScanline && ctx) {\n                ImageDebug.drawPath(line, {x: 'x', y: 'y'}, ctx, {color: 'red', lineWidth: 3});\n            }\n\n            return {\n                codeResult: result.codeResult,\n                line: line,\n                angle: lineAngle,\n                pattern: result.barcodeLine.line,\n                threshold: result.barcodeLine.threshold\n            };\n        }\n\n        return {\n            decodeFromBoundingBox: function(box) {\n                return decodeFromBoundingBox(box);\n            },\n            decodeFromBoundingBoxes: function(boxes) {\n                var i, result,\n                    barcodes = [],\n                    multiple = config.multiple;\n\n                for ( i = 0; i < boxes.length; i++) {\n                    const box = boxes[i];\n                    result = decodeFromBoundingBox(box) || {};\n                    result.box = box;\n\n                    if (multiple) {\n                        barcodes.push(result);\n                    } else if (result.codeResult) {\n                        return result;\n                    }\n                }\n\n                if (multiple) {\n                    return {\n                        barcodes\n                    };\n                }\n            },\n            setReaders: function(readers) {\n                config.readers = readers;\n                _barcodeReaders.length = 0;\n                initReaders();\n            }\n        };\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/decoder/barcode_decoder.js","import ImageWrapper from '../common/image_wrapper';\n\nvar Bresenham = {};\n\nvar Slope = {\n    DIR: {\n        UP: 1,\n        DOWN: -1\n    }\n};\n/**\n * Scans a line of the given image from point p1 to p2 and returns a result object containing\n * gray-scale values (0-255) of the underlying pixels in addition to the min\n * and max values.\n * @param {Object} imageWrapper\n * @param {Object} p1 The start point {x,y}\n * @param {Object} p2 The end point {x,y}\n * @returns {line, min, max}\n */\nBresenham.getBarcodeLine = function(imageWrapper, p1, p2) {\n    var x0 = p1.x | 0,\n        y0 = p1.y | 0,\n        x1 = p2.x | 0,\n        y1 = p2.y | 0,\n        steep = Math.abs(y1 - y0) > Math.abs(x1 - x0),\n        deltax,\n        deltay,\n        error,\n        ystep,\n        y,\n        tmp,\n        x,\n        line = [],\n        imageData = imageWrapper.data,\n        width = imageWrapper.size.x,\n        sum = 0,\n        val,\n        min = 255,\n        max = 0;\n\n    function read(a, b) {\n        val = imageData[b * width + a];\n        sum += val;\n        min = val < min ? val : min;\n        max = val > max ? val : max;\n        line.push(val);\n    }\n\n    if (steep) {\n        tmp = x0;\n        x0 = y0;\n        y0 = tmp;\n\n        tmp = x1;\n        x1 = y1;\n        y1 = tmp;\n    }\n    if (x0 > x1) {\n        tmp = x0;\n        x0 = x1;\n        x1 = tmp;\n\n        tmp = y0;\n        y0 = y1;\n        y1 = tmp;\n    }\n    deltax = x1 - x0;\n    deltay = Math.abs(y1 - y0);\n    error = (deltax / 2) | 0;\n    y = y0;\n    ystep = y0 < y1 ? 1 : -1;\n    for ( x = x0; x < x1; x++) {\n        if (steep){\n            read(y, x);\n        } else {\n            read(x, y);\n        }\n        error = error - deltay;\n        if (error < 0) {\n            y = y + ystep;\n            error = error + deltax;\n        }\n    }\n\n    return {\n        line: line,\n        min: min,\n        max: max\n    };\n};\n\n/**\n * Converts the result from getBarcodeLine into a binary representation\n * also considering the frequency and slope of the signal for more robust results\n * @param {Object} result {line, min, max}\n */\nBresenham.toBinaryLine = function(result) {\n    var min = result.min,\n        max = result.max,\n        line = result.line,\n        slope,\n        slope2,\n        center = min + (max - min) / 2,\n        extrema = [],\n        currentDir,\n        dir,\n        threshold = (max - min) / 12,\n        rThreshold = -threshold,\n        i,\n        j;\n\n    // 1. find extrema\n    currentDir = line[0] > center ? Slope.DIR.UP : Slope.DIR.DOWN;\n    extrema.push({\n        pos: 0,\n        val: line[0]\n    });\n    for ( i = 0; i < line.length - 2; i++) {\n        slope = (line[i + 1] - line[i]);\n        slope2 = (line[i + 2] - line[i + 1]);\n        if ((slope + slope2) < rThreshold && line[i + 1] < (center * 1.5)) {\n            dir = Slope.DIR.DOWN;\n        } else if ((slope + slope2) > threshold && line[i + 1] > (center * 0.5)) {\n            dir = Slope.DIR.UP;\n        } else {\n            dir = currentDir;\n        }\n\n        if (currentDir !== dir) {\n            extrema.push({\n                pos: i,\n                val: line[i]\n            });\n            currentDir = dir;\n        }\n    }\n    extrema.push({\n        pos: line.length,\n        val: line[line.length - 1]\n    });\n\n    for ( j = extrema[0].pos; j < extrema[1].pos; j++) {\n        line[j] = line[j] > center ? 0 : 1;\n    }\n\n    // iterate over extrema and convert to binary based on avg between minmax\n    for ( i = 1; i < extrema.length - 1; i++) {\n        if (extrema[i + 1].val > extrema[i].val) {\n            threshold = (extrema[i].val + ((extrema[i + 1].val - extrema[i].val) / 3) * 2) | 0;\n        } else {\n            threshold = (extrema[i + 1].val + ((extrema[i].val - extrema[i + 1].val) / 3)) | 0;\n        }\n\n        for ( j = extrema[i].pos; j < extrema[i + 1].pos; j++) {\n            line[j] = line[j] > threshold ? 0 : 1;\n        }\n    }\n\n    return {\n        line: line,\n        threshold: threshold\n    };\n};\n\n/**\n * Used for development only\n */\nBresenham.debug = {\n    printFrequency: function(line, canvas) {\n        var i,\n            ctx = canvas.getContext(\"2d\");\n        canvas.width = line.length;\n        canvas.height = 256;\n\n        ctx.beginPath();\n        ctx.strokeStyle = \"blue\";\n        for ( i = 0; i < line.length; i++) {\n            ctx.moveTo(i, 255);\n            ctx.lineTo(i, 255 - line[i]);\n        }\n        ctx.stroke();\n        ctx.closePath();\n    },\n\n    printPattern: function(line, canvas) {\n        var ctx = canvas.getContext(\"2d\"), i;\n\n        canvas.width = line.length;\n        ctx.fillColor = \"black\";\n        for ( i = 0; i < line.length; i++) {\n            if (line[i] === 1) {\n                ctx.fillRect(i, 0, 1, 100);\n            }\n        }\n    }\n};\n\nexport default Bresenham;\n\n\n\n// WEBPACK FOOTER //\n// ./src/decoder/bresenham.js","import {omit, pick} from 'lodash';\nimport {getUserMedia, enumerateDevices} from 'mediaDevices';\n\nconst facingMatching = {\n    \"user\": /front/i,\n    \"environment\": /back/i\n};\n\nvar streamRef;\n\nfunction waitForVideo(video) {\n    return new Promise((resolve, reject) => {\n        let attempts = 10;\n\n        function checkVideo() {\n            if (attempts > 0) {\n                if (video.videoWidth > 0 && video.videoHeight > 0) {\n                    if (ENV.development) {\n                        console.log(video.videoWidth + \"px x \" + video.videoHeight + \"px\");\n                    }\n                    resolve();\n                } else {\n                    window.setTimeout(checkVideo, 500);\n                }\n            } else {\n                reject('Unable to play video stream. Is webcam working?');\n            }\n            attempts--;\n        }\n        checkVideo();\n    });\n}\n\n/**\n * Tries to attach the camera-stream to a given video-element\n * and calls the callback function when the content is ready\n * @param {Object} constraints\n * @param {Object} video\n */\nfunction initCamera(video, constraints) {\n    return getUserMedia(constraints)\n    .then((stream) => {\n        return new Promise((resolve) => {\n            streamRef = stream;\n            video.setAttribute(\"autoplay\", 'true');\n            video.srcObject = stream;\n            video.addEventListener('loadedmetadata', () => {\n                video.play();\n                resolve();\n            });\n        });\n    })\n    .then(waitForVideo.bind(null, video));\n}\n\nfunction deprecatedConstraints(videoConstraints) {\n    const normalized = pick(videoConstraints, [\"width\", \"height\", \"facingMode\",\n            \"aspectRatio\", \"deviceId\"]);\n\n    if (typeof videoConstraints.minAspectRatio !== 'undefined' &&\n            videoConstraints.minAspectRatio > 0) {\n        normalized.aspectRatio = videoConstraints.minAspectRatio;\n        console.log(\"WARNING: Constraint 'minAspectRatio' is deprecated; Use 'aspectRatio' instead\");\n    }\n    if (typeof videoConstraints.facing !== 'undefined') {\n        normalized.facingMode = videoConstraints.facing;\n        console.log(\"WARNING: Constraint 'facing' is deprecated. Use 'facingMode' instead'\");\n    }\n    return normalized;\n}\n\nexport function pickConstraints(videoConstraints) {\n    const normalizedConstraints = {\n        audio: false,\n        video: deprecatedConstraints(videoConstraints)\n    };\n\n    if (normalizedConstraints.video.deviceId\n            && normalizedConstraints.video.facingMode) {\n        delete normalizedConstraints.video.facingMode;\n    }\n    return Promise.resolve(normalizedConstraints);\n}\n\nfunction enumerateVideoDevices() {\n    return enumerateDevices()\n    .then(devices => devices.filter(device => device.kind === 'videoinput'));\n}\n\nexport default {\n    request: function(video, videoConstraints) {\n        return pickConstraints(videoConstraints)\n            .then(initCamera.bind(null, video));\n    },\n    release: function() {\n        var tracks = streamRef && streamRef.getVideoTracks();\n        if (tracks && tracks.length) {\n            tracks[0].stop();\n        }\n        streamRef = null;\n    },\n    enumerateVideoDevices,\n    getActiveStreamLabel: function() {\n        if (streamRef) {\n            const tracks = streamRef.getVideoTracks();\n            if (tracks && tracks.length) {\n                return tracks[0].label;\n            }\n        }\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/input/camera_access.js","import ImageWrapper from '../common/image_wrapper';\nimport {\n    calculatePatchSize,\n    otsuThreshold,\n    hsv2rgb,\n    cluster,\n    topGeneric,\n    imageRef,\n    halfSample,\n    computeImageArea\n} from '../common/cv_utils';\nimport ArrayHelper from '../common/array_helper';\nimport ImageDebug from '../common/image_debug';\nimport Rasterizer from './rasterizer';\nimport Tracer from './tracer';\nimport skeletonizer from './skeletonizer';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n    dot:  require('gl-vec2/dot'),\n    scale: require('gl-vec2/scale'),\n    transformMat2: require('gl-vec2/transformMat2')\n};\nconst mat2 = {\n    copy: require('gl-mat2/copy'),\n    create: require('gl-mat2/create'),\n    invert: require('gl-mat2/invert')\n}\n\nvar _config,\n    _currentImageWrapper,\n    _skelImageWrapper,\n    _subImageWrapper,\n    _labelImageWrapper,\n    _patchGrid,\n    _patchLabelGrid,\n    _imageToPatchGrid,\n    _binaryImageWrapper,\n    _patchSize,\n    _canvasContainer = {\n        ctx: {\n            binary: null\n        },\n        dom: {\n            binary: null\n        }\n    },\n    _numPatches = {x: 0, y: 0},\n    _inputImageWrapper,\n    _skeletonizer;\n\nfunction initBuffers() {\n    var skeletonImageData;\n\n    if (_config.halfSample) {\n        _currentImageWrapper = new ImageWrapper({\n            x: _inputImageWrapper.size.x / 2 | 0,\n            y: _inputImageWrapper.size.y / 2 | 0\n        });\n    } else {\n        _currentImageWrapper = _inputImageWrapper;\n    }\n\n    _patchSize = calculatePatchSize(_config.patchSize, _currentImageWrapper.size);\n\n    _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0;\n    _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0;\n\n    _binaryImageWrapper = new ImageWrapper(_currentImageWrapper.size, undefined, Uint8Array, false);\n\n    _labelImageWrapper = new ImageWrapper(_patchSize, undefined, Array, true);\n\n    skeletonImageData = new ArrayBuffer(64 * 1024);\n    _subImageWrapper = new ImageWrapper(_patchSize,\n        new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y));\n    _skelImageWrapper = new ImageWrapper(_patchSize,\n        new Uint8Array(skeletonImageData, _patchSize.x * _patchSize.y * 3, _patchSize.x * _patchSize.y),\n        undefined, true);\n    _skeletonizer = skeletonizer((typeof window !== 'undefined') ? window : (typeof self !== 'undefined') ? self : global, {\n        size: _patchSize.x\n    }, skeletonImageData);\n\n    _imageToPatchGrid = new ImageWrapper({\n        x: (_currentImageWrapper.size.x / _subImageWrapper.size.x) | 0,\n        y: (_currentImageWrapper.size.y / _subImageWrapper.size.y) | 0\n    }, undefined, Array, true);\n    _patchGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, undefined, true);\n    _patchLabelGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, Int32Array, true);\n}\n\nfunction initCanvas() {\n    if (_config.useWorker || typeof document === 'undefined') {\n        return;\n    }\n    _canvasContainer.dom.binary = document.createElement(\"canvas\");\n    _canvasContainer.dom.binary.className = \"binaryBuffer\";\n    if (ENV.development && _config.debug.showCanvas === true) {\n        document.querySelector(\"#debug\").appendChild(_canvasContainer.dom.binary);\n    }\n    _canvasContainer.ctx.binary = _canvasContainer.dom.binary.getContext(\"2d\");\n    _canvasContainer.dom.binary.width = _binaryImageWrapper.size.x;\n    _canvasContainer.dom.binary.height = _binaryImageWrapper.size.y;\n}\n\n/**\n * Creates a bounding box which encloses all the given patches\n * @returns {Array} The minimal bounding box\n */\nfunction boxFromPatches(patches) {\n    var overAvg,\n        i,\n        j,\n        patch,\n        transMat,\n        minx =\n        _binaryImageWrapper.size.x,\n        miny = _binaryImageWrapper.size.y,\n        maxx = -_binaryImageWrapper.size.x,\n        maxy = -_binaryImageWrapper.size.y,\n        box,\n        scale;\n\n    // draw all patches which are to be taken into consideration\n    overAvg = 0;\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        overAvg += patch.rad;\n        if (ENV.development && _config.debug.showPatches) {\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, {color: \"red\"});\n        }\n    }\n\n    overAvg /= patches.length;\n    overAvg = (overAvg * 180 / Math.PI + 90) % 180 - 90;\n    if (overAvg < 0) {\n        overAvg += 180;\n    }\n\n    overAvg = (180 - overAvg) * Math.PI / 180;\n    transMat = mat2.copy(mat2.create(), [Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]);\n\n    // iterate over patches and rotate by angle\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        for ( j = 0; j < 4; j++) {\n            vec2.transformMat2(patch.box[j], patch.box[j], transMat);\n        }\n\n        if (ENV.development && _config.debug.boxFromPatches.showTransformed) {\n            ImageDebug.drawPath(patch.box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#99ff00', lineWidth: 2});\n        }\n    }\n\n    // find bounding box\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        for ( j = 0; j < 4; j++) {\n            if (patch.box[j][0] < minx) {\n                minx = patch.box[j][0];\n            }\n            if (patch.box[j][0] > maxx) {\n                maxx = patch.box[j][0];\n            }\n            if (patch.box[j][1] < miny) {\n                miny = patch.box[j][1];\n            }\n            if (patch.box[j][1] > maxy) {\n                maxy = patch.box[j][1];\n            }\n        }\n    }\n\n    box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]];\n\n    if (ENV.development && _config.debug.boxFromPatches.showTransformedBox) {\n        ImageDebug.drawPath(box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#ff0000', lineWidth: 2});\n    }\n\n    scale = _config.halfSample ? 2 : 1;\n    // reverse rotation;\n    transMat = mat2.invert(transMat, transMat);\n    for ( j = 0; j < 4; j++) {\n        vec2.transformMat2(box[j], box[j], transMat);\n    }\n\n    if (ENV.development && _config.debug.boxFromPatches.showBB) {\n        ImageDebug.drawPath(box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#ff0000', lineWidth: 2});\n    }\n\n    for ( j = 0; j < 4; j++) {\n        vec2.scale(box[j], box[j], scale);\n    }\n\n    return box;\n}\n\n/**\n * Creates a binary image of the current image\n */\nfunction binarizeImage() {\n    otsuThreshold(_currentImageWrapper, _binaryImageWrapper);\n    _binaryImageWrapper.zeroBorder();\n    if (ENV.development && _config.debug.showCanvas) {\n        _binaryImageWrapper.show(_canvasContainer.dom.binary, 255);\n    }\n}\n\n/**\n * Iterate over the entire image\n * extract patches\n */\nfunction findPatches() {\n    var i,\n        j,\n        x,\n        y,\n        moments,\n        patchesFound = [],\n        rasterizer,\n        rasterResult,\n        patch;\n    for (i = 0; i < _numPatches.x; i++) {\n        for (j = 0; j < _numPatches.y; j++) {\n            x = _subImageWrapper.size.x * i;\n            y = _subImageWrapper.size.y * j;\n\n            // seperate parts\n            skeletonize(x, y);\n\n            // Rasterize, find individual bars\n            _skelImageWrapper.zeroBorder();\n            ArrayHelper.init(_labelImageWrapper.data, 0);\n            rasterizer = Rasterizer.create(_skelImageWrapper, _labelImageWrapper);\n            rasterResult = rasterizer.rasterize(0);\n\n            if (ENV.development && _config.debug.showLabels) {\n                _labelImageWrapper.overlay(_canvasContainer.dom.binary, Math.floor(360 / rasterResult.count),\n                    {x: x, y: y});\n            }\n\n            // calculate moments from the skeletonized patch\n            moments = _labelImageWrapper.moments(rasterResult.count);\n\n            // extract eligible patches\n            patchesFound = patchesFound.concat(describePatch(moments, [i, j], x, y));\n        }\n    }\n\n    if (ENV.development && _config.debug.showFoundPatches) {\n        for ( i = 0; i < patchesFound.length; i++) {\n            patch = patchesFound[i];\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                {color: \"#99ff00\", lineWidth: 2});\n        }\n    }\n\n    return patchesFound;\n}\n\n/**\n * Finds those connected areas which contain at least 6 patches\n * and returns them ordered DESC by the number of contained patches\n * @param {Number} maxLabel\n */\nfunction findBiggestConnectedAreas(maxLabel){\n    var i,\n        sum,\n        labelHist = [],\n        topLabels = [];\n\n    for ( i = 0; i < maxLabel; i++) {\n        labelHist.push(0);\n    }\n    sum = _patchLabelGrid.data.length;\n    while (sum--) {\n        if (_patchLabelGrid.data[sum] > 0) {\n            labelHist[_patchLabelGrid.data[sum] - 1]++;\n        }\n    }\n\n    labelHist = labelHist.map(function(val, idx) {\n        return {\n            val: val,\n            label: idx + 1\n        };\n    });\n\n    labelHist.sort(function(a, b) {\n        return b.val - a.val;\n    });\n\n    // extract top areas with at least 6 patches present\n    topLabels = labelHist.filter(function(el) {\n        return el.val >= 5;\n    });\n\n    return topLabels;\n}\n\n/**\n *\n */\nfunction findBoxes(topLabels, maxLabel) {\n    var i,\n        j,\n        sum,\n        patches = [],\n        patch,\n        box,\n        boxes = [],\n        hsv = [0, 1, 1],\n        rgb = [0, 0, 0];\n\n    for ( i = 0; i < topLabels.length; i++) {\n        sum = _patchLabelGrid.data.length;\n        patches.length = 0;\n        while (sum--) {\n            if (_patchLabelGrid.data[sum] === topLabels[i].label) {\n                patch = _imageToPatchGrid.data[sum];\n                patches.push(patch);\n            }\n        }\n        box = boxFromPatches(patches);\n        if (box) {\n            boxes.push(box);\n\n            // draw patch-labels if requested\n            if (ENV.development && _config.debug.showRemainingPatchLabels) {\n                for ( j = 0; j < patches.length; j++) {\n                    patch = patches[j];\n                    hsv[0] = (topLabels[i].label / (maxLabel + 1)) * 360;\n                    hsv2rgb(hsv, rgb);\n                    ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                        {color: \"rgb(\" + rgb.join(\",\") + \")\", lineWidth: 2});\n                }\n            }\n        }\n    }\n    return boxes;\n}\n\n/**\n * Find similar moments (via cluster)\n * @param {Object} moments\n */\nfunction similarMoments(moments) {\n    var clusters = cluster(moments, 0.90);\n    var topCluster = topGeneric(clusters, 1, function(e) {\n        return e.getPoints().length;\n    });\n    var points = [], result = [];\n    if (topCluster.length === 1) {\n        points = topCluster[0].item.getPoints();\n        for (var i = 0; i < points.length; i++) {\n            result.push(points[i].point);\n        }\n    }\n    return result;\n}\n\nfunction skeletonize(x, y) {\n    _binaryImageWrapper.subImageAsCopy(_subImageWrapper, imageRef(x, y));\n    _skeletonizer.skeletonize();\n\n    // Show skeleton if requested\n    if (ENV.development && _config.debug.showSkeleton) {\n        _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, imageRef(x, y));\n    }\n}\n\n/**\n * Extracts and describes those patches which seem to contain a barcode pattern\n * @param {Array} moments\n * @param {Object} patchPos,\n * @param {Number} x\n * @param {Number} y\n * @returns {Array} list of patches\n */\nfunction describePatch(moments, patchPos, x, y) {\n    var k,\n        avg,\n        eligibleMoments = [],\n        matchingMoments,\n        patch,\n        patchesFound = [],\n        minComponentWeight = Math.ceil(_patchSize.x / 3);\n\n    if (moments.length >= 2) {\n        // only collect moments which's area covers at least minComponentWeight pixels.\n        for ( k = 0; k < moments.length; k++) {\n            if (moments[k].m00 > minComponentWeight) {\n                eligibleMoments.push(moments[k]);\n            }\n        }\n\n        // if at least 2 moments are found which have at least minComponentWeights covered\n        if (eligibleMoments.length >= 2) {\n            matchingMoments = similarMoments(eligibleMoments);\n            avg = 0;\n            // determine the similarity of the moments\n            for ( k = 0; k < matchingMoments.length; k++) {\n                avg += matchingMoments[k].rad;\n            }\n\n            // Only two of the moments are allowed not to fit into the equation\n            // add the patch to the set\n            if (matchingMoments.length > 1\n                    && matchingMoments.length >= (eligibleMoments.length / 4) * 3\n                    && matchingMoments.length > moments.length / 4) {\n                avg /= matchingMoments.length;\n                patch = {\n                    index: patchPos[1] * _numPatches.x + patchPos[0],\n                    pos: {\n                        x: x,\n                        y: y\n                    },\n                    box: [\n                        vec2.clone([x, y]),\n                        vec2.clone([x + _subImageWrapper.size.x, y]),\n                        vec2.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]),\n                        vec2.clone([x, y + _subImageWrapper.size.y])\n                    ],\n                    moments: matchingMoments,\n                    rad: avg,\n                    vec: vec2.clone([Math.cos(avg), Math.sin(avg)])\n                };\n                patchesFound.push(patch);\n            }\n        }\n    }\n    return patchesFound;\n}\n\n/**\n * finds patches which are connected and share the same orientation\n * @param {Object} patchesFound\n */\nfunction rasterizeAngularSimilarity(patchesFound) {\n    var label = 0,\n        threshold = 0.95,\n        currIdx = 0,\n        j,\n        patch,\n        hsv = [0, 1, 1],\n        rgb = [0, 0, 0];\n\n    function notYetProcessed() {\n        var i;\n        for ( i = 0; i < _patchLabelGrid.data.length; i++) {\n            if (_patchLabelGrid.data[i] === 0 && _patchGrid.data[i] === 1) {\n                return i;\n            }\n        }\n        return _patchLabelGrid.length;\n    }\n\n    function trace(currentIdx) {\n        var x,\n            y,\n            currentPatch,\n            idx,\n            dir,\n            current = {\n                x: currentIdx % _patchLabelGrid.size.x,\n                y: (currentIdx / _patchLabelGrid.size.x) | 0\n            },\n            similarity;\n\n        if (currentIdx < _patchLabelGrid.data.length) {\n            currentPatch = _imageToPatchGrid.data[currentIdx];\n            // assign label\n            _patchLabelGrid.data[currentIdx] = label;\n            for ( dir = 0; dir < Tracer.searchDirections.length; dir++) {\n                y = current.y + Tracer.searchDirections[dir][0];\n                x = current.x + Tracer.searchDirections[dir][1];\n                idx = y * _patchLabelGrid.size.x + x;\n\n                // continue if patch empty\n                if (_patchGrid.data[idx] === 0) {\n                    _patchLabelGrid.data[idx] = Number.MAX_VALUE;\n                    continue;\n                }\n\n                if (_patchLabelGrid.data[idx] === 0) {\n                    similarity = Math.abs(vec2.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec));\n                    if (similarity > threshold) {\n                        trace(idx);\n                    }\n                }\n            }\n        }\n    }\n\n    // prepare for finding the right patches\n    ArrayHelper.init(_patchGrid.data, 0);\n    ArrayHelper.init(_patchLabelGrid.data, 0);\n    ArrayHelper.init(_imageToPatchGrid.data, null);\n\n    for ( j = 0; j < patchesFound.length; j++) {\n        patch = patchesFound[j];\n        _imageToPatchGrid.data[patch.index] = patch;\n        _patchGrid.data[patch.index] = 1;\n    }\n\n    // rasterize the patches found to determine area\n    _patchGrid.zeroBorder();\n\n    while (( currIdx = notYetProcessed()) < _patchLabelGrid.data.length) {\n        label++;\n        trace(currIdx);\n    }\n\n    // draw patch-labels if requested\n    if (ENV.development && _config.debug.showPatchLabels) {\n        for ( j = 0; j < _patchLabelGrid.data.length; j++) {\n            if (_patchLabelGrid.data[j] > 0 && _patchLabelGrid.data[j] <= label) {\n                patch = _imageToPatchGrid.data[j];\n                hsv[0] = (_patchLabelGrid.data[j] / (label + 1)) * 360;\n                hsv2rgb(hsv, rgb);\n                ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                    {color: \"rgb(\" + rgb.join(\",\") + \")\", lineWidth: 2});\n            }\n        }\n    }\n\n    return label;\n}\n\nexport default {\n    init: function(inputImageWrapper, config) {\n        _config = config;\n        _inputImageWrapper = inputImageWrapper;\n\n        initBuffers();\n        initCanvas();\n    },\n\n    locate: function() {\n        var patchesFound,\n            topLabels,\n            boxes;\n\n        if (_config.halfSample) {\n            halfSample(_inputImageWrapper, _currentImageWrapper);\n        }\n\n        binarizeImage();\n        patchesFound = findPatches();\n        // return unless 5% or more patches are found\n        if (patchesFound.length < _numPatches.x * _numPatches.y * 0.05) {\n            return null;\n        }\n\n        // rasterrize area by comparing angular similarity;\n        var maxLabel = rasterizeAngularSimilarity(patchesFound);\n        if (maxLabel < 1) {\n            return null;\n        }\n\n        // search for area with the most patches (biggest connected area)\n        topLabels = findBiggestConnectedAreas(maxLabel);\n        if (topLabels.length === 0) {\n            return null;\n        }\n\n        boxes = findBoxes(topLabels, maxLabel);\n        return boxes;\n    },\n\n    checkImageConstraints: function(inputStream, config) {\n        var patchSize,\n            width = inputStream.getWidth(),\n            height = inputStream.getHeight(),\n            halfSample = config.halfSample ? 0.5 : 1,\n            size,\n            area;\n\n        // calculate width and height based on area\n        if (inputStream.getConfig().area) {\n            area = computeImageArea(width, height, inputStream.getConfig().area);\n            inputStream.setTopRight({x: area.sx, y: area.sy});\n            inputStream.setCanvasSize({x: width, y: height});\n            width = area.sw;\n            height = area.sh;\n        }\n\n        size = {\n            x: Math.floor(width * halfSample),\n            y: Math.floor(height * halfSample)\n        };\n\n        patchSize = calculatePatchSize(config.patchSize, size);\n        if (ENV.development) {\n            console.log(\"Patch-Size: \" + JSON.stringify(patchSize));\n        }\n\n        inputStream.setWidth(Math.floor(Math.floor(size.x / patchSize.x) * (1 / halfSample) * patchSize.x));\n        inputStream.setHeight(Math.floor(Math.floor(size.y / patchSize.y) * (1 / halfSample) * patchSize.y));\n\n        if ((inputStream.getWidth() % patchSize.x) === 0 && (inputStream.getHeight() % patchSize.y) === 0) {\n            return true;\n        }\n\n        throw new Error(\"Image dimensions do not comply with the current settings: Width (\" +\n            width + \" )and height (\" + height +\n            \") must a multiple of \" + patchSize.x);\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/barcode_locator.js","import Tracer from './tracer';\n\n/**\n * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\n */\nvar Rasterizer = {\n    createContour2D: function() {\n        return {\n            dir: null,\n            index: null,\n            firstVertex: null,\n            insideContours: null,\n            nextpeer: null,\n            prevpeer: null\n        };\n    },\n    CONTOUR_DIR: {\n        CW_DIR: 0,\n        CCW_DIR: 1,\n        UNKNOWN_DIR: 2\n    },\n    DIR: {\n        OUTSIDE_EDGE: -32767,\n        INSIDE_EDGE: -32766\n    },\n    create: function(imageWrapper, labelWrapper) {\n        var imageData = imageWrapper.data,\n            labelData = labelWrapper.data,\n            width = imageWrapper.size.x,\n            height = imageWrapper.size.y,\n            tracer = Tracer.create(imageWrapper, labelWrapper);\n\n        return {\n            rasterize: function(depthlabel) {\n                var color,\n                    bc,\n                    lc,\n                    labelindex,\n                    cx,\n                    cy,\n                    colorMap = [],\n                    vertex,\n                    p,\n                    cc,\n                    sc,\n                    pos,\n                    connectedCount = 0,\n                    i;\n\n                for ( i = 0; i < 400; i++) {\n                    colorMap[i] = 0;\n                }\n\n                colorMap[0] = imageData[0];\n                cc = null;\n                for ( cy = 1; cy < height - 1; cy++) {\n                    labelindex = 0;\n                    bc = colorMap[0];\n                    for ( cx = 1; cx < width - 1; cx++) {\n                        pos = cy * width + cx;\n                        if (labelData[pos] === 0) {\n                            color = imageData[pos];\n                            if (color !== bc) {\n                                if (labelindex === 0) {\n                                    lc = connectedCount + 1;\n                                    colorMap[lc] = color;\n                                    bc = color;\n                                    vertex = tracer.contourTracing(cy, cx, lc, color, Rasterizer.DIR.OUTSIDE_EDGE);\n                                    if (vertex !== null) {\n                                        connectedCount++;\n                                        labelindex = lc;\n                                        p = Rasterizer.createContour2D();\n                                        p.dir = Rasterizer.CONTOUR_DIR.CW_DIR;\n                                        p.index = labelindex;\n                                        p.firstVertex = vertex;\n                                        p.nextpeer = cc;\n                                        p.insideContours = null;\n                                        if (cc !== null) {\n                                            cc.prevpeer = p;\n                                        }\n                                        cc = p;\n                                    }\n                                } else {\n                                    vertex = tracer\n                                        .contourTracing(cy, cx, Rasterizer.DIR.INSIDE_EDGE, color, labelindex);\n                                    if (vertex !== null) {\n                                        p = Rasterizer.createContour2D();\n                                        p.firstVertex = vertex;\n                                        p.insideContours = null;\n                                        if (depthlabel === 0) {\n                                            p.dir = Rasterizer.CONTOUR_DIR.CCW_DIR;\n                                        } else {\n                                            p.dir = Rasterizer.CONTOUR_DIR.CW_DIR;\n                                        }\n                                        p.index = depthlabel;\n                                        sc = cc;\n                                        while ((sc !== null) && sc.index !== labelindex) {\n                                            sc = sc.nextpeer;\n                                        }\n                                        if (sc !== null) {\n                                            p.nextpeer = sc.insideContours;\n                                            if (sc.insideContours !== null) {\n                                                sc.insideContours.prevpeer = p;\n                                            }\n                                            sc.insideContours = p;\n                                        }\n                                    }\n                                }\n                            } else {\n                                labelData[pos] = labelindex;\n                            }\n                        } else if (labelData[pos] === Rasterizer.DIR.OUTSIDE_EDGE\n                                || labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) {\n                            labelindex = 0;\n                            if (labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) {\n                                bc = imageData[pos];\n                            } else {\n                                bc = colorMap[0];\n                            }\n                        } else {\n                            labelindex = labelData[pos];\n                            bc = colorMap[labelindex];\n                        }\n                    }\n                }\n                sc = cc;\n                while (sc !== null) {\n                    sc.index = depthlabel;\n                    sc = sc.nextpeer;\n                }\n                return {\n                    cc: cc,\n                    count: connectedCount\n                };\n            },\n            debug: {\n                drawContour: function(canvas, firstContour) {\n                    var ctx = canvas.getContext(\"2d\"),\n                        pq = firstContour,\n                        iq,\n                        q,\n                        p;\n\n                    ctx.strokeStyle = \"red\";\n                    ctx.fillStyle = \"red\";\n                    ctx.lineWidth = 1;\n\n                    if (pq !== null) {\n                        iq = pq.insideContours;\n                    } else {\n                        iq = null;\n                    }\n\n                    while (pq !== null) {\n                        if (iq !== null) {\n                            q = iq;\n                            iq = iq.nextpeer;\n                        } else {\n                            q = pq;\n                            pq = pq.nextpeer;\n                            if (pq !== null) {\n                                iq = pq.insideContours;\n                            } else {\n                                iq = null;\n                            }\n                        }\n\n                        switch (q.dir) {\n                        case Rasterizer.CONTOUR_DIR.CW_DIR:\n                            ctx.strokeStyle = \"red\";\n                            break;\n                        case Rasterizer.CONTOUR_DIR.CCW_DIR:\n                            ctx.strokeStyle = \"blue\";\n                            break;\n                        case Rasterizer.CONTOUR_DIR.UNKNOWN_DIR:\n                            ctx.strokeStyle = \"green\";\n                            break;\n                        }\n\n                        p = q.firstVertex;\n                        ctx.beginPath();\n                        ctx.moveTo(p.x, p.y);\n                        do {\n                            p = p.next;\n                            ctx.lineTo(p.x, p.y);\n                        } while (p !== q.firstVertex);\n                        ctx.stroke();\n                    }\n                }\n            }\n        };\n    }\n};\n\nexport default Rasterizer;\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/rasterizer.js","/* @preserve ASM BEGIN */\n/* eslint-disable eqeqeq*/\nfunction Skeletonizer(stdlib, foreign, buffer) {\n    \"use asm\";\n\n    var images = new stdlib.Uint8Array(buffer),\n        size = foreign.size | 0,\n        imul = stdlib.Math.imul;\n\n    function erode(inImagePtr, outImagePtr) {\n        inImagePtr = inImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var v = 0,\n            u = 0,\n            sum = 0,\n            yStart1 = 0,\n            yStart2 = 0,\n            xStart1 = 0,\n            xStart2 = 0,\n            offset = 0;\n\n        for ( v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\n            offset = (offset + size) | 0;\n            for ( u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\n                yStart1 = (offset - size) | 0;\n                yStart2 = (offset + size) | 0;\n                xStart1 = (u - 1) | 0;\n                xStart2 = (u + 1) | 0;\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\n                if ((sum | 0) == (5 | 0)) {\n                    images[(outImagePtr + offset + u) | 0] = 1;\n                } else {\n                    images[(outImagePtr + offset + u) | 0] = 0;\n                }\n            }\n        }\n        return;\n    }\n\n    function subtract(aImagePtr, bImagePtr, outImagePtr) {\n        aImagePtr = aImagePtr | 0;\n        bImagePtr = bImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(outImagePtr + length) | 0] =\n                ((images[(aImagePtr + length) | 0] | 0) - (images[(bImagePtr + length) | 0] | 0)) | 0;\n        }\n    }\n\n    function bitwiseOr(aImagePtr, bImagePtr, outImagePtr) {\n        aImagePtr = aImagePtr | 0;\n        bImagePtr = bImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(outImagePtr + length) | 0] =\n                ((images[(aImagePtr + length) | 0] | 0) | (images[(bImagePtr + length) | 0] | 0)) | 0;\n        }\n    }\n\n    function countNonZero(imagePtr) {\n        imagePtr = imagePtr | 0;\n\n        var sum = 0,\n            length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            sum = ((sum | 0) + (images[(imagePtr + length) | 0] | 0)) | 0;\n        }\n\n        return (sum | 0);\n    }\n\n    function init(imagePtr, value) {\n        imagePtr = imagePtr | 0;\n        value = value | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(imagePtr + length) | 0] = value;\n        }\n    }\n\n    function dilate(inImagePtr, outImagePtr) {\n        inImagePtr = inImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var v = 0,\n            u = 0,\n            sum = 0,\n            yStart1 = 0,\n            yStart2 = 0,\n            xStart1 = 0,\n            xStart2 = 0,\n            offset = 0;\n\n        for ( v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\n            offset = (offset + size) | 0;\n            for ( u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\n                yStart1 = (offset - size) | 0;\n                yStart2 = (offset + size) | 0;\n                xStart1 = (u - 1) | 0;\n                xStart2 = (u + 1) | 0;\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\n                if ((sum | 0) > (0 | 0)) {\n                    images[(outImagePtr + offset + u) | 0] = 1;\n                } else {\n                    images[(outImagePtr + offset + u) | 0] = 0;\n                }\n            }\n        }\n        return;\n    }\n\n    function memcpy(srcImagePtr, dstImagePtr) {\n        srcImagePtr = srcImagePtr | 0;\n        dstImagePtr = dstImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(dstImagePtr + length) | 0] = (images[(srcImagePtr + length) | 0] | 0);\n        }\n    }\n\n    function zeroBorder(imagePtr) {\n        imagePtr = imagePtr | 0;\n\n        var x = 0,\n            y = 0;\n\n        for ( x = 0; (x | 0) < ((size - 1) | 0); x = (x + 1) | 0) {\n            images[(imagePtr + x) | 0] = 0;\n            images[(imagePtr + y) | 0] = 0;\n            y = ((y + size) - 1) | 0;\n            images[(imagePtr + y) | 0] = 0;\n            y = (y + 1) | 0;\n        }\n        for ( x = 0; (x | 0) < (size | 0); x = (x + 1) | 0) {\n            images[(imagePtr + y) | 0] = 0;\n            y = (y + 1) | 0;\n        }\n    }\n\n    function skeletonize() {\n        var subImagePtr = 0,\n            erodedImagePtr = 0,\n            tempImagePtr = 0,\n            skelImagePtr = 0,\n            sum = 0,\n            done = 0;\n\n        erodedImagePtr = imul(size, size) | 0;\n        tempImagePtr = (erodedImagePtr + erodedImagePtr) | 0;\n        skelImagePtr = (tempImagePtr + erodedImagePtr) | 0;\n\n        // init skel-image\n        init(skelImagePtr, 0);\n        zeroBorder(subImagePtr);\n\n        do {\n            erode(subImagePtr, erodedImagePtr);\n            dilate(erodedImagePtr, tempImagePtr);\n            subtract(subImagePtr, tempImagePtr, tempImagePtr);\n            bitwiseOr(skelImagePtr, tempImagePtr, skelImagePtr);\n            memcpy(erodedImagePtr, subImagePtr);\n            sum = countNonZero(subImagePtr) | 0;\n            done = ((sum | 0) == 0 | 0);\n        } while (!done);\n    }\n    return {\n        skeletonize: skeletonize\n    };\n}\n/* @preserve ASM END */\nexport default Skeletonizer;\n/* eslint-enable eqeqeq*/\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/skeletonizer.js","import BarcodeReader from './barcode_reader';\n\nfunction CodabarReader() {\n    BarcodeReader.call(this);\n    this._counters = [];\n}\n\nvar properties = {\n    ALPHABETH_STRING: {value: \"0123456789-$:/.+ABCD\"},\n    ALPHABET: {value: [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 45, 36, 58, 47, 46, 43, 65, 66, 67, 68]},\n    CHARACTER_ENCODINGS: {value: [0x003, 0x006, 0x009, 0x060, 0x012, 0x042, 0x021, 0x024, 0x030, 0x048, 0x00c, 0x018,\n        0x045, 0x051, 0x054, 0x015, 0x01A, 0x029, 0x00B, 0x00E]},\n    START_END: {value: [0x01A, 0x029, 0x00B, 0x00E]},\n    MIN_ENCODED_CHARS: {value: 4},\n    MAX_ACCEPTABLE: {value: 2.0},\n    PADDING: {value: 1.5},\n    FORMAT: {value: \"codabar\", writeable: false}\n};\n\nCodabarReader.prototype = Object.create(BarcodeReader.prototype, properties);\nCodabarReader.prototype.constructor = CodabarReader;\n\nCodabarReader.prototype._decode = function() {\n    var self = this,\n        result = [],\n        start,\n        decodedChar,\n        pattern,\n        nextStart,\n        end;\n\n    this._counters = self._fillCounters();\n    start = self._findStart();\n    if (!start) {\n        return null;\n    }\n    nextStart = start.startCounter;\n\n    do {\n        pattern = self._toPattern(nextStart);\n        if (pattern < 0) {\n            return null;\n        }\n        decodedChar = self._patternToChar(pattern);\n        if (decodedChar < 0){\n            return null;\n        }\n        result.push(decodedChar);\n        nextStart += 8;\n        if (result.length > 1 && self._isStartEnd(pattern)) {\n            break;\n        }\n    } while (nextStart < self._counters.length);\n\n    // verify end\n    if ((result.length - 2) < self.MIN_ENCODED_CHARS || !self._isStartEnd(pattern)) {\n        return null;\n    }\n\n    // verify end white space\n    if (!self._verifyWhitespace(start.startCounter, nextStart - 8)){\n        return null;\n    }\n\n    if (!self._validateResult(result, start.startCounter)){\n        return null;\n    }\n\n    nextStart = nextStart > self._counters.length ? self._counters.length : nextStart;\n    end = start.start + self._sumCounters(start.startCounter, nextStart - 8);\n\n    return {\n        code: result.join(\"\"),\n        start: start.start,\n        end: end,\n        startInfo: start,\n        decodedCodes: result\n    };\n};\n\nCodabarReader.prototype._verifyWhitespace = function(startCounter, endCounter) {\n    if ((startCounter - 1 <= 0)\n            || this._counters[startCounter - 1] >= (this._calculatePatternLength(startCounter) / 2.0)) {\n        if ((endCounter + 8 >= this._counters.length)\n                || this._counters[endCounter + 7] >= (this._calculatePatternLength(endCounter) / 2.0)) {\n            return true;\n        }\n    }\n    return false;\n};\n\nCodabarReader.prototype._calculatePatternLength = function(offset) {\n    var i,\n        sum = 0;\n\n    for (i = offset; i < offset + 7; i++) {\n        sum += this._counters[i];\n    }\n\n    return sum;\n};\n\nCodabarReader.prototype._thresholdResultPattern = function(result, startCounter){\n    var self = this,\n        categorization = {\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        kind,\n        cat,\n        i,\n        j,\n        pos = startCounter,\n        pattern;\n\n    for (i = 0; i < result.length; i++){\n        pattern = self._charToPattern(result[i]);\n        for (j = 6; j >= 0; j--) {\n            kind = (j & 1) === 2 ? categorization.bar : categorization.space;\n            cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\n            cat.size += self._counters[pos + j];\n            cat.counts++;\n            pattern >>= 1;\n        }\n        pos += 8;\n    }\n\n    [\"space\", \"bar\"].forEach(function(key) {\n        var newkind = categorization[key];\n        newkind.wide.min =\n            Math.floor((newkind.narrow.size / newkind.narrow.counts + newkind.wide.size / newkind.wide.counts) / 2);\n        newkind.narrow.max = Math.ceil(newkind.wide.min);\n        newkind.wide.max = Math.ceil((newkind.wide.size * self.MAX_ACCEPTABLE + self.PADDING) / newkind.wide.counts);\n    });\n\n    return categorization;\n};\n\nCodabarReader.prototype._charToPattern = function(char) {\n    var self = this,\n        charCode = char.charCodeAt(0),\n        i;\n\n    for (i = 0; i < self.ALPHABET.length; i++) {\n        if (self.ALPHABET[i] === charCode){\n            return self.CHARACTER_ENCODINGS[i];\n        }\n    }\n    return 0x0;\n};\n\nCodabarReader.prototype._validateResult = function(result, startCounter) {\n    var self = this,\n        thresholds = self._thresholdResultPattern(result, startCounter),\n        i,\n        j,\n        kind,\n        cat,\n        size,\n        pos = startCounter,\n        pattern;\n\n    for (i = 0; i < result.length; i++) {\n        pattern = self._charToPattern(result[i]);\n        for (j = 6; j >= 0; j--) {\n            kind = (j & 1) === 0 ? thresholds.bar : thresholds.space;\n            cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\n            size = self._counters[pos + j];\n            if (size < cat.min || size > cat.max) {\n                return false;\n            }\n            pattern >>= 1;\n        }\n        pos += 8;\n    }\n    return true;\n};\n\nCodabarReader.prototype._patternToChar = function(pattern) {\n    var i,\n        self = this;\n\n    for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {\n        if (self.CHARACTER_ENCODINGS[i] === pattern) {\n            return String.fromCharCode(self.ALPHABET[i]);\n        }\n    }\n    return -1;\n};\n\nCodabarReader.prototype._computeAlternatingThreshold = function(offset, end) {\n    var i,\n        min = Number.MAX_VALUE,\n        max = 0,\n        counter;\n\n    for (i = offset; i < end; i += 2){\n        counter = this._counters[i];\n        if (counter > max) {\n            max = counter;\n        }\n        if (counter < min) {\n            min = counter;\n        }\n    }\n\n    return ((min + max) / 2.0) | 0;\n};\n\nCodabarReader.prototype._toPattern = function(offset) {\n    var numCounters = 7,\n        end = offset + numCounters,\n        barThreshold,\n        spaceThreshold,\n        bitmask = 1 << (numCounters - 1),\n        pattern = 0,\n        i,\n        threshold;\n\n    if (end > this._counters.length) {\n        return -1;\n    }\n\n    barThreshold = this._computeAlternatingThreshold(offset, end);\n    spaceThreshold = this._computeAlternatingThreshold(offset + 1, end);\n\n    for (i = 0; i < numCounters; i++){\n        threshold = (i & 1) === 0 ? barThreshold : spaceThreshold;\n        if (this._counters[offset + i] > threshold) {\n            pattern |= bitmask;\n        }\n        bitmask >>= 1;\n    }\n\n    return pattern;\n};\n\nCodabarReader.prototype._isStartEnd = function(pattern) {\n    var i;\n\n    for (i = 0; i < this.START_END.length; i++) {\n        if (this.START_END[i] === pattern) {\n            return true;\n        }\n    }\n    return false;\n};\n\nCodabarReader.prototype._sumCounters = function(start, end) {\n    var i,\n        sum = 0;\n\n    for (i = start; i < end; i++) {\n        sum += this._counters[i];\n    }\n    return sum;\n};\n\nCodabarReader.prototype._findStart = function() {\n    var self = this,\n        i,\n        pattern,\n        start = self._nextUnset(self._row),\n        end;\n\n    for (i = 1; i < this._counters.length; i++) {\n        pattern = self._toPattern(i);\n        if (pattern !== -1 && self._isStartEnd(pattern)) {\n            // TODO: Look for whitespace ahead\n            start += self._sumCounters(0, i);\n            end = start + self._sumCounters(i, i + 8);\n            return {\n                start: start,\n                end: end,\n                startCounter: i,\n                endCounter: i + 8\n            };\n        }\n    }\n};\n\nexport default CodabarReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/codabar_reader.js","import BarcodeReader from './barcode_reader';\n\nfunction Code128Reader() {\n    BarcodeReader.call(this);\n}\n\nvar properties = {\n    CODE_SHIFT: {value: 98},\n    CODE_C: {value: 99},\n    CODE_B: {value: 100},\n    CODE_A: {value: 101},\n    START_CODE_A: {value: 103},\n    START_CODE_B: {value: 104},\n    START_CODE_C: {value: 105},\n    STOP_CODE: {value: 106},\n    CODE_PATTERN: {value: [\n        [2, 1, 2, 2, 2, 2],\n        [2, 2, 2, 1, 2, 2],\n        [2, 2, 2, 2, 2, 1],\n        [1, 2, 1, 2, 2, 3],\n        [1, 2, 1, 3, 2, 2],\n        [1, 3, 1, 2, 2, 2],\n        [1, 2, 2, 2, 1, 3],\n        [1, 2, 2, 3, 1, 2],\n        [1, 3, 2, 2, 1, 2],\n        [2, 2, 1, 2, 1, 3],\n        [2, 2, 1, 3, 1, 2],\n        [2, 3, 1, 2, 1, 2],\n        [1, 1, 2, 2, 3, 2],\n        [1, 2, 2, 1, 3, 2],\n        [1, 2, 2, 2, 3, 1],\n        [1, 1, 3, 2, 2, 2],\n        [1, 2, 3, 1, 2, 2],\n        [1, 2, 3, 2, 2, 1],\n        [2, 2, 3, 2, 1, 1],\n        [2, 2, 1, 1, 3, 2],\n        [2, 2, 1, 2, 3, 1],\n        [2, 1, 3, 2, 1, 2],\n        [2, 2, 3, 1, 1, 2],\n        [3, 1, 2, 1, 3, 1],\n        [3, 1, 1, 2, 2, 2],\n        [3, 2, 1, 1, 2, 2],\n        [3, 2, 1, 2, 2, 1],\n        [3, 1, 2, 2, 1, 2],\n        [3, 2, 2, 1, 1, 2],\n        [3, 2, 2, 2, 1, 1],\n        [2, 1, 2, 1, 2, 3],\n        [2, 1, 2, 3, 2, 1],\n        [2, 3, 2, 1, 2, 1],\n        [1, 1, 1, 3, 2, 3],\n        [1, 3, 1, 1, 2, 3],\n        [1, 3, 1, 3, 2, 1],\n        [1, 1, 2, 3, 1, 3],\n        [1, 3, 2, 1, 1, 3],\n        [1, 3, 2, 3, 1, 1],\n        [2, 1, 1, 3, 1, 3],\n        [2, 3, 1, 1, 1, 3],\n        [2, 3, 1, 3, 1, 1],\n        [1, 1, 2, 1, 3, 3],\n        [1, 1, 2, 3, 3, 1],\n        [1, 3, 2, 1, 3, 1],\n        [1, 1, 3, 1, 2, 3],\n        [1, 1, 3, 3, 2, 1],\n        [1, 3, 3, 1, 2, 1],\n        [3, 1, 3, 1, 2, 1],\n        [2, 1, 1, 3, 3, 1],\n        [2, 3, 1, 1, 3, 1],\n        [2, 1, 3, 1, 1, 3],\n        [2, 1, 3, 3, 1, 1],\n        [2, 1, 3, 1, 3, 1],\n        [3, 1, 1, 1, 2, 3],\n        [3, 1, 1, 3, 2, 1],\n        [3, 3, 1, 1, 2, 1],\n        [3, 1, 2, 1, 1, 3],\n        [3, 1, 2, 3, 1, 1],\n        [3, 3, 2, 1, 1, 1],\n        [3, 1, 4, 1, 1, 1],\n        [2, 2, 1, 4, 1, 1],\n        [4, 3, 1, 1, 1, 1],\n        [1, 1, 1, 2, 2, 4],\n        [1, 1, 1, 4, 2, 2],\n        [1, 2, 1, 1, 2, 4],\n        [1, 2, 1, 4, 2, 1],\n        [1, 4, 1, 1, 2, 2],\n        [1, 4, 1, 2, 2, 1],\n        [1, 1, 2, 2, 1, 4],\n        [1, 1, 2, 4, 1, 2],\n        [1, 2, 2, 1, 1, 4],\n        [1, 2, 2, 4, 1, 1],\n        [1, 4, 2, 1, 1, 2],\n        [1, 4, 2, 2, 1, 1],\n        [2, 4, 1, 2, 1, 1],\n        [2, 2, 1, 1, 1, 4],\n        [4, 1, 3, 1, 1, 1],\n        [2, 4, 1, 1, 1, 2],\n        [1, 3, 4, 1, 1, 1],\n        [1, 1, 1, 2, 4, 2],\n        [1, 2, 1, 1, 4, 2],\n        [1, 2, 1, 2, 4, 1],\n        [1, 1, 4, 2, 1, 2],\n        [1, 2, 4, 1, 1, 2],\n        [1, 2, 4, 2, 1, 1],\n        [4, 1, 1, 2, 1, 2],\n        [4, 2, 1, 1, 1, 2],\n        [4, 2, 1, 2, 1, 1],\n        [2, 1, 2, 1, 4, 1],\n        [2, 1, 4, 1, 2, 1],\n        [4, 1, 2, 1, 2, 1],\n        [1, 1, 1, 1, 4, 3],\n        [1, 1, 1, 3, 4, 1],\n        [1, 3, 1, 1, 4, 1],\n        [1, 1, 4, 1, 1, 3],\n        [1, 1, 4, 3, 1, 1],\n        [4, 1, 1, 1, 1, 3],\n        [4, 1, 1, 3, 1, 1],\n        [1, 1, 3, 1, 4, 1],\n        [1, 1, 4, 1, 3, 1],\n        [3, 1, 1, 1, 4, 1],\n        [4, 1, 1, 1, 3, 1],\n        [2, 1, 1, 4, 1, 2],\n        [2, 1, 1, 2, 1, 4],\n        [2, 1, 1, 2, 3, 2],\n        [2, 3, 3, 1, 1, 1, 2]\n    ]},\n    SINGLE_CODE_ERROR: {value: 0.64},\n    AVG_CODE_ERROR: {value: 0.30},\n    FORMAT: {value: \"code_128\", writeable: false},\n    MODULE_INDICES: {value: {bar: [0, 2, 4], space: [1, 3, 5]}}\n};\n\nCode128Reader.prototype = Object.create(BarcodeReader.prototype, properties);\nCode128Reader.prototype.constructor = Code128Reader;\n\nCode128Reader.prototype._decodeCode = function(start, correction) {\n    var counter = [0, 0, 0, 0, 0, 0],\n        i,\n        self = this,\n        offset = start,\n        isWhite = !self._row[offset],\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: start,\n            end: start,\n            correction: {\n                bar: 1,\n                space: 1\n            }\n        },\n        code,\n        error;\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                if (correction) {\n                    self._correct(counter, correction);\n                }\n                for (code = 0; code < self.CODE_PATTERN.length; code++) {\n                    error = self._matchPattern(counter, self.CODE_PATTERN[code]);\n                    if (error < bestMatch.error) {\n                        bestMatch.code = code;\n                        bestMatch.error = error;\n                    }\n                }\n                bestMatch.end = i;\n                if (bestMatch.code === -1 || bestMatch.error > self.AVG_CODE_ERROR) {\n                    return null;\n                }\n                if (self.CODE_PATTERN[bestMatch.code]) {\n                    bestMatch.correction.bar = calculateCorrection(\n                        self.CODE_PATTERN[bestMatch.code], counter,\n                        this.MODULE_INDICES.bar);\n                    bestMatch.correction.space = calculateCorrection(\n                        self.CODE_PATTERN[bestMatch.code], counter,\n                        this.MODULE_INDICES.space);\n                }\n                return bestMatch;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nCode128Reader.prototype._correct = function(counter, correction) {\n    this._correctBars(counter, correction.bar, this.MODULE_INDICES.bar);\n    this._correctBars(counter, correction.space, this.MODULE_INDICES.space);\n};\n\nCode128Reader.prototype._findStart = function() {\n    var counter = [0, 0, 0, 0, 0, 0],\n        i,\n        self = this,\n        offset = self._nextSet(self._row),\n        isWhite = false,\n        counterPos = 0,\n        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        code,\n        error,\n        j,\n        sum;\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                sum = 0;\n                for ( j = 0; j < counter.length; j++) {\n                    sum += counter[j];\n                }\n                for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) {\n                    error = self._matchPattern(counter, self.CODE_PATTERN[code]);\n                    if (error < bestMatch.error) {\n                        bestMatch.code = code;\n                        bestMatch.error = error;\n                    }\n                }\n                if (bestMatch.error < self.AVG_CODE_ERROR) {\n                    bestMatch.start = i - sum;\n                    bestMatch.end = i;\n                    bestMatch.correction.bar = calculateCorrection(\n                        self.CODE_PATTERN[bestMatch.code], counter,\n                        this.MODULE_INDICES.bar);\n                    bestMatch.correction.space = calculateCorrection(\n                        self.CODE_PATTERN[bestMatch.code], counter,\n                        this.MODULE_INDICES.space);\n                    return bestMatch;\n                }\n\n                for ( j = 0; j < 4; j++) {\n                    counter[j] = counter[j + 2];\n                }\n                counter[4] = 0;\n                counter[5] = 0;\n                counterPos--;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nCode128Reader.prototype._decode = function() {\n    var self = this,\n        startInfo = self._findStart(),\n        code = null,\n        done = false,\n        result = [],\n        multiplier = 0,\n        checksum = 0,\n        codeset,\n        rawResult = [],\n        decodedCodes = [],\n        shiftNext = false,\n        unshift,\n        removeLastCharacter = true;\n\n    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    switch (code.code) {\n    case self.START_CODE_A:\n        codeset = self.CODE_A;\n        break;\n    case self.START_CODE_B:\n        codeset = self.CODE_B;\n        break;\n    case self.START_CODE_C:\n        codeset = self.CODE_C;\n        break;\n    default:\n        return null;\n    }\n\n    while (!done) {\n        unshift = shiftNext;\n        shiftNext = false;\n        code = self._decodeCode(code.end, code.correction);\n        if (code !== null) {\n            if (code.code !== self.STOP_CODE) {\n                removeLastCharacter = true;\n            }\n\n            if (code.code !== self.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 self.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 !== self.STOP_CODE) {\n                        removeLastCharacter = false;\n                    }\n                    switch (code.code) {\n                    case self.CODE_SHIFT:\n                        shiftNext = true;\n                        codeset = self.CODE_B;\n                        break;\n                    case self.CODE_B:\n                        codeset = self.CODE_B;\n                        break;\n                    case self.CODE_C:\n                        codeset = self.CODE_C;\n                        break;\n                    case self.STOP_CODE:\n                        done = true;\n                        break;\n                    }\n                }\n                break;\n            case self.CODE_B:\n                if (code.code < 96) {\n                    result.push(String.fromCharCode(32 + code.code));\n                } else {\n                    if (code.code !== self.STOP_CODE) {\n                        removeLastCharacter = false;\n                    }\n                    switch (code.code) {\n                    case self.CODE_SHIFT:\n                        shiftNext = true;\n                        codeset = self.CODE_A;\n                        break;\n                    case self.CODE_A:\n                        codeset = self.CODE_A;\n                        break;\n                    case self.CODE_C:\n                        codeset = self.CODE_C;\n                        break;\n                    case self.STOP_CODE:\n                        done = true;\n                        break;\n                    }\n                }\n                break;\n            case self.CODE_C:\n                if (code.code < 100) {\n                    result.push(code.code < 10 ? \"0\" + code.code : code.code);\n                } else {\n                    if (code.code !== self.STOP_CODE) {\n                        removeLastCharacter = false;\n                    }\n                    switch (code.code) {\n                    case self.CODE_A:\n                        codeset = self.CODE_A;\n                        break;\n                    case self.CODE_B:\n                        codeset = self.CODE_B;\n                        break;\n                    case self.STOP_CODE:\n                        done = true;\n                        break;\n                    }\n                }\n                break;\n            }\n        } else {\n            done = true;\n        }\n        if (unshift) {\n            codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A;\n        }\n    }\n\n    if (code === null) {\n        return null;\n    }\n\n    code.end = self._nextUnset(self._row, code.end);\n    if (!self._verifyTrailingWhitespace(code)){\n        return null;\n    }\n\n    checksum -= multiplier * rawResult[rawResult.length - 1];\n    if (checksum % 103 !== rawResult[rawResult.length - 1]) {\n        return null;\n    }\n\n    if (!result.length) {\n        return null;\n    }\n\n    // remove last code from result (checksum)\n    if (removeLastCharacter) {\n        result.splice(result.length - 1, 1);\n    }\n\n\n    return {\n        code: result.join(\"\"),\n        start: startInfo.start,\n        end: code.end,\n        codeset: codeset,\n        startInfo: startInfo,\n        decodedCodes: decodedCodes,\n        endInfo: code\n    };\n};\n\n\nBarcodeReader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n    return null;\n};\n\nfunction calculateCorrection(expected, normalized, indices) {\n    var length = indices.length,\n        sumNormalized = 0,\n        sumExpected = 0;\n\n    while(length--) {\n        sumExpected += expected[indices[length]];\n        sumNormalized += normalized[indices[length]];\n    }\n    return sumExpected/sumNormalized;\n}\n\nexport default Code128Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_128_reader.js","import Code39Reader from './code_39_reader';\n\nfunction Code39VINReader() {\n    Code39Reader.call(this);\n}\n\nvar patterns = {\n    IOQ: /[IOQ]/g,\n    AZ09: /[A-Z0-9]{17}/\n};\n\nCode39VINReader.prototype = Object.create(Code39Reader.prototype);\nCode39VINReader.prototype.constructor = Code39VINReader;\n\n// Cribbed from:\n// https://github.com/zxing/zxing/blob/master/core/src/main/java/com/google/zxing/client/result/VINResultParser.java\nCode39VINReader.prototype._decode = function() {\n    var result = Code39Reader.prototype._decode.apply(this);\n    if (!result) {\n        return null;\n    }\n\n    var code = result.code;\n\n    if (!code) {\n        return null;\n    }\n\n    code = code.replace(patterns.IOQ, '');\n\n    if (!code.match(patterns.AZ09)) {\n        if (ENV.development) {\n            console.log('Failed AZ09 pattern code:', code);\n        }\n        return null;\n    }\n\n    if (!this._checkChecksum(code)) {\n        return null;\n    }\n\n    result.code = code;\n    return result;\n};\n\nCode39VINReader.prototype._checkChecksum = function(code) {\n    // TODO\n    return !!code;\n};\n\nexport default Code39VINReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_39_vin_reader.js","import EANReader from './ean_reader';\n\nfunction EAN2Reader() {\n    EANReader.call(this);\n}\n\nvar properties = {\n    FORMAT: {value: \"ean_2\", writeable: false}\n};\n\nEAN2Reader.prototype = Object.create(EANReader.prototype, properties);\nEAN2Reader.prototype.constructor = EAN2Reader;\n\nEAN2Reader.prototype.decode = function(row, start) {\n    this._row = row;\n    var counters = [0, 0, 0, 0],\n        codeFrequency = 0,\n        i = 0,\n        offset = start,\n        end = this._row.length,\n        code,\n        result = [],\n        decodedCodes = [];\n\n    for (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    return {\n        code: result.join(\"\"),\n        decodedCodes,\n        end: code.end\n    };\n};\n\nexport default EAN2Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_2_reader.js","import EANReader from './ean_reader';\n\nfunction EAN5Reader() {\n    EANReader.call(this);\n}\n\nvar properties = {\n    FORMAT: {value: \"ean_5\", writeable: false}\n};\n\nconst CHECK_DIGIT_ENCODINGS = [24, 20, 18, 17, 12, 6, 3, 10, 9, 5];\n\nEAN5Reader.prototype = Object.create(EANReader.prototype, properties);\nEAN5Reader.prototype.constructor = EAN5Reader;\n\nEAN5Reader.prototype.decode = function(row, start) {\n    this._row = row;\n    var counters = [0, 0, 0, 0],\n        codeFrequency = 0,\n        i = 0,\n        offset = start,\n        end = this._row.length,\n        code,\n        result = [],\n        decodedCodes = [];\n\n    for (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 (extensionChecksum(result) !== determineCheckDigit(codeFrequency)) {\n        return null;\n    }\n    return {\n        code: result.join(\"\"),\n        decodedCodes,\n        end: code.end\n    };\n};\n\nfunction determineCheckDigit(codeFrequency) {\n    var i;\n    for (i = 0; i < 10; i++) {\n        if (codeFrequency === CHECK_DIGIT_ENCODINGS[i]) {\n            return i;\n        }\n    }\n    return null;\n}\n\n\nfunction extensionChecksum(result) {\n    var length = result.length,\n        sum = 0,\n        i;\n\n    for (i = length - 2; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    sum *= 3;\n    for (i = length - 1; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    sum *= 3;\n    return sum % 10;\n}\n\nexport default EAN5Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_5_reader.js","import EANReader from './ean_reader';\n\nfunction EAN8Reader(opts, supplements) {\n    EANReader.call(this, opts, supplements);\n}\n\nvar properties = {\n    FORMAT: {value: \"ean_8\", writeable: false}\n};\n\nEAN8Reader.prototype = Object.create(EANReader.prototype, properties);\nEAN8Reader.prototype.constructor = EAN8Reader;\n\nEAN8Reader.prototype._decodePayload = function(code, result, decodedCodes) {\n    var i,\n        self = this;\n\n    for ( i = 0; i < 4; i++) {\n        code = self._decodeCode(code.end, self.CODE_G_START);\n        if (!code) {\n            return null;\n        }\n        result.push(code.code);\n        decodedCodes.push(code);\n    }\n\n    code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);\n    if (code === null) {\n        return null;\n    }\n    decodedCodes.push(code);\n\n    for ( i = 0; i < 4; i++) {\n        code = self._decodeCode(code.end, self.CODE_G_START);\n        if (!code) {\n            return null;\n        }\n        decodedCodes.push(code);\n        result.push(code.code);\n    }\n\n    return code;\n};\n\nexport default EAN8Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_8_reader.js","import BarcodeReader from './barcode_reader';\nimport {merge} from 'lodash';\n\nfunction I2of5Reader(opts) {\n    opts = merge(getDefaulConfig(), opts);\n    BarcodeReader.call(this, opts);\n    this.barSpaceRatio = [1, 1];\n    if (opts.normalizeBarSpaceWidth) {\n        this.SINGLE_CODE_ERROR = 0.38;\n        this.AVG_CODE_ERROR = 0.09;\n    }\n}\n\nfunction getDefaulConfig() {\n    var config = {};\n\n    Object.keys(I2of5Reader.CONFIG_KEYS).forEach(function(key) {\n        config[key] = I2of5Reader.CONFIG_KEYS[key].default;\n    });\n    return config;\n}\n\nvar N = 1,\n    W = 3,\n    properties = {\n        START_PATTERN: {value: [N, N, N, N]},\n        STOP_PATTERN: {value: [N, N, W]},\n        CODE_PATTERN: {value: [\n            [N, N, W, W, N],\n            [W, N, N, N, W],\n            [N, W, N, N, W],\n            [W, W, N, N, N],\n            [N, N, W, N, W],\n            [W, N, W, N, N],\n            [N, W, W, N, N],\n            [N, N, N, W, W],\n            [W, N, N, W, N],\n            [N, W, N, W, N]\n        ]},\n        SINGLE_CODE_ERROR: {value: 0.78, writable: true},\n        AVG_CODE_ERROR: {value: 0.38, writable: true},\n        MAX_CORRECTION_FACTOR: {value: 5},\n        FORMAT: {value: \"i2of5\"}\n    };\n\nI2of5Reader.prototype = Object.create(BarcodeReader.prototype, properties);\nI2of5Reader.prototype.constructor = I2of5Reader;\n\nI2of5Reader.prototype._matchPattern = function(counter, code) {\n    if (this.config.normalizeBarSpaceWidth) {\n        var i,\n            counterSum = [0, 0],\n            codeSum = [0, 0],\n            correction = [0, 0],\n            correctionRatio = this.MAX_CORRECTION_FACTOR,\n            correctionRatioInverse = 1 / correctionRatio;\n\n        for (i = 0; i < counter.length; i++) {\n            counterSum[i % 2] += counter[i];\n            codeSum[i % 2] += code[i];\n        }\n        correction[0] = codeSum[0] / counterSum[0];\n        correction[1] = codeSum[1] / counterSum[1];\n\n        correction[0] = Math.max(Math.min(correction[0], correctionRatio), correctionRatioInverse);\n        correction[1] = Math.max(Math.min(correction[1], correctionRatio), correctionRatioInverse);\n        this.barSpaceRatio = correction;\n        for (i = 0; i < counter.length; i++) {\n            counter[i] *= this.barSpaceRatio[i % 2];\n        }\n    }\n    return BarcodeReader.prototype._matchPattern.call(this, counter, code);\n};\n\nI2of5Reader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder) {\n    var counter = [],\n        self = this,\n        i,\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        },\n        error,\n        j,\n        sum,\n        normalized,\n        epsilon = self.AVG_CODE_ERROR;\n\n    isWhite = isWhite || false;\n    tryHarder = tryHarder || false;\n\n    if (!offset) {\n        offset = self._nextSet(self._row);\n    }\n\n    for ( i = 0; i < pattern.length; i++) {\n        counter[i] = 0;\n    }\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                sum = 0;\n                for ( j = 0; j < counter.length; j++) {\n                    sum += counter[j];\n                }\n                error = self._matchPattern(counter, pattern);\n                if (error < epsilon) {\n                    bestMatch.error = error;\n                    bestMatch.start = i - sum;\n                    bestMatch.end = i;\n                    return bestMatch;\n                }\n                if (tryHarder) {\n                    for (j = 0; j < counter.length - 2; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[counter.length - 2] = 0;\n                    counter[counter.length - 1] = 0;\n                    counterPos--;\n                } else {\n                    return null;\n                }\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nI2of5Reader.prototype._findStart = function() {\n    var self = this,\n        leadingWhitespaceStart,\n        offset = self._nextSet(self._row),\n        startInfo,\n        narrowBarWidth = 1;\n\n    while (!startInfo) {\n        startInfo = self._findPattern(self.START_PATTERN, offset, false, true);\n        if (!startInfo) {\n            return null;\n        }\n        narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / 4);\n        leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10;\n        if (leadingWhitespaceStart >= 0) {\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                return startInfo;\n            }\n        }\n        offset = startInfo.end;\n        startInfo = null;\n    }\n};\n\nI2of5Reader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n    return null;\n};\n\nI2of5Reader.prototype._findEnd = function() {\n    var self = this,\n        endInfo,\n        tmp;\n\n    self._row.reverse();\n    endInfo = self._findPattern(self.STOP_PATTERN);\n    self._row.reverse();\n\n    if (endInfo === null) {\n        return null;\n    }\n\n    // reverse numbers\n    tmp = endInfo.start;\n    endInfo.start = self._row.length - endInfo.end;\n    endInfo.end = self._row.length - tmp;\n\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\n};\n\nI2of5Reader.prototype._decodePair = function(counterPair) {\n    var i,\n        code,\n        codes = [],\n        self = this;\n\n    for (i = 0; i < counterPair.length; i++) {\n        code = self._decodeCode(counterPair[i]);\n        if (!code) {\n            return null;\n        }\n        codes.push(code);\n    }\n    return codes;\n};\n\nI2of5Reader.prototype._decodeCode = function(counter) {\n    var j,\n        self = this,\n        sum = 0,\n        normalized,\n        error,\n        epsilon = self.AVG_CODE_ERROR,\n        code,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        };\n\n    for ( j = 0; j < counter.length; j++) {\n        sum += counter[j];\n    }\n    for (code = 0; code < self.CODE_PATTERN.length; code++) {\n        error = self._matchPattern(counter, self.CODE_PATTERN[code]);\n        if (error < bestMatch.error) {\n            bestMatch.code = code;\n            bestMatch.error = error;\n        }\n    }\n    if (bestMatch.error < epsilon) {\n        return bestMatch;\n    }\n};\n\nI2of5Reader.prototype._decodePayload = function(counters, result, decodedCodes) {\n    var i,\n        self = this,\n        pos = 0,\n        counterLength = counters.length,\n        counterPair = [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0]],\n        codes;\n\n    while (pos < counterLength) {\n        for (i = 0; i < 5; i++) {\n            counterPair[0][i] = counters[pos] * this.barSpaceRatio[0];\n            counterPair[1][i] = counters[pos + 1] * this.barSpaceRatio[1];\n            pos += 2;\n        }\n        codes = self._decodePair(counterPair);\n        if (!codes) {\n            return null;\n        }\n        for (i = 0; i < codes.length; i++) {\n            result.push(codes[i].code + \"\");\n            decodedCodes.push(codes[i]);\n        }\n    }\n    return codes;\n};\n\nI2of5Reader.prototype._verifyCounterLength = function(counters) {\n    return (counters.length % 10 === 0);\n};\n\nI2of5Reader.prototype._decode = function() {\n    var startInfo,\n        endInfo,\n        self = this,\n        code,\n        result = [],\n        decodedCodes = [],\n        counters;\n\n    startInfo = self._findStart();\n    if (!startInfo) {\n        return null;\n    }\n    decodedCodes.push(startInfo);\n\n    endInfo = self._findEnd();\n    if (!endInfo) {\n        return null;\n    }\n\n    counters = self._fillCounters(startInfo.end, endInfo.start, false);\n    if (!self._verifyCounterLength(counters)) {\n        return null;\n    }\n    code = self._decodePayload(counters, result, decodedCodes);\n    if (!code) {\n        return null;\n    }\n    if (result.length % 2 !== 0 ||\n            result.length < 6) {\n        return null;\n    }\n\n    decodedCodes.push(endInfo);\n    return {\n        code: result.join(\"\"),\n        start: startInfo.start,\n        end: endInfo.end,\n        startInfo: startInfo,\n        decodedCodes: decodedCodes\n    };\n};\n\nI2of5Reader.CONFIG_KEYS = {\n    normalizeBarSpaceWidth: {\n        'type': 'boolean',\n        'default': false,\n        'description': 'If true, the reader tries to normalize the' +\n        'width-difference between bars and spaces'\n    }\n};\n\nexport default I2of5Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/i2of5_reader.js","import EANReader from './ean_reader';\n\nfunction UPCEReader(opts, supplements) {\n    EANReader.call(this, opts, supplements);\n}\n\nvar properties = {\n    CODE_FREQUENCY: {value: [\n        [ 56, 52, 50, 49, 44, 38, 35, 42, 41, 37 ],\n        [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]]},\n    STOP_PATTERN: { value: [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7]},\n    FORMAT: {value: \"upc_e\", writeable: false}\n};\n\nUPCEReader.prototype = Object.create(EANReader.prototype, properties);\nUPCEReader.prototype.constructor = UPCEReader;\n\nUPCEReader.prototype._decodePayload = function(code, result, decodedCodes) {\n    var i,\n        self = this,\n        codeFrequency = 0x0;\n\n    for ( i = 0; i < 6; i++) {\n        code = self._decodeCode(code.end);\n        if (!code) {\n            return null;\n        }\n        if (code.code >= self.CODE_G_START) {\n            code.code = code.code - self.CODE_G_START;\n            codeFrequency |= 1 << (5 - i);\n        }\n        result.push(code.code);\n        decodedCodes.push(code);\n    }\n    if (!self._determineParity(codeFrequency, result)) {\n        return null;\n    }\n\n    return code;\n};\n\nUPCEReader.prototype._determineParity = function(codeFrequency, result) {\n    var i,\n        nrSystem;\n\n    for (nrSystem = 0; nrSystem < this.CODE_FREQUENCY.length; nrSystem++){\n        for ( i = 0; i < this.CODE_FREQUENCY[nrSystem].length; i++) {\n            if (codeFrequency === this.CODE_FREQUENCY[nrSystem][i]) {\n                result.unshift(nrSystem);\n                result.push(i);\n                return true;\n            }\n        }\n    }\n    return false;\n};\n\nUPCEReader.prototype._convertToUPCA = function(result) {\n    var upca = [result[0]],\n        lastDigit = result[result.length - 2];\n\n    if (lastDigit <= 2) {\n        upca = upca.concat(result.slice(1, 3))\n            .concat([lastDigit, 0, 0, 0, 0])\n            .concat(result.slice(3, 6));\n    } else if (lastDigit === 3) {\n        upca = upca.concat(result.slice(1, 4))\n            .concat([0, 0, 0, 0, 0])\n            .concat(result.slice(4, 6));\n    } else if (lastDigit === 4) {\n        upca = upca.concat(result.slice(1, 5))\n            .concat([0, 0, 0, 0, 0, result[5]]);\n    } else {\n        upca = upca.concat(result.slice(1, 6))\n            .concat([0, 0, 0, 0, lastDigit]);\n    }\n\n    upca.push(result[result.length - 1]);\n    return upca;\n};\n\nUPCEReader.prototype._checksum = function(result) {\n    return EANReader.prototype._checksum.call(this, this._convertToUPCA(result));\n};\n\nUPCEReader.prototype._findEnd = function(offset, isWhite) {\n    isWhite = true;\n    return EANReader.prototype._findEnd.call(this, offset, isWhite);\n};\n\nUPCEReader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n};\n\nexport default UPCEReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/upc_e_reader.js","import EANReader from './ean_reader';\n\nfunction UPCReader(opts, supplements) {\n    EANReader.call(this, opts, supplements);\n}\n\nvar properties = {\n    FORMAT: {value: \"upc_a\", writeable: false}\n};\n\nUPCReader.prototype = Object.create(EANReader.prototype, properties);\nUPCReader.prototype.constructor = UPCReader;\n\nUPCReader.prototype._decode = function() {\n    var result = EANReader.prototype._decode.call(this);\n\n    if (result && result.code && result.code.length === 13 && result.code.charAt(0) === \"0\") {\n        result.code = result.code.substring(1);\n        return result;\n    }\n    return null;\n};\n\nexport default UPCReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/upc_reader.js","module.exports = copy\n\n/**\n * Copy the values from one mat2 to another\n *\n * @alias mat2.copy\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nfunction copy(out, a) {\n  out[0] = a[0]\n  out[1] = a[1]\n  out[2] = a[2]\n  out[3] = a[3]\n  return out\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/copy.js\n// module id = 74\n// module chunks = 0","module.exports = create\n\n/**\n * Creates a new identity mat2\n *\n * @alias mat2.create\n * @returns {mat2} a new 2x2 matrix\n */\nfunction create() {\n  var out = new Float32Array(4)\n  out[0] = 1\n  out[1] = 0\n  out[2] = 0\n  out[3] = 1\n  return out\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/create.js\n// module id = 75\n// module chunks = 0","module.exports = invert\n\n/**\n * Inverts a mat2\n *\n * @alias mat2.invert\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nfunction invert(out, a) {\n  var a0 = a[0]\n  var a1 = a[1]\n  var a2 = a[2]\n  var a3 = a[3]\n  var det = a0 * a3 - a2 * a1\n\n  if (!det) return null\n  det = 1.0 / det\n\n  out[0] =  a3 * det\n  out[1] = -a1 * det\n  out[2] = -a2 * det\n  out[3] =  a0 * det\n\n  return out\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/invert.js\n// module id = 76\n// module chunks = 0","module.exports = scale\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nfunction scale(out, a, b) {\n    out[0] = a[0] * b\n    out[1] = a[1] * b\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/scale.js\n// module id = 77\n// module chunks = 0","module.exports = transformMat2\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat2(out, a, m) {\n    var x = a[0],\n        y = a[1]\n    out[0] = m[0] * x + m[2] * y\n    out[1] = m[1] * x + m[3] * y\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/transformMat2.js\n// module id = 78\n// module chunks = 0","module.exports = clone;\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {vec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nfunction clone(a) {\n    var out = new Float32Array(3)\n    out[0] = a[0]\n    out[1] = a[1]\n    out[2] = a[2]\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec3/clone.js\n// module id = 79\n// module chunks = 0","var hashClear = require('./_hashClear'),\n    hashDelete = require('./_hashDelete'),\n    hashGet = require('./_hashGet'),\n    hashHas = require('./_hashHas'),\n    hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Hash.js\n// module id = 80\n// module chunks = 0","var ListCache = require('./_ListCache'),\n    stackClear = require('./_stackClear'),\n    stackDelete = require('./_stackDelete'),\n    stackGet = require('./_stackGet'),\n    stackHas = require('./_stackHas'),\n    stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n  var data = this.__data__ = new ListCache(entries);\n  this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Stack.js\n// module id = 81\n// module chunks = 0","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Uint8Array.js\n// module id = 82\n// module chunks = 0","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n  switch (args.length) {\n    case 0: return func.call(thisArg);\n    case 1: return func.call(thisArg, args[0]);\n    case 2: return func.call(thisArg, args[0], args[1]);\n    case 3: return func.call(thisArg, args[0], args[1], args[2]);\n  }\n  return func.apply(thisArg, args);\n}\n\nmodule.exports = apply;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_apply.js\n// module id = 83\n// module chunks = 0","var baseTimes = require('./_baseTimes'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isBuffer = require('./isBuffer'),\n    isIndex = require('./_isIndex'),\n    isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n  var isArr = isArray(value),\n      isArg = !isArr && isArguments(value),\n      isBuff = !isArr && !isArg && isBuffer(value),\n      isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n      skipIndexes = isArr || isArg || isBuff || isType,\n      result = skipIndexes ? baseTimes(value.length, String) : [],\n      length = result.length;\n\n  for (var key in value) {\n    if ((inherited || hasOwnProperty.call(value, key)) &&\n        !(skipIndexes && (\n           // Safari 9 has enumerable `arguments.length` in strict mode.\n           key == 'length' ||\n           // Node.js 0.10 has enumerable non-index properties on buffers.\n           (isBuff && (key == 'offset' || key == 'parent')) ||\n           // PhantomJS 2 has enumerable non-index properties on typed arrays.\n           (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n           // Skip index properties.\n           isIndex(key, length)\n        ))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = arrayLikeKeys;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayLikeKeys.js\n// module id = 84\n// module chunks = 0","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n  var index = -1,\n      length = array == null ? 0 : array.length,\n      result = Array(length);\n\n  while (++index < length) {\n    result[index] = iteratee(array[index], index, array);\n  }\n  return result;\n}\n\nmodule.exports = arrayMap;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayMap.js\n// module id = 85\n// module chunks = 0","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n  var index = -1,\n      length = values.length,\n      offset = array.length;\n\n  while (++index < length) {\n    array[offset + index] = values[index];\n  }\n  return array;\n}\n\nmodule.exports = arrayPush;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayPush.js\n// module id = 86\n// module chunks = 0","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n  function object() {}\n  return function(proto) {\n    if (!isObject(proto)) {\n      return {};\n    }\n    if (objectCreate) {\n      return objectCreate(proto);\n    }\n    object.prototype = proto;\n    var result = new object;\n    object.prototype = undefined;\n    return result;\n  };\n}());\n\nmodule.exports = baseCreate;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseCreate.js\n// module id = 87\n// module chunks = 0","var arrayPush = require('./_arrayPush'),\n    isFlattenable = require('./_isFlattenable');\n\n/**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, predicate, isStrict, result) {\n  var index = -1,\n      length = array.length;\n\n  predicate || (predicate = isFlattenable);\n  result || (result = []);\n\n  while (++index < length) {\n    var value = array[index];\n    if (depth > 0 && predicate(value)) {\n      if (depth > 1) {\n        // Recursively flatten arrays (susceptible to call stack limits).\n        baseFlatten(value, depth - 1, predicate, isStrict, result);\n      } else {\n        arrayPush(result, value);\n      }\n    } else if (!isStrict) {\n      result[result.length] = value;\n    }\n  }\n  return result;\n}\n\nmodule.exports = baseFlatten;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseFlatten.js\n// module id = 88\n// module chunks = 0","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseFor.js\n// module id = 89\n// module chunks = 0","var castPath = require('./_castPath'),\n    toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n  path = castPath(path, object);\n\n  var index = 0,\n      length = path.length;\n\n  while (object != null && index < length) {\n    object = object[toKey(path[index++])];\n  }\n  return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseGet.js\n// module id = 90\n// module chunks = 0","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n  return object != null && key in Object(object);\n}\n\nmodule.exports = baseHasIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseHasIn.js\n// module id = 91\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n  return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsArguments.js\n// module id = 92\n// module chunks = 0","var isFunction = require('./isFunction'),\n    isMasked = require('./_isMasked'),\n    isObject = require('./isObject'),\n    toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n *  else `false`.\n */\nfunction baseIsNative(value) {\n  if (!isObject(value) || isMasked(value)) {\n    return false;\n  }\n  var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n  return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsNative.js\n// module id = 93\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    isLength = require('./isLength'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsTypedArray.js\n// module id = 94\n// module chunks = 0","var isObject = require('./isObject'),\n    isPrototype = require('./_isPrototype'),\n    nativeKeysIn = require('./_nativeKeysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n  if (!isObject(object)) {\n    return nativeKeysIn(object);\n  }\n  var isProto = isPrototype(object),\n      result = [];\n\n  for (var key in object) {\n    if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = baseKeysIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseKeysIn.js\n// module id = 95\n// module chunks = 0","var Stack = require('./_Stack'),\n    assignMergeValue = require('./_assignMergeValue'),\n    baseFor = require('./_baseFor'),\n    baseMergeDeep = require('./_baseMergeDeep'),\n    isObject = require('./isObject'),\n    keysIn = require('./keysIn');\n\n/**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n  if (object === source) {\n    return;\n  }\n  baseFor(source, function(srcValue, key) {\n    if (isObject(srcValue)) {\n      stack || (stack = new Stack);\n      baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n    }\n    else {\n      var newValue = customizer\n        ? customizer(object[key], srcValue, (key + ''), object, source, stack)\n        : undefined;\n\n      if (newValue === undefined) {\n        newValue = srcValue;\n      }\n      assignMergeValue(object, key, newValue);\n    }\n  }, keysIn);\n}\n\nmodule.exports = baseMerge;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseMerge.js\n// module id = 96\n// module chunks = 0","var assignMergeValue = require('./_assignMergeValue'),\n    cloneBuffer = require('./_cloneBuffer'),\n    cloneTypedArray = require('./_cloneTypedArray'),\n    copyArray = require('./_copyArray'),\n    initCloneObject = require('./_initCloneObject'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isArrayLikeObject = require('./isArrayLikeObject'),\n    isBuffer = require('./isBuffer'),\n    isFunction = require('./isFunction'),\n    isObject = require('./isObject'),\n    isPlainObject = require('./isPlainObject'),\n    isTypedArray = require('./isTypedArray'),\n    toPlainObject = require('./toPlainObject');\n\n/**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n  var objValue = object[key],\n      srcValue = source[key],\n      stacked = stack.get(srcValue);\n\n  if (stacked) {\n    assignMergeValue(object, key, stacked);\n    return;\n  }\n  var newValue = customizer\n    ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n    : undefined;\n\n  var isCommon = newValue === undefined;\n\n  if (isCommon) {\n    var isArr = isArray(srcValue),\n        isBuff = !isArr && isBuffer(srcValue),\n        isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n    newValue = srcValue;\n    if (isArr || isBuff || isTyped) {\n      if (isArray(objValue)) {\n        newValue = objValue;\n      }\n      else if (isArrayLikeObject(objValue)) {\n        newValue = copyArray(objValue);\n      }\n      else if (isBuff) {\n        isCommon = false;\n        newValue = cloneBuffer(srcValue, true);\n      }\n      else if (isTyped) {\n        isCommon = false;\n        newValue = cloneTypedArray(srcValue, true);\n      }\n      else {\n        newValue = [];\n      }\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      newValue = objValue;\n      if (isArguments(objValue)) {\n        newValue = toPlainObject(objValue);\n      }\n      else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) {\n        newValue = initCloneObject(srcValue);\n      }\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    stack.set(srcValue, newValue);\n    mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n    stack['delete'](srcValue);\n  }\n  assignMergeValue(object, key, newValue);\n}\n\nmodule.exports = baseMergeDeep;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseMergeDeep.js\n// module id = 97\n// module chunks = 0","var basePickBy = require('./_basePickBy'),\n    hasIn = require('./hasIn');\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, paths) {\n  return basePickBy(object, paths, function(value, path) {\n    return hasIn(object, path);\n  });\n}\n\nmodule.exports = basePick;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_basePick.js\n// module id = 98\n// module chunks = 0","var baseGet = require('./_baseGet'),\n    baseSet = require('./_baseSet'),\n    castPath = require('./_castPath');\n\n/**\n * The base implementation of  `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\nfunction basePickBy(object, paths, predicate) {\n  var index = -1,\n      length = paths.length,\n      result = {};\n\n  while (++index < length) {\n    var path = paths[index],\n        value = baseGet(object, path);\n\n    if (predicate(value, path)) {\n      baseSet(result, castPath(path, object), value);\n    }\n  }\n  return result;\n}\n\nmodule.exports = basePickBy;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_basePickBy.js\n// module id = 99\n// module chunks = 0","var identity = require('./identity'),\n    overRest = require('./_overRest'),\n    setToString = require('./_setToString');\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n  return setToString(overRest(func, start, identity), func + '');\n}\n\nmodule.exports = baseRest;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseRest.js\n// module id = 100\n// module chunks = 0","var assignValue = require('./_assignValue'),\n    castPath = require('./_castPath'),\n    isIndex = require('./_isIndex'),\n    isObject = require('./isObject'),\n    toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n  if (!isObject(object)) {\n    return object;\n  }\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length,\n      lastIndex = length - 1,\n      nested = object;\n\n  while (nested != null && ++index < length) {\n    var key = toKey(path[index]),\n        newValue = value;\n\n    if (index != lastIndex) {\n      var objValue = nested[key];\n      newValue = customizer ? customizer(objValue, key, nested) : undefined;\n      if (newValue === undefined) {\n        newValue = isObject(objValue)\n          ? objValue\n          : (isIndex(path[index + 1]) ? [] : {});\n      }\n    }\n    assignValue(nested, key, newValue);\n    nested = nested[key];\n  }\n  return object;\n}\n\nmodule.exports = baseSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseSet.js\n// module id = 101\n// module chunks = 0","var constant = require('./constant'),\n    defineProperty = require('./_defineProperty'),\n    identity = require('./identity');\n\n/**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar baseSetToString = !defineProperty ? identity : function(func, string) {\n  return defineProperty(func, 'toString', {\n    'configurable': true,\n    'enumerable': false,\n    'value': constant(string),\n    'writable': true\n  });\n};\n\nmodule.exports = baseSetToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseSetToString.js\n// module id = 102\n// module chunks = 0","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n  var index = -1,\n      result = Array(n);\n\n  while (++index < n) {\n    result[index] = iteratee(index);\n  }\n  return result;\n}\n\nmodule.exports = baseTimes;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseTimes.js\n// module id = 103\n// module chunks = 0","var Symbol = require('./_Symbol'),\n    arrayMap = require('./_arrayMap'),\n    isArray = require('./isArray'),\n    isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n  // Exit early for strings to avoid a performance hit in some environments.\n  if (typeof value == 'string') {\n    return value;\n  }\n  if (isArray(value)) {\n    // Recursively convert values (susceptible to call stack limits).\n    return arrayMap(value, baseToString) + '';\n  }\n  if (isSymbol(value)) {\n    return symbolToString ? symbolToString.call(value) : '';\n  }\n  var result = (value + '');\n  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseToString.js\n// module id = 104\n// module chunks = 0","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n  return function(value) {\n    return func(value);\n  };\n}\n\nmodule.exports = baseUnary;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseUnary.js\n// module id = 105\n// module chunks = 0","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n  new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n  return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneArrayBuffer.js\n// module id = 106\n// module chunks = 0","var root = require('./_root');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n    allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of  `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n  if (isDeep) {\n    return buffer.slice();\n  }\n  var length = buffer.length,\n      result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n  buffer.copy(result);\n  return result;\n}\n\nmodule.exports = cloneBuffer;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneBuffer.js\n// module id = 107\n// module chunks = 0","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneTypedArray.js\n// module id = 108\n// module chunks = 0","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n  var index = -1,\n      length = source.length;\n\n  array || (array = Array(length));\n  while (++index < length) {\n    array[index] = source[index];\n  }\n  return array;\n}\n\nmodule.exports = copyArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_copyArray.js\n// module id = 109\n// module chunks = 0","var assignValue = require('./_assignValue'),\n    baseAssignValue = require('./_baseAssignValue');\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n  var isNew = !object;\n  object || (object = {});\n\n  var index = -1,\n      length = props.length;\n\n  while (++index < length) {\n    var key = props[index];\n\n    var newValue = customizer\n      ? customizer(object[key], source[key], key, object, source)\n      : undefined;\n\n    if (newValue === undefined) {\n      newValue = source[key];\n    }\n    if (isNew) {\n      baseAssignValue(object, key, newValue);\n    } else {\n      assignValue(object, key, newValue);\n    }\n  }\n  return object;\n}\n\nmodule.exports = copyObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_copyObject.js\n// module id = 110\n// module chunks = 0","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_coreJsData.js\n// module id = 111\n// module chunks = 0","var baseRest = require('./_baseRest'),\n    isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\nfunction createAssigner(assigner) {\n  return baseRest(function(object, sources) {\n    var index = -1,\n        length = sources.length,\n        customizer = length > 1 ? sources[length - 1] : undefined,\n        guard = length > 2 ? sources[2] : undefined;\n\n    customizer = (assigner.length > 3 && typeof customizer == 'function')\n      ? (length--, customizer)\n      : undefined;\n\n    if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n      customizer = length < 3 ? undefined : customizer;\n      length = 1;\n    }\n    object = Object(object);\n    while (++index < length) {\n      var source = sources[index];\n      if (source) {\n        assigner(object, source, index, customizer);\n      }\n    }\n    return object;\n  });\n}\n\nmodule.exports = createAssigner;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_createAssigner.js\n// module id = 112\n// module chunks = 0","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n  return function(object, iteratee, keysFunc) {\n    var index = -1,\n        iterable = Object(object),\n        props = keysFunc(object),\n        length = props.length;\n\n    while (length--) {\n      var key = props[fromRight ? length : ++index];\n      if (iteratee(iterable[key], key, iterable) === false) {\n        break;\n      }\n    }\n    return object;\n  };\n}\n\nmodule.exports = createBaseFor;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_createBaseFor.js\n// module id = 113\n// module chunks = 0","var flatten = require('./flatten'),\n    overRest = require('./_overRest'),\n    setToString = require('./_setToString');\n\n/**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\nfunction flatRest(func) {\n  return setToString(overRest(func, undefined, flatten), func + '');\n}\n\nmodule.exports = flatRest;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_flatRest.js\n// module id = 114\n// module chunks = 0","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n  var isOwn = hasOwnProperty.call(value, symToStringTag),\n      tag = value[symToStringTag];\n\n  try {\n    value[symToStringTag] = undefined;\n    var unmasked = true;\n  } catch (e) {}\n\n  var result = nativeObjectToString.call(value);\n  if (unmasked) {\n    if (isOwn) {\n      value[symToStringTag] = tag;\n    } else {\n      delete value[symToStringTag];\n    }\n  }\n  return result;\n}\n\nmodule.exports = getRawTag;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getRawTag.js\n// module id = 115\n// module chunks = 0","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getValue.js\n// module id = 116\n// module chunks = 0","var castPath = require('./_castPath'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isIndex = require('./_isIndex'),\n    isLength = require('./isLength'),\n    toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length,\n      result = false;\n\n  while (++index < length) {\n    var key = toKey(path[index]);\n    if (!(result = object != null && hasFunc(object, key))) {\n      break;\n    }\n    object = object[key];\n  }\n  if (result || ++index != length) {\n    return result;\n  }\n  length = object == null ? 0 : object.length;\n  return !!length && isLength(length) && isIndex(key, length) &&\n    (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hasPath.js\n// module id = 117\n// module chunks = 0","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n  this.__data__ = nativeCreate ? nativeCreate(null) : {};\n  this.size = 0;\n}\n\nmodule.exports = hashClear;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashClear.js\n// module id = 118\n// module chunks = 0","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n  var result = this.has(key) && delete this.__data__[key];\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nmodule.exports = hashDelete;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashDelete.js\n// module id = 119\n// module chunks = 0","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n  var data = this.__data__;\n  if (nativeCreate) {\n    var result = data[key];\n    return result === HASH_UNDEFINED ? undefined : result;\n  }\n  return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashGet.js\n// module id = 120\n// module chunks = 0","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n  var data = this.__data__;\n  return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashHas.js\n// module id = 121\n// module chunks = 0","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n  var data = this.__data__;\n  this.size += this.has(key) ? 0 : 1;\n  data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n  return this;\n}\n\nmodule.exports = hashSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashSet.js\n// module id = 122\n// module chunks = 0","var baseCreate = require('./_baseCreate'),\n    getPrototype = require('./_getPrototype'),\n    isPrototype = require('./_isPrototype');\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n  return (typeof object.constructor == 'function' && !isPrototype(object))\n    ? baseCreate(getPrototype(object))\n    : {};\n}\n\nmodule.exports = initCloneObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_initCloneObject.js\n// module id = 123\n// module chunks = 0","var Symbol = require('./_Symbol'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray');\n\n/** Built-in value references. */\nvar spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;\n\n/**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\nfunction isFlattenable(value) {\n  return isArray(value) || isArguments(value) ||\n    !!(spreadableSymbol && value && value[spreadableSymbol]);\n}\n\nmodule.exports = isFlattenable;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isFlattenable.js\n// module id = 124\n// module chunks = 0","var eq = require('./eq'),\n    isArrayLike = require('./isArrayLike'),\n    isIndex = require('./_isIndex'),\n    isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n *  else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n  if (!isObject(object)) {\n    return false;\n  }\n  var type = typeof index;\n  if (type == 'number'\n        ? (isArrayLike(object) && isIndex(index, object.length))\n        : (type == 'string' && index in object)\n      ) {\n    return eq(object[index], value);\n  }\n  return false;\n}\n\nmodule.exports = isIterateeCall;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isIterateeCall.js\n// module id = 125\n// module chunks = 0","var isArray = require('./isArray'),\n    isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n    reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n  if (isArray(value)) {\n    return false;\n  }\n  var type = typeof value;\n  if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n      value == null || isSymbol(value)) {\n    return true;\n  }\n  return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n    (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isKey.js\n// module id = 126\n// module chunks = 0","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n  var type = typeof value;\n  return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n    ? (value !== '__proto__')\n    : (value === null);\n}\n\nmodule.exports = isKeyable;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isKeyable.js\n// module id = 127\n// module chunks = 0","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n  return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isMasked.js\n// module id = 128\n// module chunks = 0","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n  this.__data__ = [];\n  this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheClear.js\n// module id = 129\n// module chunks = 0","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    return false;\n  }\n  var lastIndex = data.length - 1;\n  if (index == lastIndex) {\n    data.pop();\n  } else {\n    splice.call(data, index, 1);\n  }\n  --this.size;\n  return true;\n}\n\nmodule.exports = listCacheDelete;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheDelete.js\n// module id = 130\n// module chunks = 0","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheGet.js\n// module id = 131\n// module chunks = 0","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n  return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheHas.js\n// module id = 132\n// module chunks = 0","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    ++this.size;\n    data.push([key, value]);\n  } else {\n    data[index][1] = value;\n  }\n  return this;\n}\n\nmodule.exports = listCacheSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheSet.js\n// module id = 133\n// module chunks = 0","var Hash = require('./_Hash'),\n    ListCache = require('./_ListCache'),\n    Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n  this.size = 0;\n  this.__data__ = {\n    'hash': new Hash,\n    'map': new (Map || ListCache),\n    'string': new Hash\n  };\n}\n\nmodule.exports = mapCacheClear;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheClear.js\n// module id = 134\n// module chunks = 0","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n  var result = getMapData(this, key)['delete'](key);\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nmodule.exports = mapCacheDelete;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheDelete.js\n// module id = 135\n// module chunks = 0","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n  return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheGet.js\n// module id = 136\n// module chunks = 0","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n  return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheHas.js\n// module id = 137\n// module chunks = 0","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n  var data = getMapData(this, key),\n      size = data.size;\n\n  data.set(key, value);\n  this.size += data.size == size ? 0 : 1;\n  return this;\n}\n\nmodule.exports = mapCacheSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheSet.js\n// module id = 138\n// module chunks = 0","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n  var result = memoize(func, function(key) {\n    if (cache.size === MAX_MEMOIZE_SIZE) {\n      cache.clear();\n    }\n    return key;\n  });\n\n  var cache = result.cache;\n  return result;\n}\n\nmodule.exports = memoizeCapped;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_memoizeCapped.js\n// module id = 139\n// module chunks = 0","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n  var result = [];\n  if (object != null) {\n    for (var key in Object(object)) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = nativeKeysIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nativeKeysIn.js\n// module id = 140\n// module chunks = 0","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n  try {\n    return freeProcess && freeProcess.binding && freeProcess.binding('util');\n  } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nodeUtil.js\n// module id = 141\n// module chunks = 0","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n  return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_objectToString.js\n// module id = 142\n// module chunks = 0","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\n}\n\nmodule.exports = overArg;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_overArg.js\n// module id = 143\n// module chunks = 0","/** Used to detect hot functions by number of calls within a span of milliseconds. */\nvar HOT_COUNT = 800,\n    HOT_SPAN = 16;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeNow = Date.now;\n\n/**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\nfunction shortOut(func) {\n  var count = 0,\n      lastCalled = 0;\n\n  return function() {\n    var stamp = nativeNow(),\n        remaining = HOT_SPAN - (stamp - lastCalled);\n\n    lastCalled = stamp;\n    if (remaining > 0) {\n      if (++count >= HOT_COUNT) {\n        return arguments[0];\n      }\n    } else {\n      count = 0;\n    }\n    return func.apply(undefined, arguments);\n  };\n}\n\nmodule.exports = shortOut;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_shortOut.js\n// module id = 144\n// module chunks = 0","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n  this.__data__ = new ListCache;\n  this.size = 0;\n}\n\nmodule.exports = stackClear;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackClear.js\n// module id = 145\n// module chunks = 0","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n  var data = this.__data__,\n      result = data['delete'](key);\n\n  this.size = data.size;\n  return result;\n}\n\nmodule.exports = stackDelete;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackDelete.js\n// module id = 146\n// module chunks = 0","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n  return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackGet.js\n// module id = 147\n// module chunks = 0","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n  return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackHas.js\n// module id = 148\n// module chunks = 0","var ListCache = require('./_ListCache'),\n    Map = require('./_Map'),\n    MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n  var data = this.__data__;\n  if (data instanceof ListCache) {\n    var pairs = data.__data__;\n    if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n      pairs.push([key, value]);\n      this.size = ++data.size;\n      return this;\n    }\n    data = this.__data__ = new MapCache(pairs);\n  }\n  data.set(key, value);\n  this.size = data.size;\n  return this;\n}\n\nmodule.exports = stackSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackSet.js\n// module id = 149\n// module chunks = 0","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar reLeadingDot = /^\\./,\n    rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n  var result = [];\n  if (reLeadingDot.test(string)) {\n    result.push('');\n  }\n  string.replace(rePropName, function(match, number, quote, string) {\n    result.push(quote ? string.replace(reEscapeChar, '$1') : (number || match));\n  });\n  return result;\n});\n\nmodule.exports = stringToPath;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stringToPath.js\n// module id = 150\n// module chunks = 0","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n  if (func != null) {\n    try {\n      return funcToString.call(func);\n    } catch (e) {}\n    try {\n      return (func + '');\n    } catch (e) {}\n  }\n  return '';\n}\n\nmodule.exports = toSource;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_toSource.js\n// module id = 151\n// module chunks = 0","/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\nfunction constant(value) {\n  return function() {\n    return value;\n  };\n}\n\nmodule.exports = constant;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/constant.js\n// module id = 152\n// module chunks = 0","var baseFlatten = require('./_baseFlatten');\n\n/**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\nfunction flatten(array) {\n  var length = array == null ? 0 : array.length;\n  return length ? baseFlatten(array, 1) : [];\n}\n\nmodule.exports = flatten;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/flatten.js\n// module id = 153\n// module chunks = 0","var baseHasIn = require('./_baseHasIn'),\n    hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n  return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/hasIn.js\n// module id = 154\n// module chunks = 0","var isArrayLike = require('./isArrayLike'),\n    isObjectLike = require('./isObjectLike');\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n *  else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\n}\n\nmodule.exports = isArrayLikeObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArrayLikeObject.js\n// module id = 155\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    getPrototype = require('./_getPrototype'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n  if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n    return false;\n  }\n  var proto = getPrototype(value);\n  if (proto === null) {\n    return true;\n  }\n  var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n  return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n    funcToString.call(Ctor) == objectCtorString;\n}\n\nmodule.exports = isPlainObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isPlainObject.js\n// module id = 156\n// module chunks = 0","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n  if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  var memoized = function() {\n    var args = arguments,\n        key = resolver ? resolver.apply(this, args) : args[0],\n        cache = memoized.cache;\n\n    if (cache.has(key)) {\n      return cache.get(key);\n    }\n    var result = func.apply(this, args);\n    memoized.cache = cache.set(key, result) || cache;\n    return result;\n  };\n  memoized.cache = new (memoize.Cache || MapCache);\n  return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/memoize.js\n// module id = 157\n// module chunks = 0","var basePick = require('./_basePick'),\n    flatRest = require('./_flatRest');\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\nvar pick = flatRest(function(object, paths) {\n  return object == null ? {} : basePick(object, paths);\n});\n\nmodule.exports = pick;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/pick.js\n// module id = 158\n// module chunks = 0","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n  return false;\n}\n\nmodule.exports = stubFalse;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/stubFalse.js\n// module id = 159\n// module chunks = 0","var copyObject = require('./_copyObject'),\n    keysIn = require('./keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\nfunction toPlainObject(value) {\n  return copyObject(value, keysIn(value));\n}\n\nmodule.exports = toPlainObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/toPlainObject.js\n// module id = 160\n// module chunks = 0","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n  return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/toString.js\n// module id = 161\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_162__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"get-pixels\"\n// module id = 162\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_163__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"ndarray\"\n// module id = 163\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_164__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"ndarray-linear-interpolate\"\n// module id = 164\n// module chunks = 0"],"sourceRoot":""}
\ No newline at end of file
+//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 4f870937f797b554584b","webpack:///./~/lodash/isObject.js","webpack:///./src/reader/barcode_reader.js","webpack:///./~/lodash/isArray.js","webpack:///./src/common/array_helper.js","webpack:///./src/reader/ean_reader.js","webpack:///./~/lodash/_root.js","webpack:///./~/lodash/isObjectLike.js","webpack:///./~/gl-vec2/clone.js","webpack:///./~/lodash/_baseGetTag.js","webpack:///./src/common/image_debug.js","webpack:///./~/lodash/_ListCache.js","webpack:///./~/lodash/_Symbol.js","webpack:///./~/lodash/_assocIndexOf.js","webpack:///./~/lodash/_castPath.js","webpack:///./~/lodash/_getMapData.js","webpack:///./~/lodash/_isIndex.js","webpack:///./~/lodash/_nativeCreate.js","webpack:///./~/lodash/eq.js","webpack:///./~/lodash/isArguments.js","webpack:///./src/common/cv_utils.js","webpack:///./src/common/image_wrapper.js","webpack:///./~/lodash/_baseAssignValue.js","webpack:///./~/lodash/_getNative.js","webpack:///./~/lodash/_toKey.js","webpack:///./~/lodash/isArrayLike.js","webpack:///./~/lodash/isFunction.js","webpack:///./~/lodash/isLength.js","webpack:///./~/lodash/isSymbol.js","webpack:///./~/lodash/merge.js","webpack:///(webpack)/buildin/module.js","webpack:///./src/locator/tracer.js","webpack:///./src/reader/code_39_reader.js","webpack:///./~/gl-vec2/dot.js","webpack:///./~/lodash/_Map.js","webpack:///./~/lodash/_MapCache.js","webpack:///./~/lodash/_assignMergeValue.js","webpack:///./~/lodash/_assignValue.js","webpack:///./~/lodash/_defineProperty.js","webpack:///./~/lodash/_freeGlobal.js","webpack:///./~/lodash/_getPrototype.js","webpack:///./~/lodash/_isPrototype.js","webpack:///./~/lodash/_overRest.js","webpack:///./~/lodash/_setToString.js","webpack:///./~/lodash/identity.js","webpack:///./~/lodash/isBuffer.js","webpack:///./~/lodash/isTypedArray.js","webpack:///./~/lodash/keysIn.js","webpack:///(webpack)/buildin/global.js","webpack:///./src/quagga.js","webpack:///./lib/frame_grabber.js","webpack:///./lib/input_stream.js","webpack:///./src/analytics/result_collector.js","webpack:///./src/common/cluster.js","webpack:///./src/common/events.js","webpack:///./src/common/mediaDevices.js","webpack:///./src/common/subImage.js","webpack:///./src/common/typedefs.js","webpack:///./src/config/config.js","webpack:///./src/config/config.node.js","webpack:///./src/decoder/barcode_decoder.js","webpack:///./src/decoder/bresenham.js","webpack:///./src/input/camera_access.js","webpack:///./src/locator/barcode_locator.js","webpack:///./src/locator/rasterizer.js","webpack:///./src/locator/skeletonizer.js","webpack:///./src/reader/2of5_reader.js","webpack:///./src/reader/codabar_reader.js","webpack:///./src/reader/code_128_reader.js","webpack:///./src/reader/code_39_vin_reader.js","webpack:///./src/reader/code_93_reader.js","webpack:///./src/reader/ean_2_reader.js","webpack:///./src/reader/ean_5_reader.js","webpack:///./src/reader/ean_8_reader.js","webpack:///./src/reader/i2of5_reader.js","webpack:///./src/reader/upc_e_reader.js","webpack:///./src/reader/upc_reader.js","webpack:///./~/gl-mat2/copy.js","webpack:///./~/gl-mat2/create.js","webpack:///./~/gl-mat2/invert.js","webpack:///./~/gl-vec2/scale.js","webpack:///./~/gl-vec2/transformMat2.js","webpack:///./~/gl-vec3/clone.js","webpack:///./~/lodash/_Hash.js","webpack:///./~/lodash/_Stack.js","webpack:///./~/lodash/_Uint8Array.js","webpack:///./~/lodash/_apply.js","webpack:///./~/lodash/_arrayLikeKeys.js","webpack:///./~/lodash/_arrayMap.js","webpack:///./~/lodash/_arrayPush.js","webpack:///./~/lodash/_baseCreate.js","webpack:///./~/lodash/_baseFlatten.js","webpack:///./~/lodash/_baseFor.js","webpack:///./~/lodash/_baseGet.js","webpack:///./~/lodash/_baseHasIn.js","webpack:///./~/lodash/_baseIsArguments.js","webpack:///./~/lodash/_baseIsNative.js","webpack:///./~/lodash/_baseIsTypedArray.js","webpack:///./~/lodash/_baseKeysIn.js","webpack:///./~/lodash/_baseMerge.js","webpack:///./~/lodash/_baseMergeDeep.js","webpack:///./~/lodash/_basePick.js","webpack:///./~/lodash/_basePickBy.js","webpack:///./~/lodash/_baseRest.js","webpack:///./~/lodash/_baseSet.js","webpack:///./~/lodash/_baseSetToString.js","webpack:///./~/lodash/_baseTimes.js","webpack:///./~/lodash/_baseToString.js","webpack:///./~/lodash/_baseUnary.js","webpack:///./~/lodash/_cloneArrayBuffer.js","webpack:///./~/lodash/_cloneBuffer.js","webpack:///./~/lodash/_cloneTypedArray.js","webpack:///./~/lodash/_copyArray.js","webpack:///./~/lodash/_copyObject.js","webpack:///./~/lodash/_coreJsData.js","webpack:///./~/lodash/_createAssigner.js","webpack:///./~/lodash/_createBaseFor.js","webpack:///./~/lodash/_flatRest.js","webpack:///./~/lodash/_getRawTag.js","webpack:///./~/lodash/_getValue.js","webpack:///./~/lodash/_hasPath.js","webpack:///./~/lodash/_hashClear.js","webpack:///./~/lodash/_hashDelete.js","webpack:///./~/lodash/_hashGet.js","webpack:///./~/lodash/_hashHas.js","webpack:///./~/lodash/_hashSet.js","webpack:///./~/lodash/_initCloneObject.js","webpack:///./~/lodash/_isFlattenable.js","webpack:///./~/lodash/_isIterateeCall.js","webpack:///./~/lodash/_isKey.js","webpack:///./~/lodash/_isKeyable.js","webpack:///./~/lodash/_isMasked.js","webpack:///./~/lodash/_listCacheClear.js","webpack:///./~/lodash/_listCacheDelete.js","webpack:///./~/lodash/_listCacheGet.js","webpack:///./~/lodash/_listCacheHas.js","webpack:///./~/lodash/_listCacheSet.js","webpack:///./~/lodash/_mapCacheClear.js","webpack:///./~/lodash/_mapCacheDelete.js","webpack:///./~/lodash/_mapCacheGet.js","webpack:///./~/lodash/_mapCacheHas.js","webpack:///./~/lodash/_mapCacheSet.js","webpack:///./~/lodash/_memoizeCapped.js","webpack:///./~/lodash/_nativeKeysIn.js","webpack:///./~/lodash/_nodeUtil.js","webpack:///./~/lodash/_objectToString.js","webpack:///./~/lodash/_overArg.js","webpack:///./~/lodash/_shortOut.js","webpack:///./~/lodash/_stackClear.js","webpack:///./~/lodash/_stackDelete.js","webpack:///./~/lodash/_stackGet.js","webpack:///./~/lodash/_stackHas.js","webpack:///./~/lodash/_stackSet.js","webpack:///./~/lodash/_stringToPath.js","webpack:///./~/lodash/_toSource.js","webpack:///./~/lodash/constant.js","webpack:///./~/lodash/flatten.js","webpack:///./~/lodash/hasIn.js","webpack:///./~/lodash/isArrayLikeObject.js","webpack:///./~/lodash/isPlainObject.js","webpack:///./~/lodash/memoize.js","webpack:///./~/lodash/pick.js","webpack:///./~/lodash/stubFalse.js","webpack:///./~/lodash/toPlainObject.js","webpack:///./~/lodash/toString.js","webpack:///external \"get-pixels\"","webpack:///external \"ndarray\"","webpack:///external \"ndarray-linear-interpolate\""],"names":["BarcodeReader","config","supplements","_row","prototype","_nextUnset","line","start","i","undefined","length","_matchPattern","counter","code","maxSingleError","error","singleError","sum","modulo","barWidth","count","scaled","SINGLE_CODE_ERROR","Number","MAX_VALUE","Math","abs","_nextSet","offset","_correctBars","correction","indices","tmp","_matchTrace","cmpCounter","epsilon","self","isWhite","counterPos","bestMatch","push","end","decodePattern","pattern","result","_decode","reverse","direction","DIRECTION","REVERSE","FORWARD","format","FORMAT","_matchRange","value","_fillCounters","counters","_toCounters","numCounters","init","Object","defineProperty","writeable","Exception","StartNotFoundException","CodeNotFoundException","PatternNotFoundException","CONFIG_KEYS","arr","val","l","shuffle","j","x","floor","random","toPointList","row","rows","join","threshold","scoreFunc","queue","apply","maxIndex","max","EANReader","opts","getDefaulConfig","call","keys","forEach","key","default","properties","CODE_L_START","CODE_G_START","START_PATTERN","STOP_PATTERN","MIDDLE_PATTERN","EXTENSION_START_PATTERN","CODE_PATTERN","CODE_FREQUENCY","AVG_CODE_ERROR","create","constructor","_decodeCode","coderange","_findPattern","tryHarder","_findStart","leadingWhitespaceStart","startInfo","_verifyTrailingWhitespace","endInfo","trailingWhitespaceEnd","_findEnd","_calculateFirstDigit","codeFrequency","_decodePayload","decodedCodes","firstDigit","unshift","resultInfo","_checksum","ext","_decodeExtensions","lastCode","supplement","codeset","decode","drawRect","pos","size","ctx","style","strokeStyle","color","fillStyle","lineWidth","beginPath","strokeRect","y","drawPath","path","def","moveTo","lineTo","closePath","stroke","drawImage","imageData","canvasData","getImageData","data","imageDataPos","canvasDataPos","putImageData","imageRef","computeIntegralImage2","computeIntegralImage","thresholdImage","computeHistogram","sharpenLine","determineOtsuThreshold","otsuThreshold","computeBinaryImage","cluster","dilate","erode","subtract","bitwiseOr","countNonZero","topGeneric","grayArrayFromImage","grayArrayFromContext","grayAndHalfSampleFromCanvasData","computeGray","loadImageArray","halfSample","hsv2rgb","_computeDivisors","calculatePatchSize","_parseCSSDimensionValues","computeImageArea","vec2","clone","require","vec3","that","toVec2","toVec3","round","imageWrapper","integralWrapper","width","height","integralImageData","posA","posB","posC","posD","v","u","targetWrapper","targetData","bitsPerPixel","bitShift","bucketCnt","hist","Int32Array","left","center","right","px","mx","determineThreshold","vet","p1","p2","p12","k","m1","m2","m12","kernel","A","B","C","D","avg","points","property","point","clusters","addToCluster","newPoint","found","fits","add","createPoint","Tracer","trace","vec","iteration","maxIterations","top","centerPos","currentPos","idx","forward","from","to","toIdx","predictedPos","thresholdX","thresholdY","match","predicted","DILATE","ERODE","inImageWrapper","outImageWrapper","inImageData","outImageData","yStart1","yStart2","xStart1","xStart2","aImageWrapper","bImageWrapper","resultImageWrapper","aImageData","bImageData","cImageData","list","minIdx","min","score","hit","item","htmlImage","offsetX","array","ctxData","outArray","topRowIdx","bottomRowIdx","endIdx","outWidth","outImgIdx","inWidth","singleChannel","src","callback","canvas","document","createElement","img","Image","onload","getContext","Uint8Array","inImgWrapper","outImgWrapper","inImg","outImg","hsv","rgb","h","s","c","m","r","g","b","n","largeDivisors","divisors","sqrt","concat","_computeIntersection","arr1","arr2","patchSize","imgSize","divisorsX","divisorsY","wideSide","common","nrOfPatchesList","nrOfPatchesMap","nrOfPatchesIdx","medium","nrOfPatches","desiredPatchSize","optimalPatchSize","findPatchSizeForDivisors","dimension","parseFloat","unit","indexOf","_dimensionsConverters","context","bottom","inputWidth","inputHeight","area","parsedArea","reduce","parsed","calculated","sx","sy","sw","sh","ImageWrapper","ArrayType","initialize","Array","inImageWithBorder","imgRef","border","sample","lx","ly","w","base","a","d","e","clearArray","subImage","subImageAsCopy","sizeY","sizeX","copyTo","srcData","dstData","get","getSafe","indexMapping","set","zeroBorder","invert","convolve","kx","ky","kSize","accu","moments","labelcount","ysq","labelsum","label","mu11","mu02","mu20","x_","y_","PI","PI_4","m00","m01","m10","m11","m02","m20","theta","rad","isNaN","atan","cos","sin","show","scale","frame","current","pixel","overlay","whiteRgb","blackRgb","searchDirections","labelWrapper","labelData","edgelabel","cy","dir","cx","vertex2D","next","prev","contourTracing","Fv","Cv","P","ldir","Code39Reader","ALPHABETH_STRING","ALPHABET","CHARACTER_ENCODINGS","ASTERISK","decodedChar","lastStart","nextStart","_toPattern","_patternToChar","pop","patternSize","String","fromCharCode","_findNextWidth","minWidth","maxNarrowWidth","numWideBars","wideBarWidth","patternStart","whiteSpaceMustStart","_inputStream","_framegrabber","_stopped","_canvasContainer","image","dom","_inputImageWrapper","_boxSize","_decoder","_workerPool","_onUIThread","_resultCollector","_config","initializeData","initBuffers","decoder","initInputStream","cb","video","inputStream","type","createVideoStream","createImageStream","$viewport","getViewPort","querySelector","appendChild","createLiveStream","request","constraints","then","trigger","catch","err","setAttribute","setInputStream","addEventListener","canRecord","bind","target","nodeName","nodeType","selector","checkImageConstraints","locator","initCanvas","adjustWorkerPool","numOfWorkers","ready","play","className","getCanvasSize","clearFix","getWidth","getHeight","console","log","getBoundingBoxes","locate","transformResult","topRight","getTopRight","xOffset","yOffset","barcodes","moveLine","box","moveBox","boxes","corner","addResult","filter","barcode","codeResult","hasCodeResult","some","publishResult","resultToPublish","publish","locateAndDecode","decodeFromBoundingBoxes","update","availableWorker","workerThread","busy","attachData","grab","worker","postMessage","cmd","buffer","startContinuousUpdate","delay","frequency","timestamp","window","requestAnimFrame","performance","now","initWorker","blobURL","generateWorkerBlob","Worker","onmessage","event","URL","revokeObjectURL","message","configForWorker","workerInterface","factory","Quagga","onProcessed","setReaders","readers","blob","factorySource","__factorySource__","Blob","toString","createObjectURL","capacity","increaseBy","workersToTerminate","slice","terminate","workerInitialized","stop","release","clearEventHandlers","pause","onDetected","subscribe","offDetected","unsubscribe","offProcessed","registerResultCollector","resultCollector","decodeSingle","resultCallback","sequence","once","ImageDebug","ResultCollector","CameraAccess","CVUtils","Ndarray","Interp2D","d2","FrameGrabber","_that","_streamConfig","getConfig","_video_size","getRealWidth","getRealHeight","_canvasSize","_size","_topRight","_data","_grayData","_canvasData","_grayImageArray","transpose","_canvasImageArray","_targetImageArray","hi","lo","_stepSizeX","_stepSizeY","JSON","stringify","videoSize","shape","canvasSize","stepSize","getData","getFrame","scaleAndCrop","Error","getSize","module","exports","GetPixels","InputStream","frameIdx","paused","loaded","baseUrl","ended","calculatedWidth","calculatedHeight","_eventNames","_eventHandlers","loadImages","mime","pixels","exit","setTimeout","publishEvent","eventName","args","handlers","setWidth","setHeight","stream","setCurrentTime","time","f","setTopRight","setCanvasSize","contains","every","passesFilter","results","capture","matchesConstraints","blacklist","imageSize","toDataURL","getResults","dot","pointMap","updateCenter","pointToAdd","id","otherPoint","similarity","getPoints","getCenter","events","getEvent","subscribers","clearEvents","publishSubscription","subscription","async","subscriber","enumerateDevices","getUserMedia","navigator","mediaDevices","Promise","reject","SubImage","I","originalSize","updateData","updateFrom","requestAnimationFrame","webkitRequestAnimationFrame","mozRequestAnimationFrame","oRequestAnimationFrame","msRequestAnimationFrame","imul","ah","al","bh","bl","assign","TypeError","index","arguments","nextSource","nextKey","hasOwnProperty","READERS","code_128_reader","ean_reader","ean_5_reader","ean_2_reader","ean_8_reader","code_39_reader","code_39_vin_reader","codabar_reader","upc_reader","upc_e_reader","i2of5_reader","code_93_reader","inputImageWrapper","_canvas","_barcodeReaders","initReaders","initConfig","$debug","readerConfig","reader","configuration","map","vis","node","prop","debug","showFrequency","showPattern","display","getExtendedLine","angle","extendLine","amount","extension","ceil","getLine","tryDecode","barcodeLine","getBarcodeLine","printFrequency","toBinaryLine","printPattern","tryDecodeBruteForce","lineAngle","sideLength","pow","slices","xdir","ydir","getLineLength","decodeFromBoundingBox","lineLength","drawBoundingBox","atan2","multiple","Bresenham","Slope","DIR","UP","DOWN","x0","y0","x1","y1","steep","deltax","deltay","ystep","read","slope","slope2","extrema","currentDir","rThreshold","fillColor","fillRect","pickConstraints","facingMatching","streamRef","waitForVideo","resolve","attempts","checkVideo","videoWidth","videoHeight","initCamera","srcObject","deprecatedConstraints","videoConstraints","normalized","minAspectRatio","aspectRatio","facing","facingMode","normalizedConstraints","audio","deviceId","enumerateVideoDevices","devices","device","kind","getActiveTrack","tracks","getVideoTracks","getActiveStreamLabel","track","transformMat2","mat2","copy","_currentImageWrapper","_skelImageWrapper","_subImageWrapper","_labelImageWrapper","_patchGrid","_patchLabelGrid","_imageToPatchGrid","_binaryImageWrapper","_patchSize","binary","_numPatches","_skeletonizer","skeletonImageData","ArrayBuffer","global","useWorker","boxFromPatches","patches","overAvg","patch","transMat","minx","miny","maxx","maxy","binarizeImage","findPatches","patchesFound","rasterizer","rasterResult","skeletonize","rasterize","describePatch","findBiggestConnectedAreas","maxLabel","labelHist","topLabels","sort","el","findBoxes","similarMoments","topCluster","patchPos","eligibleMoments","matchingMoments","minComponentWeight","rasterizeAngularSimilarity","currIdx","notYetProcessed","currentIdx","currentPatch","Rasterizer","createContour2D","firstVertex","insideContours","nextpeer","prevpeer","CONTOUR_DIR","CW_DIR","CCW_DIR","UNKNOWN_DIR","OUTSIDE_EDGE","INSIDE_EDGE","tracer","depthlabel","bc","lc","labelindex","colorMap","vertex","p","cc","sc","connectedCount","drawContour","firstContour","pq","iq","q","Skeletonizer","stdlib","foreign","images","inImagePtr","outImagePtr","aImagePtr","bImagePtr","imagePtr","memcpy","srcImagePtr","dstImagePtr","subImagePtr","erodedImagePtr","tempImagePtr","skelImagePtr","done","TwoOfFiveReader","barSpaceRatio","N","W","writable","startPatternLength","narrowBarWidth","counterLength","_verifyCounterLength","CodabarReader","_counters","START_END","MIN_ENCODED_CHARS","MAX_ACCEPTABLE","PADDING","startCounter","_isStartEnd","_verifyWhitespace","_validateResult","_sumCounters","endCounter","_calculatePatternLength","_thresholdResultPattern","categorization","space","narrow","counts","wide","bar","cat","_charToPattern","newkind","char","charCode","charCodeAt","thresholds","_computeAlternatingThreshold","barThreshold","spaceThreshold","bitmask","Code128Reader","CODE_SHIFT","CODE_C","CODE_B","CODE_A","START_CODE_A","START_CODE_B","START_CODE_C","STOP_CODE","MODULE_INDICES","_correct","calculateCorrection","multiplier","checksum","rawResult","shiftNext","removeLastCharacter","splice","expected","sumNormalized","sumExpected","Code39VINReader","patterns","IOQ","AZ09","replace","_checkChecksum","Code93Reader","split","_verifyEnd","_verifyChecksums","_decodeExtended","charArray","nextChar","nextCharCode","_matchCheckChar","maxWeight","arrayToCheck","weightedSums","weight","checkChar","EAN2Reader","parseInt","EAN5Reader","CHECK_DIGIT_ENCODINGS","extensionChecksum","determineCheckDigit","EAN8Reader","I2of5Reader","normalizeBarSpaceWidth","MAX_CORRECTION_FACTOR","counterSum","codeSum","correctionRatio","correctionRatioInverse","_decodePair","counterPair","codes","UPCEReader","_determineParity","nrSystem","_convertToUPCA","upca","lastDigit","UPCReader","charAt","substring"],"mappings":"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P,CAAvB;AACA8G,aAAKhJ,SAAS,CAAT,GAAa,CAAlB,IAAuBkC,OAAO,CAAP,CAAvB;AACA8G,aAAKhJ,SAAS,CAAT,GAAa,CAAlB,IAAuB,GAAvB;AACH;AACD4H,QAAIuB,YAAJ,CAAiBmQ,KAAjB,EAAwBrK,KAAKlL,CAA7B,EAAgCkL,KAAK7G,CAArC;AACH,CAtBD;;kBAwBesN,Y;;;;;;AC5Vf;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;;AAEA;;;;;;;ACxBA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,cAAc;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;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CA;AACA;AACA,C;;;;;;ACXA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACNA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,EAAE;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB;AACA,GAAG;AACH,CAAC;;AAED;;;;;;;ACVA;AACA;;AAEA;;;;;;;;ACHA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnCA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,EAAE;AACf;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AAC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ACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;;;;;;AC1BA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,OAAO;AAClB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA,C;;;;;;ACdA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,C;;;;;;AChBA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB,aAAa,KAAK;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,C;;;;;;ACdA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC1BA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,EAAE;AACb,WAAW,MAAM;AACjB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,QAAQ;AACnB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChDA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,SAAS;AACpB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;;;;;;;AC7BA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;;AAEA;;;;;;;ACfA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,EAAE;AACf;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvBA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oCAAoC;;AAEpC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC9CA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3DA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5FA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;AClBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,OAAO;AAClB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,WAAW,EAAE;AACb,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC9CA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,SAAS;AACpB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;;AAEA;AACA;AACA;AACA;AACA,WAAW,YAAY;AACvB,aAAa,YAAY;AACzB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;;AClCA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,QAAQ;AACnB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,MAAM;AACjB,WAAW,OAAO,WAAW;AAC7B,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA,wBAAwB;;AAExB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvCA;;AAEA;AACA;;AAEA;;;;;;;ACLA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;ACpCA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7CA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,WAAW,SAAS;AACpB,aAAa,QAAQ;AACrB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,EAAE;AACb,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7BA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;;AAEA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACZA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;AClBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACfA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACnBA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,CAAC;;AAED;;;;;;;;ACrBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,EAAE;AACf;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,QAAQ;AACrB;AACA;AACA;AACA;;AAEA;;;;;;;ACbA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjCA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,CAAC;;AAED;;;;;;;AC3BA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,SAAS;AACtB;AACA;AACA,wCAAwC,SAAS;AACjD;AACA;AACA,WAAW,SAAS,GAAG,SAAS;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACzBA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM;AACjB,aAAa,MAAM;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACrBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,aAAa;AACxB,aAAa,QAAQ;AACrB;AACA;AACA,0BAA0B,gBAAgB,SAAS,GAAG;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjCA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChCA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC7DA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,aAAa,SAAS;AACtB;AACA;AACA,iBAAiB;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;ACxEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,qBAAqB;AAChC,aAAa,OAAO;AACpB;AACA;AACA,iBAAiB;AACjB;AACA;AACA,UAAU;AACV;AACA;AACA,4BAA4B;AAC5B,CAAC;;AAED;;;;;;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACjBA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAAS;AACtB,UAAU;AACV;AACA,aAAa,SAAS;AACtB,UAAU;AACV;AACA;AACA;AACA;;AAEA;;;;;;;AC/BA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,aAAa,OAAO;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AC3BA,iD;;;;;;ACAA,iD;;;;;;ACAA,iD","file":"quagga.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"get-pixels\"), require(\"ndarray\"), require(\"ndarray-linear-interpolate\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"get-pixels\", \"ndarray\", \"ndarray-linear-interpolate\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Quagga\"] = factory(require(\"get-pixels\"), require(\"ndarray\"), require(\"ndarray-linear-interpolate\"));\n\telse\n\t\troot[\"Quagga\"] = factory(root[\"get-pixels\"], root[\"ndarray\"], root[\"ndarray-linear-interpolate\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE_164__, __WEBPACK_EXTERNAL_MODULE_165__, __WEBPACK_EXTERNAL_MODULE_166__) {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 167);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 4f870937f797b554584b","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n  var type = typeof value;\n  return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isObject.js\n// module id = 0\n// module chunks = 0","import ArrayHelper from '../common/array_helper';\n\nfunction BarcodeReader(config, supplements) {\n    this._row = [];\n    this.config = config || {};\n    this.supplements = supplements;\n    return this;\n}\n\nBarcodeReader.prototype._nextUnset = function(line, start) {\n    var i;\n\n    if (start === undefined) {\n        start = 0;\n    }\n    for (i = start; i < line.length; i++) {\n        if (!line[i]) {\n            return i;\n        }\n    }\n    return line.length;\n};\n\nBarcodeReader.prototype._matchPattern = function(counter, code, maxSingleError) {\n    var i,\n        error = 0,\n        singleError = 0,\n        sum = 0,\n        modulo = 0,\n        barWidth,\n        count,\n        scaled;\n\n    maxSingleError = maxSingleError || this.SINGLE_CODE_ERROR || 1;\n\n    for (i = 0; i < counter.length; i++) {\n        sum += counter[i];\n        modulo += code[i];\n    }\n    if (sum < modulo) {\n        return Number.MAX_VALUE;\n    }\n    barWidth = sum / modulo;\n    maxSingleError *= barWidth;\n\n    for (i = 0; i < counter.length; i++) {\n        count = counter[i];\n        scaled = code[i] * barWidth;\n        singleError = Math.abs(count - scaled) / scaled;\n        if (singleError > maxSingleError) {\n            return Number.MAX_VALUE;\n        }\n        error += singleError;\n    }\n    return error / modulo;\n};\n\nBarcodeReader.prototype._nextSet = function(line, offset) {\n    var i;\n\n    offset = offset || 0;\n    for (i = offset; i < line.length; i++) {\n        if (line[i]) {\n            return i;\n        }\n    }\n    return line.length;\n};\n\nBarcodeReader.prototype._correctBars = function(counter, correction, indices) {\n    var length = indices.length,\n        tmp = 0;\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\nBarcodeReader.prototype._matchTrace = function(cmpCounter, epsilon) {\n    var counter = [],\n        i,\n        self = this,\n        offset = self._nextSet(self._row),\n        isWhite = !self._row[offset],\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0\n        },\n        error;\n\n    if (cmpCounter) {\n        for ( i = 0; i < cmpCounter.length; i++) {\n            counter.push(0);\n        }\n        for ( i = offset; i < self._row.length; i++) {\n            if (self._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                if (counterPos === counter.length - 1) {\n                    error = self._matchPattern(counter, cmpCounter);\n\n                    if (error < epsilon) {\n                        bestMatch.start = i - offset;\n                        bestMatch.end = i;\n                        bestMatch.counter = counter;\n                        return bestMatch;\n                    } else {\n                        return null;\n                    }\n                } else {\n                    counterPos++;\n                }\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n    } else {\n        counter.push(0);\n        for ( i = offset; i < self._row.length; i++) {\n            if (self._row[i] ^ isWhite) {\n                counter[counterPos]++;\n            } else {\n                counterPos++;\n                counter.push(0);\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n    }\n\n    // if cmpCounter was not given\n    bestMatch.start = offset;\n    bestMatch.end = self._row.length - 1;\n    bestMatch.counter = counter;\n    return bestMatch;\n};\n\nBarcodeReader.prototype.decodePattern = function(pattern) {\n    var self = this,\n        result;\n\n    self._row = pattern;\n    result = self._decode();\n    if (result === null) {\n        self._row.reverse();\n        result = self._decode();\n        if (result) {\n            result.direction = BarcodeReader.DIRECTION.REVERSE;\n            result.start = self._row.length - result.start;\n            result.end = self._row.length - result.end;\n        }\n    } else {\n        result.direction = BarcodeReader.DIRECTION.FORWARD;\n    }\n    if (result) {\n        result.format = self.FORMAT;\n    }\n    return result;\n};\n\nBarcodeReader.prototype._matchRange = function(start, end, value) {\n    var i;\n\n    start = start < 0 ? 0 : start;\n    for (i = start; i < end; i++) {\n        if (this._row[i] !== value) {\n            return false;\n        }\n    }\n    return true;\n};\n\nBarcodeReader.prototype._fillCounters = function(offset, end, isWhite) {\n    var self = this,\n        counterPos = 0,\n        i,\n        counters = [];\n\n    isWhite = (typeof isWhite !== 'undefined') ? isWhite : true;\n    offset = (typeof offset !== 'undefined') ? offset : self._nextUnset(self._row);\n    end = end || self._row.length;\n\n    counters[counterPos] = 0;\n    for (i = offset; i < end; i++) {\n        if (self._row[i] ^ isWhite) {\n            counters[counterPos]++;\n        } else {\n            counterPos++;\n            counters[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return counters;\n};\n\nBarcodeReader.prototype._toCounters = function(start, counter) {\n    var self = this,\n        numCounters = counter.length,\n        end = self._row.length,\n        isWhite = !self._row[start],\n        i,\n        counterPos = 0;\n\n    ArrayHelper.init(counter, 0);\n\n    for ( i = start; i < end; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            counterPos++;\n            if (counterPos === numCounters) {\n                break;\n            } else {\n                counter[counterPos] = 1;\n                isWhite = !isWhite;\n            }\n        }\n    }\n\n    return counter;\n};\n\nObject.defineProperty(BarcodeReader.prototype, \"FORMAT\", {\n    value: 'unknown',\n    writeable: false\n});\n\nBarcodeReader.DIRECTION = {\n    FORWARD: 1,\n    REVERSE: -1\n};\n\nBarcodeReader.Exception = {\n    StartNotFoundException: \"Start-Info was not found!\",\n    CodeNotFoundException: \"Code could not be found!\",\n    PatternNotFoundException: \"Pattern could not be found!\"\n};\n\nBarcodeReader.CONFIG_KEYS = {};\n\nexport default BarcodeReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/barcode_reader.js","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArray.js\n// module id = 2\n// module chunks = 0","export default {\n    init: function(arr, val) {\n        var l = arr.length;\n        while (l--) {\n            arr[l] = val;\n        }\n    },\n\n    /**\n     * Shuffles the content of an array\n     * @return {Array} the array itself shuffled\n     */\n    shuffle: function(arr) {\n        var i = arr.length - 1, j, x;\n        for (i; i >= 0; i--) {\n            j = Math.floor(Math.random() * i);\n            x = arr[i];\n            arr[i] = arr[j];\n            arr[j] = x;\n        }\n        return arr;\n    },\n\n    toPointList: function(arr) {\n        var i, j, row = [], rows = [];\n        for ( i = 0; i < arr.length; i++) {\n            row = [];\n            for ( j = 0; j < arr[i].length; j++) {\n                row[j] = arr[i][j];\n            }\n            rows[i] = \"[\" + row.join(\",\") + \"]\";\n        }\n        return \"[\" + rows.join(\",\\r\\n\") + \"]\";\n    },\n\n    /**\n     * returns the elements which's score is bigger than the threshold\n     * @return {Array} the reduced array\n     */\n    threshold: function(arr, threshold, scoreFunc) {\n        var i, queue = [];\n        for ( i = 0; i < arr.length; i++) {\n            if (scoreFunc.apply(arr, [arr[i]]) >= threshold) {\n                queue.push(arr[i]);\n            }\n        }\n        return queue;\n    },\n\n    maxIndex: function(arr) {\n        var i, max = 0;\n        for ( i = 0; i < arr.length; i++) {\n            if (arr[i] > arr[max]) {\n                max = i;\n            }\n        }\n        return max;\n    },\n\n    max: function(arr) {\n        var i, max = 0;\n        for ( i = 0; i < arr.length; i++) {\n            if (arr[i] > max) {\n                max = arr[i];\n            }\n        }\n        return max;\n    },\n\n    sum: function(arr) {\n        var length = arr.length,\n            sum = 0;\n\n        while (length--) {\n            sum += arr[length];\n        }\n        return sum;\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/array_helper.js","import BarcodeReader from './barcode_reader';\nimport {merge} from 'lodash';\n\nfunction EANReader(opts, supplements) {\n    opts = merge(getDefaulConfig(), opts);\n    BarcodeReader.call(this, opts, supplements);\n}\n\nfunction getDefaulConfig() {\n    var config = {};\n\n    Object.keys(EANReader.CONFIG_KEYS).forEach(function(key) {\n        config[key] = EANReader.CONFIG_KEYS[key].default;\n    });\n    return config;\n}\n\nvar properties = {\n    CODE_L_START: {value: 0},\n    CODE_G_START: {value: 10},\n    START_PATTERN: {value: [1, 1, 1]},\n    STOP_PATTERN: {value: [1, 1, 1]},\n    MIDDLE_PATTERN: {value: [1, 1, 1, 1, 1]},\n    EXTENSION_START_PATTERN: {value: [1, 1, 2]},\n    CODE_PATTERN: {value: [\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    ]},\n    CODE_FREQUENCY: {value: [0, 11, 13, 14, 19, 25, 28, 21, 22, 26]},\n    SINGLE_CODE_ERROR: {value: 0.70},\n    AVG_CODE_ERROR: {value: 0.48},\n    FORMAT: {value: \"ean_13\", writeable: false}\n};\n\nEANReader.prototype = Object.create(BarcodeReader.prototype, properties);\nEANReader.prototype.constructor = EANReader;\n\nEANReader.prototype._decodeCode = function(start, coderange) {\n    var counter = [0, 0, 0, 0],\n        i,\n        self = this,\n        offset = start,\n        isWhite = !self._row[offset],\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: start,\n            end: start\n        },\n        code,\n        error;\n\n    if (!coderange) {\n        coderange = self.CODE_PATTERN.length;\n    }\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                for (code = 0; code < coderange; code++) {\n                    error = self._matchPattern(counter, self.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 > self.AVG_CODE_ERROR) {\n                    return null;\n                }\n                return bestMatch;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder, epsilon) {\n    var counter = [],\n        self = this,\n        i,\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        },\n        error,\n        j,\n        sum;\n\n    if (!offset) {\n        offset = self._nextSet(self._row);\n    }\n\n    if (isWhite === undefined) {\n        isWhite = false;\n    }\n\n    if (tryHarder === undefined) {\n        tryHarder = true;\n    }\n\n    if ( epsilon === undefined) {\n        epsilon = self.AVG_CODE_ERROR;\n    }\n\n    for ( i = 0; i < pattern.length; i++) {\n        counter[i] = 0;\n    }\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                sum = 0;\n                for ( j = 0; j < counter.length; j++) {\n                    sum += counter[j];\n                }\n                error = self._matchPattern(counter, pattern);\n\n                if (error < epsilon) {\n                    bestMatch.error = error;\n                    bestMatch.start = i - sum;\n                    bestMatch.end = i;\n                    return bestMatch;\n                }\n                if (tryHarder) {\n                    for ( j = 0; j < counter.length - 2; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[counter.length - 2] = 0;\n                    counter[counter.length - 1] = 0;\n                    counterPos--;\n                } else {\n                    return null;\n                }\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._findStart = function() {\n    var self = this,\n        leadingWhitespaceStart,\n        offset = self._nextSet(self._row),\n        startInfo;\n\n    while (!startInfo) {\n        startInfo = self._findPattern(self.START_PATTERN, offset);\n        if (!startInfo) {\n            return null;\n        }\n        leadingWhitespaceStart = startInfo.start - (startInfo.end - startInfo.start);\n        if (leadingWhitespaceStart >= 0) {\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                return startInfo;\n            }\n        }\n        offset = startInfo.end;\n        startInfo = null;\n    }\n};\n\nEANReader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + (endInfo.end - endInfo.start);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._findEnd = function(offset, isWhite) {\n    var self = this,\n        endInfo = self._findPattern(self.STOP_PATTERN, offset, isWhite, false);\n\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\n};\n\nEANReader.prototype._calculateFirstDigit = function(codeFrequency) {\n    var i,\n        self = this;\n\n    for ( i = 0; i < self.CODE_FREQUENCY.length; i++) {\n        if (codeFrequency === self.CODE_FREQUENCY[i]) {\n            return i;\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._decodePayload = function(code, result, decodedCodes) {\n    var i,\n        self = this,\n        codeFrequency = 0x0,\n        firstDigit;\n\n    for ( i = 0; i < 6; i++) {\n        code = self._decodeCode(code.end);\n        if (!code) {\n            return null;\n        }\n        if (code.code >= self.CODE_G_START) {\n            code.code = code.code - self.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    firstDigit = self._calculateFirstDigit(codeFrequency);\n    if (firstDigit === null) {\n        return null;\n    }\n    result.unshift(firstDigit);\n\n    code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);\n    if (code === null) {\n        return null;\n    }\n    decodedCodes.push(code);\n\n    for ( i = 0; i < 6; i++) {\n        code = self._decodeCode(code.end, self.CODE_G_START);\n        if (!code) {\n            return null;\n        }\n        decodedCodes.push(code);\n        result.push(code.code);\n    }\n\n    return code;\n};\n\nEANReader.prototype._decode = function() {\n    var startInfo,\n        self = this,\n        code,\n        result = [],\n        decodedCodes = [],\n        resultInfo = {};\n\n    startInfo = self._findStart();\n    if (!startInfo) {\n        return null;\n    }\n    code = {\n        code: startInfo.code,\n        start: startInfo.start,\n        end: startInfo.end\n    };\n    decodedCodes.push(code);\n    code = self._decodePayload(code, result, decodedCodes);\n    if (!code) {\n        return null;\n    }\n    code = self._findEnd(code.end, false);\n    if (!code){\n        return null;\n    }\n\n    decodedCodes.push(code);\n\n    // Checksum\n    if (!self._checksum(result)) {\n        return null;\n    }\n\n    if (this.supplements.length > 0) {\n        let ext = this._decodeExtensions(code.end);\n        if (!ext) {\n            return null;\n        }\n        let lastCode = ext.decodedCodes[ext.decodedCodes.length-1],\n            endInfo = {\n                start: lastCode.start + (((lastCode.end - lastCode.start) / 2) | 0),\n                end: lastCode.end\n            };\n        if(!self._verifyTrailingWhitespace(endInfo)) {\n            return null;\n        }\n        resultInfo = {\n            supplement: ext,\n            code: result.join(\"\") + ext.code\n        }\n    }\n\n    return {\n        code: result.join(\"\"),\n        start: startInfo.start,\n        end: code.end,\n        codeset: \"\",\n        startInfo: startInfo,\n        decodedCodes: decodedCodes,\n        ...resultInfo\n    };\n};\n\nEANReader.prototype._decodeExtensions = function(offset) {\n    var i,\n        start = this._nextSet(this._row, offset),\n        startInfo = this._findPattern(this.EXTENSION_START_PATTERN, start, false, false),\n        result;\n\n    if (startInfo === null) {\n        return null;\n    }\n\n    for (i = 0; i < this.supplements.length; i++) {\n        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                codeset: \"\",\n                decodedCodes: result.decodedCodes\n            }\n        }\n    }\n    return null;\n};\n\nEANReader.prototype._checksum = function(result) {\n    var sum = 0, i;\n\n    for ( i = result.length - 2; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    sum *= 3;\n    for ( i = result.length - 1; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    return sum % 10 === 0;\n};\n\nEANReader.CONFIG_KEYS = {\n    supplements: {\n        'type': 'arrayOf(string)',\n        'default': [],\n        'description': 'Allowed extensions to be decoded (2 and/or 5)'\n    }\n};\n\nexport default (EANReader);\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_reader.js","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_root.js\n// module id = 5\n// module chunks = 0","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isObjectLike.js\n// module id = 6\n// module chunks = 0","module.exports = clone\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nfunction clone(a) {\n    var out = new Float32Array(2)\n    out[0] = a[0]\n    out[1] = a[1]\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/clone.js\n// module id = 7\n// module chunks = 0","var Symbol = require('./_Symbol'),\n    getRawTag = require('./_getRawTag'),\n    objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n    undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n  if (value == null) {\n    return value === undefined ? undefinedTag : nullTag;\n  }\n  return (symToStringTag && symToStringTag in Object(value))\n    ? getRawTag(value)\n    : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseGetTag.js\n// module id = 8\n// module chunks = 0","export default {\n    drawRect: function(pos, size, ctx, style){\n        ctx.strokeStyle = style.color;\n        ctx.fillStyle = style.color;\n        ctx.lineWidth = 1;\n        ctx.beginPath();\n        ctx.strokeRect(pos.x, pos.y, size.x, size.y);\n    },\n    drawPath: function(path, def, ctx, style) {\n        ctx.strokeStyle = style.color;\n        ctx.fillStyle = style.color;\n        ctx.lineWidth = style.lineWidth;\n        ctx.beginPath();\n        ctx.moveTo(path[0][def.x], path[0][def.y]);\n        for (var j = 1; j < path.length; j++) {\n            ctx.lineTo(path[j][def.x], path[j][def.y]);\n        }\n        ctx.closePath();\n        ctx.stroke();\n    },\n    drawImage: function(imageData, size, ctx) {\n        var canvasData = ctx.getImageData(0, 0, size.x, size.y),\n            data = canvasData.data,\n            imageDataPos = imageData.length,\n            canvasDataPos = data.length,\n            value;\n\n        if (canvasDataPos / imageDataPos !== 4) {\n            return false;\n        }\n        while (imageDataPos--){\n            value = imageData[imageDataPos];\n            data[--canvasDataPos] = 255;\n            data[--canvasDataPos] = value;\n            data[--canvasDataPos] = value;\n            data[--canvasDataPos] = value;\n        }\n        ctx.putImageData(canvasData, 0, 0);\n        return true;\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/image_debug.js","var listCacheClear = require('./_listCacheClear'),\n    listCacheDelete = require('./_listCacheDelete'),\n    listCacheGet = require('./_listCacheGet'),\n    listCacheHas = require('./_listCacheHas'),\n    listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_ListCache.js\n// module id = 10\n// module chunks = 0","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Symbol.js\n// module id = 11\n// module chunks = 0","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n  var length = array.length;\n  while (length--) {\n    if (eq(array[length][0], key)) {\n      return length;\n    }\n  }\n  return -1;\n}\n\nmodule.exports = assocIndexOf;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assocIndexOf.js\n// module id = 12\n// module chunks = 0","var isArray = require('./isArray'),\n    isKey = require('./_isKey'),\n    stringToPath = require('./_stringToPath'),\n    toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n  if (isArray(value)) {\n    return value;\n  }\n  return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_castPath.js\n// module id = 13\n// module chunks = 0","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n  var data = map.__data__;\n  return isKeyable(key)\n    ? data[typeof key == 'string' ? 'string' : 'hash']\n    : data.map;\n}\n\nmodule.exports = getMapData;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getMapData.js\n// module id = 14\n// module chunks = 0","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return !!length &&\n    (typeof value == 'number' || reIsUint.test(value)) &&\n    (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isIndex.js\n// module id = 15\n// module chunks = 0","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nativeCreate.js\n// module id = 16\n// module chunks = 0","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/eq.js\n// module id = 17\n// module chunks = 0","var baseIsArguments = require('./_baseIsArguments'),\n    isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n *  else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n  return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n    !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArguments.js\n// module id = 18\n// module chunks = 0","import Cluster2 from './cluster';\nimport ArrayHelper from './array_helper';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n};\nconst vec3 = {\n    clone: require('gl-vec3/clone'),\n};\n\n/**\n * @param x x-coordinate\n * @param y y-coordinate\n * @return ImageReference {x,y} Coordinate\n */\nexport function imageRef(x, y) {\n    var that = {\n        x: x,\n        y: y,\n        toVec2: function() {\n            return vec2.clone([this.x, this.y]);\n        },\n        toVec3: function() {\n            return vec3.clone([this.x, this.y, 1]);\n        },\n        round: function() {\n            this.x = this.x > 0.0 ? Math.floor(this.x + 0.5) : Math.floor(this.x - 0.5);\n            this.y = this.y > 0.0 ? Math.floor(this.y + 0.5) : Math.floor(this.y - 0.5);\n            return this;\n        }\n    };\n    return that;\n};\n\n/**\n * Computes an integral image of a given grayscale image.\n * @param imageDataContainer {ImageDataContainer} the image to be integrated\n */\nexport function computeIntegralImage2(imageWrapper, integralWrapper) {\n    var imageData = imageWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0, posA = 0, posB = 0, posC = 0, posD = 0, x, y;\n\n    // sum up first column\n    posB = width;\n    sum = 0;\n    for ( y = 1; y < height; y++) {\n        sum += imageData[posA];\n        integralImageData[posB] += sum;\n        posA += width;\n        posB += width;\n    }\n\n    posA = 0;\n    posB = 1;\n    sum = 0;\n    for ( x = 1; x < width; x++) {\n        sum += imageData[posA];\n        integralImageData[posB] += sum;\n        posA++;\n        posB++;\n    }\n\n    for ( y = 1; y < height; y++) {\n        posA = y * width + 1;\n        posB = (y - 1) * width + 1;\n        posC = y * width;\n        posD = (y - 1) * width;\n        for ( x = 1; x < width; x++) {\n            integralImageData[posA] +=\n                imageData[posA] + integralImageData[posB] + integralImageData[posC] - integralImageData[posD];\n            posA++;\n            posB++;\n            posC++;\n            posD++;\n        }\n    }\n};\n\nexport function computeIntegralImage(imageWrapper, integralWrapper) {\n    var imageData = imageWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0;\n\n    // sum up first row\n    for (var i = 0; i < width; i++) {\n        sum += imageData[i];\n        integralImageData[i] = sum;\n    }\n\n    for (var v = 1; v < height; v++) {\n        sum = 0;\n        for (var u = 0; u < width; u++) {\n            sum += imageData[v * width + u];\n            integralImageData[((v) * width) + u] = sum + integralImageData[(v - 1) * width + u];\n        }\n    }\n};\n\nexport function thresholdImage(imageWrapper, threshold, targetWrapper) {\n    if (!targetWrapper) {\n        targetWrapper = imageWrapper;\n    }\n    var imageData = imageWrapper.data, length = imageData.length, targetData = targetWrapper.data;\n\n    while (length--) {\n        targetData[length] = imageData[length] < threshold ? 1 : 0;\n    }\n};\n\nexport function computeHistogram(imageWrapper, bitsPerPixel) {\n    if (!bitsPerPixel) {\n        bitsPerPixel = 8;\n    }\n    var imageData = imageWrapper.data,\n        length = imageData.length,\n        bitShift = 8 - bitsPerPixel,\n        bucketCnt = 1 << bitsPerPixel,\n        hist = new Int32Array(bucketCnt);\n\n    while (length--) {\n        hist[imageData[length] >> bitShift]++;\n    }\n    return hist;\n};\n\nexport function sharpenLine(line) {\n    var i,\n        length = line.length,\n        left = line[0],\n        center = line[1],\n        right;\n\n    for (i = 1; i < length - 1; i++) {\n        right = line[i + 1];\n        //  -1 4 -1 kernel\n        line[i - 1] = (((center * 2) - left - right)) & 255;\n        left = center;\n        center = right;\n    }\n    return line;\n};\n\nexport function determineOtsuThreshold(imageWrapper, bitsPerPixel) {\n    if (!bitsPerPixel) {\n        bitsPerPixel = 8;\n    }\n    var hist,\n        threshold,\n        bitShift = 8 - bitsPerPixel;\n\n    function px(init, end) {\n        var sum = 0, i;\n        for ( i = init; i <= end; i++) {\n            sum += hist[i];\n        }\n        return sum;\n    }\n\n    function mx(init, end) {\n        var i, sum = 0;\n\n        for ( i = init; i <= end; i++) {\n            sum += i * hist[i];\n        }\n\n        return sum;\n    }\n\n    function determineThreshold() {\n        var vet = [0], p1, p2, p12, k, m1, m2, m12,\n            max = (1 << bitsPerPixel) - 1;\n\n        hist = computeHistogram(imageWrapper, bitsPerPixel);\n        for ( k = 1; k < max; k++) {\n            p1 = px(0, k);\n            p2 = px(k + 1, max);\n            p12 = p1 * p2;\n            if (p12 === 0) {\n                p12 = 1;\n            }\n            m1 = mx(0, k) * p2;\n            m2 = mx(k + 1, max) * p1;\n            m12 = m1 - m2;\n            vet[k] = m12 * m12 / p12;\n        }\n        return ArrayHelper.maxIndex(vet);\n    }\n\n    threshold = determineThreshold();\n    return threshold << bitShift;\n};\n\nexport function otsuThreshold(imageWrapper, targetWrapper) {\n    var threshold = determineOtsuThreshold(imageWrapper);\n\n    thresholdImage(imageWrapper, threshold, targetWrapper);\n    return threshold;\n};\n\n// local thresholding\nexport function computeBinaryImage(imageWrapper, integralWrapper, targetWrapper) {\n    computeIntegralImage(imageWrapper, integralWrapper);\n\n    if (!targetWrapper) {\n        targetWrapper = imageWrapper;\n    }\n    var imageData = imageWrapper.data;\n    var targetData = targetWrapper.data;\n    var width = imageWrapper.size.x;\n    var height = imageWrapper.size.y;\n    var integralImageData = integralWrapper.data;\n    var sum = 0, v, u, kernel = 3, A, B, C, D, avg, size = (kernel * 2 + 1) * (kernel * 2 + 1);\n\n    // clear out top & bottom-border\n    for ( v = 0; v <= kernel; v++) {\n        for ( u = 0; u < width; u++) {\n            targetData[((v) * width) + u] = 0;\n            targetData[(((height - 1) - v) * width) + u] = 0;\n        }\n    }\n\n    // clear out left & right border\n    for ( v = kernel; v < height - kernel; v++) {\n        for ( u = 0; u <= kernel; u++) {\n            targetData[((v) * width) + u] = 0;\n            targetData[((v) * width) + (width - 1 - u)] = 0;\n        }\n    }\n\n    for ( v = kernel + 1; v < height - kernel - 1; v++) {\n        for ( u = kernel + 1; u < width - kernel; u++) {\n            A = integralImageData[(v - kernel - 1) * width + (u - kernel - 1)];\n            B = integralImageData[(v - kernel - 1) * width + (u + kernel)];\n            C = integralImageData[(v + kernel) * width + (u - kernel - 1)];\n            D = integralImageData[(v + kernel) * width + (u + kernel)];\n            sum = D - C - B + A;\n            avg = sum / (size);\n            targetData[v * width + u] = imageData[v * width + u] > (avg + 5) ? 0 : 1;\n        }\n    }\n};\n\nexport function cluster(points, threshold, property) {\n    var i, k, cluster, point, clusters = [];\n\n    if (!property) {\n        property = \"rad\";\n    }\n\n    function addToCluster(newPoint) {\n        var found = false;\n        for ( k = 0; k < clusters.length; k++) {\n            cluster = clusters[k];\n            if (cluster.fits(newPoint)) {\n                cluster.add(newPoint);\n                found = true;\n            }\n        }\n        return found;\n    }\n\n    // iterate over each cloud\n    for ( i = 0; i < points.length; i++) {\n        point = Cluster2.createPoint(points[i], i, property);\n        if (!addToCluster(point)) {\n            clusters.push(Cluster2.create(point, threshold));\n        }\n    }\n    return clusters;\n};\n\nexport const Tracer = {\n    trace: function(points, vec) {\n        var iteration, maxIterations = 10, top = [], result = [], centerPos = 0, currentPos = 0;\n\n        function trace(idx, forward) {\n            var from, to, toIdx, predictedPos, thresholdX = 1, thresholdY = Math.abs(vec[1] / 10), found = false;\n\n            function match(pos, predicted) {\n                if (pos.x > (predicted.x - thresholdX)\n                        && pos.x < (predicted.x + thresholdX)\n                        && pos.y > (predicted.y - thresholdY)\n                        && pos.y < (predicted.y + thresholdY)) {\n                    return true;\n                } else {\n                    return false;\n                }\n            }\n\n            // check if the next index is within the vec specifications\n            // if not, check as long as the threshold is met\n\n            from = points[idx];\n            if (forward) {\n                predictedPos = {\n                    x: from.x + vec[0],\n                    y: from.y + vec[1]\n                };\n            } else {\n                predictedPos = {\n                    x: from.x - vec[0],\n                    y: from.y - vec[1]\n                };\n            }\n\n            toIdx = forward ? idx + 1 : idx - 1;\n            to = points[toIdx];\n            while (to && ( found = match(to, predictedPos)) !== true && (Math.abs(to.y - from.y) < vec[1])) {\n                toIdx = forward ? toIdx + 1 : toIdx - 1;\n                to = points[toIdx];\n            }\n\n            return found ? toIdx : null;\n        }\n\n        for ( iteration = 0; iteration < maxIterations; iteration++) {\n            // randomly select point to start with\n            centerPos = Math.floor(Math.random() * points.length);\n\n            // trace forward\n            top = [];\n            currentPos = centerPos;\n            top.push(points[currentPos]);\n            while (( currentPos = trace(currentPos, true)) !== null) {\n                top.push(points[currentPos]);\n            }\n            if (centerPos > 0) {\n                currentPos = centerPos;\n                while (( currentPos = trace(currentPos, false)) !== null) {\n                    top.push(points[currentPos]);\n                }\n            }\n\n            if (top.length > result.length) {\n                result = top;\n            }\n        }\n        return result;\n    }\n};\n\nexport const DILATE = 1;\nexport const ERODE = 2;\n\nexport function dilate(inImageWrapper, outImageWrapper) {\n    var v,\n        u,\n        inImageData = inImageWrapper.data,\n        outImageData = outImageWrapper.data,\n        height = inImageWrapper.size.y,\n        width = inImageWrapper.size.x,\n        sum,\n        yStart1,\n        yStart2,\n        xStart1,\n        xStart2;\n\n    for ( v = 1; v < height - 1; v++) {\n        for ( u = 1; u < width - 1; u++) {\n            yStart1 = v - 1;\n            yStart2 = v + 1;\n            xStart1 = u - 1;\n            xStart2 = u + 1;\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] +\n            inImageData[v * width + u] +\n            inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\n            outImageData[v * width + u] = sum > 0 ? 1 : 0;\n        }\n    }\n};\n\nexport function erode(inImageWrapper, outImageWrapper) {\n    var v,\n        u,\n        inImageData = inImageWrapper.data,\n        outImageData = outImageWrapper.data,\n        height = inImageWrapper.size.y,\n        width = inImageWrapper.size.x,\n        sum,\n        yStart1,\n        yStart2,\n        xStart1,\n        xStart2;\n\n    for ( v = 1; v < height - 1; v++) {\n        for ( u = 1; u < width - 1; u++) {\n            yStart1 = v - 1;\n            yStart2 = v + 1;\n            xStart1 = u - 1;\n            xStart2 = u + 1;\n            sum = inImageData[yStart1 * width + xStart1] + inImageData[yStart1 * width + xStart2] +\n            inImageData[v * width + u] +\n            inImageData[yStart2 * width + xStart1] + inImageData[yStart2 * width + xStart2];\n            outImageData[v * width + u] = sum === 5 ? 1 : 0;\n        }\n    }\n};\n\nexport function subtract(aImageWrapper, bImageWrapper, resultImageWrapper) {\n    if (!resultImageWrapper) {\n        resultImageWrapper = aImageWrapper;\n    }\n    var length = aImageWrapper.data.length,\n        aImageData = aImageWrapper.data,\n        bImageData = bImageWrapper.data,\n        cImageData = resultImageWrapper.data;\n\n    while (length--) {\n        cImageData[length] = aImageData[length] - bImageData[length];\n    }\n};\n\nexport function bitwiseOr(aImageWrapper, bImageWrapper, resultImageWrapper) {\n    if (!resultImageWrapper) {\n        resultImageWrapper = aImageWrapper;\n    }\n    var length = aImageWrapper.data.length,\n        aImageData = aImageWrapper.data,\n        bImageData = bImageWrapper.data,\n        cImageData = resultImageWrapper.data;\n\n    while (length--) {\n        cImageData[length] = aImageData[length] || bImageData[length];\n    }\n};\n\nexport function countNonZero(imageWrapper) {\n    var length = imageWrapper.data.length, data = imageWrapper.data, sum = 0;\n\n    while (length--) {\n        sum += data[length];\n    }\n    return sum;\n};\n\nexport function topGeneric(list, top, scoreFunc) {\n    var i, minIdx = 0, min = 0, queue = [], score, hit, pos;\n\n    for ( i = 0; i < top; i++) {\n        queue[i] = {\n            score: 0,\n            item: null\n        };\n    }\n\n    for ( i = 0; i < list.length; i++) {\n        score = scoreFunc.apply(this, [list[i]]);\n        if (score > min) {\n            hit = queue[minIdx];\n            hit.score = score;\n            hit.item = list[i];\n            min = Number.MAX_VALUE;\n            for ( pos = 0; pos < top; pos++) {\n                if (queue[pos].score < min) {\n                    min = queue[pos].score;\n                    minIdx = pos;\n                }\n            }\n        }\n    }\n\n    return queue;\n};\n\nexport function grayArrayFromImage(htmlImage, offsetX, ctx, array) {\n    ctx.drawImage(htmlImage, offsetX, 0, htmlImage.width, htmlImage.height);\n    var ctxData = ctx.getImageData(offsetX, 0, htmlImage.width, htmlImage.height).data;\n    computeGray(ctxData, array);\n};\n\nexport function grayArrayFromContext(ctx, size, offset, array) {\n    var ctxData = ctx.getImageData(offset.x, offset.y, size.x, size.y).data;\n    computeGray(ctxData, array);\n};\n\nexport function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {\n    var topRowIdx = 0;\n    var bottomRowIdx = size.x;\n    var endIdx = Math.floor(canvasData.length / 4);\n    var outWidth = size.x / 2;\n    var outImgIdx = 0;\n    var inWidth = size.x;\n    var i;\n\n    while (bottomRowIdx < endIdx) {\n        for ( i = 0; i < outWidth; i++) {\n            outArray[outImgIdx] = (\n                (0.299 * canvasData[topRowIdx * 4 + 0] +\n                 0.587 * canvasData[topRowIdx * 4 + 1] +\n                 0.114 * canvasData[topRowIdx * 4 + 2]) +\n                (0.299 * canvasData[(topRowIdx + 1) * 4 + 0] +\n                 0.587 * canvasData[(topRowIdx + 1) * 4 + 1] +\n                 0.114 * canvasData[(topRowIdx + 1) * 4 + 2]) +\n                (0.299 * canvasData[(bottomRowIdx) * 4 + 0] +\n                 0.587 * canvasData[(bottomRowIdx) * 4 + 1] +\n                 0.114 * canvasData[(bottomRowIdx) * 4 + 2]) +\n                (0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] +\n                 0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] +\n                 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4;\n            outImgIdx++;\n            topRowIdx = topRowIdx + 2;\n            bottomRowIdx = bottomRowIdx + 2;\n        }\n        topRowIdx = topRowIdx + inWidth;\n        bottomRowIdx = bottomRowIdx + inWidth;\n    }\n};\n\nexport function computeGray(imageData, outArray, config) {\n    var l = (imageData.length / 4) | 0,\n        i,\n        singleChannel = config && config.singleChannel === true;\n\n    if (singleChannel) {\n        for (i = 0; i < l; i++) {\n            outArray[i] = imageData[i * 4 + 0];\n        }\n    } else {\n        for (i = 0; i < l; i++) {\n            outArray[i] =\n                0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2];\n        }\n    }\n};\n\nexport function loadImageArray(src, callback, canvas) {\n    if (!canvas) {\n        canvas = document.createElement('canvas');\n    }\n    var img = new Image();\n    img.callback = callback;\n    img.onload = function() {\n        canvas.width = this.width;\n        canvas.height = this.height;\n        var ctx = canvas.getContext('2d');\n        ctx.drawImage(this, 0, 0);\n        var array = new Uint8Array(this.width * this.height);\n        ctx.drawImage(this, 0, 0);\n        var data = ctx.getImageData(0, 0, this.width, this.height).data;\n        computeGray(data, array);\n        this.callback(array, {\n            x: this.width,\n            y: this.height\n        }, this);\n    };\n    img.src = src;\n};\n\n/**\n * @param inImg {ImageWrapper} input image to be sampled\n * @param outImg {ImageWrapper} to be stored in\n */\nexport function halfSample(inImgWrapper, outImgWrapper) {\n    var inImg = inImgWrapper.data;\n    var inWidth = inImgWrapper.size.x;\n    var outImg = outImgWrapper.data;\n    var topRowIdx = 0;\n    var bottomRowIdx = inWidth;\n    var endIdx = inImg.length;\n    var outWidth = inWidth / 2;\n    var outImgIdx = 0;\n    while (bottomRowIdx < endIdx) {\n        for (var i = 0; i < outWidth; i++) {\n            outImg[outImgIdx] = Math.floor(\n                (inImg[topRowIdx] + inImg[topRowIdx + 1] + inImg[bottomRowIdx] + inImg[bottomRowIdx + 1]) / 4);\n            outImgIdx++;\n            topRowIdx = topRowIdx + 2;\n            bottomRowIdx = bottomRowIdx + 2;\n        }\n        topRowIdx = topRowIdx + inWidth;\n        bottomRowIdx = bottomRowIdx + inWidth;\n    }\n};\n\nexport function hsv2rgb(hsv, rgb) {\n    var h = hsv[0],\n        s = hsv[1],\n        v = hsv[2],\n        c = v * s,\n        x = c * (1 - Math.abs((h / 60) % 2 - 1)),\n        m = v - c,\n        r = 0,\n        g = 0,\n        b = 0;\n\n    rgb = rgb || [0, 0, 0];\n\n    if (h < 60) {\n        r = c;\n        g = x;\n    } else if (h < 120) {\n        r = x;\n        g = c;\n    } else if (h < 180) {\n        g = c;\n        b = x;\n    } else if (h < 240) {\n        g = x;\n        b = c;\n    } else if (h < 300) {\n        r = x;\n        b = c;\n    } else if (h < 360) {\n        r = c;\n        b = x;\n    }\n    rgb[0] = ((r + m) * 255) | 0;\n    rgb[1] = ((g + m) * 255) | 0;\n    rgb[2] = ((b + m) * 255) | 0;\n    return rgb;\n};\n\nexport function _computeDivisors(n) {\n    var largeDivisors = [],\n        divisors = [],\n        i;\n\n    for (i = 1; i < Math.sqrt(n) + 1; i++) {\n        if (n % i === 0) {\n            divisors.push(i);\n            if (i !== n / i) {\n                largeDivisors.unshift(Math.floor(n / i));\n            }\n        }\n    }\n    return divisors.concat(largeDivisors);\n};\n\nfunction _computeIntersection(arr1, arr2) {\n    var i = 0,\n        j = 0,\n        result = [];\n\n    while (i < arr1.length && j < arr2.length) {\n        if (arr1[i] === arr2[j]) {\n            result.push(arr1[i]);\n            i++;\n            j++;\n        } else if (arr1[i] > arr2[j]) {\n            j++;\n        } else {\n            i++;\n        }\n    }\n    return result;\n};\n\nexport function calculatePatchSize(patchSize, imgSize) {\n    var divisorsX = _computeDivisors(imgSize.x),\n        divisorsY = _computeDivisors(imgSize.y),\n        wideSide = Math.max(imgSize.x, imgSize.y),\n        common = _computeIntersection(divisorsX, divisorsY),\n        nrOfPatchesList = [8, 10, 15, 20, 32, 60, 80],\n        nrOfPatchesMap = {\n            \"x-small\": 5,\n            \"small\": 4,\n            \"medium\": 3,\n            \"large\": 2,\n            \"x-large\": 1\n        },\n        nrOfPatchesIdx = nrOfPatchesMap[patchSize] || nrOfPatchesMap.medium,\n        nrOfPatches = nrOfPatchesList[nrOfPatchesIdx],\n        desiredPatchSize = Math.floor(wideSide / nrOfPatches),\n        optimalPatchSize;\n\n    function findPatchSizeForDivisors(divisors) {\n        var i = 0,\n            found = divisors[Math.floor(divisors.length / 2)];\n\n        while (i < (divisors.length - 1) && divisors[i] < desiredPatchSize) {\n            i++;\n        }\n        if (i > 0) {\n            if (Math.abs(divisors[i] - desiredPatchSize) > Math.abs(divisors[i - 1] - desiredPatchSize)) {\n                found = divisors[i - 1];\n            } else {\n                found = divisors[i];\n            }\n        }\n        if (desiredPatchSize / found < nrOfPatchesList[nrOfPatchesIdx + 1] / nrOfPatchesList[nrOfPatchesIdx] &&\n            desiredPatchSize / found > nrOfPatchesList[nrOfPatchesIdx - 1] / nrOfPatchesList[nrOfPatchesIdx] ) {\n            return {x: found, y: found};\n        }\n        return null;\n    }\n\n    optimalPatchSize = findPatchSizeForDivisors(common);\n    if (!optimalPatchSize) {\n        optimalPatchSize = findPatchSizeForDivisors(_computeDivisors(wideSide));\n        if (!optimalPatchSize) {\n            optimalPatchSize = findPatchSizeForDivisors((_computeDivisors(desiredPatchSize * nrOfPatches)));\n        }\n    }\n    return optimalPatchSize;\n};\n\nexport function _parseCSSDimensionValues(value) {\n    var dimension = {\n        value: parseFloat(value),\n        unit: value.indexOf(\"%\") === value.length - 1 ? \"%\" : \"%\"\n    };\n\n    return dimension;\n};\n\nexport const _dimensionsConverters = {\n    top: function(dimension, context) {\n        if (dimension.unit === \"%\") {\n            return Math.floor(context.height * (dimension.value / 100));\n        }\n    },\n    right: function(dimension, context) {\n        if (dimension.unit === \"%\") {\n            return Math.floor(context.width - (context.width * (dimension.value / 100)));\n        }\n    },\n    bottom: function(dimension, context) {\n        if (dimension.unit === \"%\") {\n            return Math.floor(context.height - (context.height * (dimension.value / 100)));\n        }\n    },\n    left: function(dimension, context) {\n        if (dimension.unit === \"%\") {\n            return Math.floor(context.width * (dimension.value / 100));\n        }\n    }\n};\n\nexport function computeImageArea(inputWidth, inputHeight, area) {\n    var context = {width: inputWidth, height: inputHeight};\n\n    var parsedArea = Object.keys(area).reduce(function(result, key) {\n        var value = area[key],\n            parsed = _parseCSSDimensionValues(value),\n            calculated = _dimensionsConverters[key](parsed, context);\n\n        result[key] = calculated;\n        return result;\n    }, {});\n\n    return {\n        sx: parsedArea.left,\n        sy: parsedArea.top,\n        sw: parsedArea.right - parsedArea.left,\n        sh: parsedArea.bottom - parsedArea.top\n    };\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/cv_utils.js","import SubImage from './subImage';\nimport {hsv2rgb} from '../common/cv_utils';\nimport ArrayHelper from '../common/array_helper';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n};\n\n/**\n * Represents a basic image combining the data and size.\n * In addition, some methods for manipulation are contained.\n * @param size {x,y} The size of the image in pixel\n * @param data {Array} If given, a flat array containing the pixel data\n * @param ArrayType {Type} If given, the desired DataType of the Array (may be typed/non-typed)\n * @param initialize {Boolean} Indicating if the array should be initialized on creation.\n * @returns {ImageWrapper}\n */\nfunction ImageWrapper(size, data, ArrayType, initialize) {\n    if (!data) {\n        if (ArrayType) {\n            this.data = new ArrayType(size.x * size.y);\n            if (ArrayType === Array && initialize) {\n                ArrayHelper.init(this.data, 0);\n            }\n        } else {\n            this.data = new Uint8Array(size.x * size.y);\n            if (Uint8Array === Array && initialize) {\n                ArrayHelper.init(this.data, 0);\n            }\n        }\n    } else {\n        this.data = data;\n    }\n    this.size = size;\n}\n\n/**\n * tests if a position is within the image with a given offset\n * @param imgRef {x, y} The location to test\n * @param border Number the padding value in pixel\n * @returns {Boolean} true if location inside the image's border, false otherwise\n * @see cvd/image.h\n */\nImageWrapper.prototype.inImageWithBorder = function(imgRef, border) {\n    return (imgRef.x >= border)\n        && (imgRef.y >= border)\n        && (imgRef.x < (this.size.x - border))\n        && (imgRef.y < (this.size.y - border));\n};\n\n/**\n * Performs bilinear sampling\n * @param inImg Image to extract sample from\n * @param x the x-coordinate\n * @param y the y-coordinate\n * @returns the sampled value\n * @see cvd/vision.h\n */\nImageWrapper.sample = function(inImg, x, y) {\n    var lx = Math.floor(x);\n    var ly = Math.floor(y);\n    var w = inImg.size.x;\n    var base = ly * inImg.size.x + lx;\n    var a = inImg.data[base + 0];\n    var b = inImg.data[base + 1];\n    var c = inImg.data[base + w];\n    var d = inImg.data[base + w + 1];\n    var e = a - b;\n    x -= lx;\n    y -= ly;\n\n    var result = Math.floor(x * (y * (e - c + d) - e) + y * (c - a) + a);\n    return result;\n};\n\n/**\n * Initializes a given array. Sets each element to zero.\n * @param array {Array} The array to initialize\n */\nImageWrapper.clearArray = function(array) {\n    var l = array.length;\n    while (l--) {\n        array[l] = 0;\n    }\n};\n\n/**\n * Creates a {SubImage} from the current image ({this}).\n * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner)\n * @param size {ImageRef} The size of the resulting image\n * @returns {SubImage} A shared part of the original image\n */\nImageWrapper.prototype.subImage = function(from, size) {\n    return new SubImage(from, size, this);\n};\n\n/**\n * Creates an {ImageWrapper) and copies the needed underlying image-data area\n * @param imageWrapper {ImageWrapper} The target {ImageWrapper} where the data should be copied\n * @param from {ImageRef} The location where to copy from (top-left location)\n */\nImageWrapper.prototype.subImageAsCopy = function(imageWrapper, from) {\n    var sizeY = imageWrapper.size.y, sizeX = imageWrapper.size.x;\n    var x, y;\n    for ( x = 0; x < sizeX; x++) {\n        for ( y = 0; y < sizeY; y++) {\n            imageWrapper.data[y * sizeX + x] = this.data[(from.y + y) * this.size.x + from.x + x];\n        }\n    }\n};\n\nImageWrapper.prototype.copyTo = function(imageWrapper) {\n    var length = this.data.length, srcData = this.data, dstData = imageWrapper.data;\n\n    while (length--) {\n        dstData[length] = srcData[length];\n    }\n};\n\n/**\n * Retrieves a given pixel position from the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @returns {Number} The grayscale value at the pixel-position\n */\nImageWrapper.prototype.get = function(x, y) {\n    return this.data[y * this.size.x + x];\n};\n\n/**\n * Retrieves a given pixel position from the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @returns {Number} The grayscale value at the pixel-position\n */\nImageWrapper.prototype.getSafe = function(x, y) {\n    var i;\n\n    if (!this.indexMapping) {\n        this.indexMapping = {\n            x: [],\n            y: []\n        };\n        for (i = 0; i < this.size.x; i++) {\n            this.indexMapping.x[i] = i;\n            this.indexMapping.x[i + this.size.x] = i;\n        }\n        for (i = 0; i < this.size.y; i++) {\n            this.indexMapping.y[i] = i;\n            this.indexMapping.y[i + this.size.y] = i;\n        }\n    }\n    return this.data[(this.indexMapping.y[y + this.size.y]) * this.size.x + this.indexMapping.x[x + this.size.x]];\n};\n\n/**\n * Sets a given pixel position in the image\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @param value {Number} The grayscale value to set\n * @returns {ImageWrapper} The Image itself (for possible chaining)\n */\nImageWrapper.prototype.set = function(x, y, value) {\n    this.data[y * this.size.x + x] = value;\n    return this;\n};\n\n/**\n * Sets the border of the image (1 pixel) to zero\n */\nImageWrapper.prototype.zeroBorder = function() {\n    var i, width = this.size.x, height = this.size.y, data = this.data;\n    for ( i = 0; i < width; i++) {\n        data[i] = data[(height - 1) * width + i] = 0;\n    }\n    for ( i = 1; i < height - 1; i++) {\n        data[i * width] = data[i * width + (width - 1)] = 0;\n    }\n};\n\n/**\n * Inverts a binary image in place\n */\nImageWrapper.prototype.invert = function() {\n    var data = this.data, length = data.length;\n\n    while (length--) {\n        data[length] = data[length] ? 0 : 1;\n    }\n};\n\nImageWrapper.prototype.convolve = function(kernel) {\n    var x, y, kx, ky, kSize = (kernel.length / 2) | 0, accu = 0;\n    for ( y = 0; y < this.size.y; y++) {\n        for ( x = 0; x < this.size.x; x++) {\n            accu = 0;\n            for ( ky = -kSize; ky <= kSize; ky++) {\n                for ( kx = -kSize; kx <= kSize; kx++) {\n                    accu += kernel[ky + kSize][kx + kSize] * this.getSafe(x + kx, y + ky);\n                }\n            }\n            this.data[y * this.size.x + x] = accu;\n        }\n    }\n};\n\nImageWrapper.prototype.moments = function(labelcount) {\n    var data = this.data,\n        x,\n        y,\n        height = this.size.y,\n        width = this.size.x,\n        val,\n        ysq,\n        labelsum = [],\n        i,\n        label,\n        mu11,\n        mu02,\n        mu20,\n        x_,\n        y_,\n        tmp,\n        result = [],\n        PI = Math.PI,\n        PI_4 = PI / 4;\n\n    if (labelcount <= 0) {\n        return result;\n    }\n\n    for ( i = 0; i < labelcount; i++) {\n        labelsum[i] = {\n            m00: 0,\n            m01: 0,\n            m10: 0,\n            m11: 0,\n            m02: 0,\n            m20: 0,\n            theta: 0,\n            rad: 0\n        };\n    }\n\n    for ( y = 0; y < height; y++) {\n        ysq = y * y;\n        for ( x = 0; x < width; x++) {\n            val = data[y * width + x];\n            if (val > 0) {\n                label = labelsum[val - 1];\n                label.m00 += 1;\n                label.m01 += y;\n                label.m10 += x;\n                label.m11 += x * y;\n                label.m02 += ysq;\n                label.m20 += x * x;\n            }\n        }\n    }\n\n    for ( i = 0; i < labelcount; i++) {\n        label = labelsum[i];\n        if (!isNaN(label.m00) && label.m00 !== 0) {\n            x_ = label.m10 / label.m00;\n            y_ = label.m01 / label.m00;\n            mu11 = label.m11 / label.m00 - x_ * y_;\n            mu02 = label.m02 / label.m00 - y_ * y_;\n            mu20 = label.m20 / label.m00 - x_ * x_;\n            tmp = (mu02 - mu20) / (2 * mu11);\n            tmp = 0.5 * Math.atan(tmp) + (mu11 >= 0 ? PI_4 : -PI_4 ) + PI;\n            label.theta = (tmp * 180 / PI + 90) % 180 - 90;\n            if (label.theta < 0) {\n                label.theta += 180;\n            }\n            label.rad = tmp > PI ? tmp - PI : tmp;\n            label.vec = vec2.clone([Math.cos(tmp), Math.sin(tmp)]);\n            result.push(label);\n        }\n    }\n\n    return result;\n};\n\n/**\n * Displays the {ImageWrapper} in a given canvas\n * @param canvas {Canvas} The canvas element to write to\n * @param scale {Number} Scale which is applied to each pixel-value\n */\nImageWrapper.prototype.show = function(canvas, scale) {\n    var ctx,\n        frame,\n        data,\n        current,\n        pixel,\n        x,\n        y;\n\n    if (!scale) {\n        scale = 1.0;\n    }\n    ctx = canvas.getContext('2d');\n    canvas.width = this.size.x;\n    canvas.height = this.size.y;\n    frame = ctx.getImageData(0, 0, canvas.width, canvas.height);\n    data = frame.data;\n    current = 0;\n    for (y = 0; y < this.size.y; y++) {\n        for (x = 0; x < this.size.x; x++) {\n            pixel = y * this.size.x + x;\n            current = this.get(x, y) * scale;\n            data[pixel * 4 + 0] = current;\n            data[pixel * 4 + 1] = current;\n            data[pixel * 4 + 2] = current;\n            data[pixel * 4 + 3] = 255;\n        }\n    }\n    //frame.data = data;\n    ctx.putImageData(frame, 0, 0);\n};\n\n/**\n * Displays the {SubImage} in a given canvas\n * @param canvas {Canvas} The canvas element to write to\n * @param scale {Number} Scale which is applied to each pixel-value\n */\nImageWrapper.prototype.overlay = function(canvas, scale, from) {\n    if (!scale || scale < 0 || scale > 360) {\n        scale = 360;\n    }\n    var hsv = [0, 1, 1];\n    var rgb = [0, 0, 0];\n    var whiteRgb = [255, 255, 255];\n    var blackRgb = [0, 0, 0];\n    var result = [];\n    var ctx = canvas.getContext('2d');\n    var frame = ctx.getImageData(from.x, from.y, this.size.x, this.size.y);\n    var data = frame.data;\n    var length = this.data.length;\n    while (length--) {\n        hsv[0] = this.data[length] * scale;\n        result = hsv[0] <= 0 ? whiteRgb : hsv[0] >= 360 ? blackRgb : hsv2rgb(hsv, rgb);\n        data[length * 4 + 0] = result[0];\n        data[length * 4 + 1] = result[1];\n        data[length * 4 + 2] = result[2];\n        data[length * 4 + 3] = 255;\n    }\n    ctx.putImageData(frame, from.x, from.y);\n};\n\nexport default ImageWrapper;\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/image_wrapper.js","var defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n  if (key == '__proto__' && defineProperty) {\n    defineProperty(object, key, {\n      'configurable': true,\n      'enumerable': true,\n      'value': value,\n      'writable': true\n    });\n  } else {\n    object[key] = value;\n  }\n}\n\nmodule.exports = baseAssignValue;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseAssignValue.js\n// module id = 21\n// module chunks = 0","var baseIsNative = require('./_baseIsNative'),\n    getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n  var value = getValue(object, key);\n  return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getNative.js\n// module id = 22\n// module chunks = 0","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n  if (typeof value == 'string' || isSymbol(value)) {\n    return value;\n  }\n  var result = (value + '');\n  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_toKey.js\n// module id = 23\n// module chunks = 0","var isFunction = require('./isFunction'),\n    isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArrayLike.js\n// module id = 24\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  if (!isObject(value)) {\n    return false;\n  }\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 9 which returns 'object' for typed arrays and other constructors.\n  var tag = baseGetTag(value);\n  return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isFunction.js\n// module id = 25\n// module chunks = 0","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n  return typeof value == 'number' &&\n    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isLength.js\n// module id = 26\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n  return typeof value == 'symbol' ||\n    (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isSymbol.js\n// module id = 27\n// module chunks = 0","var baseMerge = require('./_baseMerge'),\n    createAssigner = require('./_createAssigner');\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n *   'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n *   'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\nvar merge = createAssigner(function(object, source, srcIndex) {\n  baseMerge(object, source, srcIndex);\n});\n\nmodule.exports = merge;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/merge.js\n// module id = 28\n// module chunks = 0","module.exports = function(module) {\r\n\tif(!module.webpackPolyfill) {\r\n\t\tmodule.deprecate = function() {};\r\n\t\tmodule.paths = [];\r\n\t\t// module.parent = undefined by default\r\n\t\tif(!module.children) module.children = [];\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.l;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.i;\r\n\t\t\t}\r\n\t\t});\r\n\t\tmodule.webpackPolyfill = 1;\r\n\t}\r\n\treturn module;\r\n};\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/module.js\n// module id = 29\n// module chunks = 0","/**\n * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\n */\nvar Tracer = {\n    searchDirections: [[0, 1], [1, 1], [1, 0], [1, -1], [0, -1], [-1, -1], [-1, 0], [-1, 1]],\n    create: function(imageWrapper, labelWrapper) {\n        var imageData = imageWrapper.data,\n            labelData = labelWrapper.data,\n            searchDirections = this.searchDirections,\n            width = imageWrapper.size.x,\n            pos;\n\n        function trace(current, color, label, edgelabel) {\n            var i,\n                y,\n                x;\n\n            for ( i = 0; i < 7; i++) {\n                y = current.cy + searchDirections[current.dir][0];\n                x = current.cx + searchDirections[current.dir][1];\n                pos = y * width + x;\n                if ((imageData[pos] === color) && ((labelData[pos] === 0) || (labelData[pos] === label))) {\n                    labelData[pos] = label;\n                    current.cy = y;\n                    current.cx = x;\n                    return true;\n                } else {\n                    if (labelData[pos] === 0) {\n                        labelData[pos] = edgelabel;\n                    }\n                    current.dir = (current.dir + 1) % 8;\n                }\n            }\n            return false;\n        }\n\n        function vertex2D(x, y, dir) {\n            return {\n                dir: dir,\n                x: x,\n                y: y,\n                next: null,\n                prev: null\n            };\n        }\n\n        function contourTracing(sy, sx, label, color, edgelabel) {\n            var Fv = null,\n                Cv,\n                P,\n                ldir,\n                current = {\n                    cx: sx,\n                    cy: sy,\n                    dir: 0\n                };\n\n            if (trace(current, color, label, edgelabel)) {\n                Fv = vertex2D(sx, sy, current.dir);\n                Cv = Fv;\n                ldir = current.dir;\n                P = vertex2D(current.cx, current.cy, 0);\n                P.prev = Cv;\n                Cv.next = P;\n                P.next = null;\n                Cv = P;\n                do {\n                    current.dir = (current.dir + 6) % 8;\n                    trace(current, color, label, edgelabel);\n                    if (ldir !== current.dir) {\n                        Cv.dir = current.dir;\n                        P = vertex2D(current.cx, current.cy, 0);\n                        P.prev = Cv;\n                        Cv.next = P;\n                        P.next = null;\n                        Cv = P;\n                    } else {\n                        Cv.dir = ldir;\n                        Cv.x = current.cx;\n                        Cv.y = current.cy;\n                    }\n                    ldir = current.dir;\n                } while (current.cx !== sx || current.cy !== sy);\n                Fv.prev = Cv.prev;\n                Cv.prev.next = Fv;\n            }\n            return Fv;\n        }\n\n        return {\n            trace: function(current, color, label, edgelabel) {\n                return trace(current, color, label, edgelabel);\n            },\n            contourTracing: function(sy, sx, label, color, edgelabel) {\n                return contourTracing(sy, sx, label, color, edgelabel);\n            }\n        };\n    }\n};\n\nexport default (Tracer);\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/tracer.js","import BarcodeReader from './barcode_reader';\nimport ArrayHelper from '../common/array_helper';\n\nfunction Code39Reader() {\n    BarcodeReader.call(this);\n}\n\nvar properties = {\n    ALPHABETH_STRING: {value: \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%\"},\n    ALPHABET: {value: [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78,\n        79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 45, 46, 32, 42, 36, 47, 43, 37]},\n    CHARACTER_ENCODINGS: {value: [0x034, 0x121, 0x061, 0x160, 0x031, 0x130, 0x070, 0x025, 0x124, 0x064, 0x109, 0x049,\n        0x148, 0x019, 0x118, 0x058, 0x00D, 0x10C, 0x04C, 0x01C, 0x103, 0x043, 0x142, 0x013, 0x112, 0x052, 0x007, 0x106,\n        0x046, 0x016, 0x181, 0x0C1, 0x1C0, 0x091, 0x190, 0x0D0, 0x085, 0x184, 0x0C4, 0x094, 0x0A8, 0x0A2, 0x08A, 0x02A\n    ]},\n    ASTERISK: {value: 0x094},\n    FORMAT: {value: \"code_39\", writeable: false}\n};\n\nCode39Reader.prototype = Object.create(BarcodeReader.prototype, properties);\nCode39Reader.prototype.constructor = Code39Reader;\n\nCode39Reader.prototype._decode = function() {\n    var self = this,\n        counters = [0, 0, 0, 0, 0, 0, 0, 0, 0],\n        result = [],\n        start = self._findStart(),\n        decodedChar,\n        lastStart,\n        pattern,\n        nextStart;\n\n    if (!start) {\n        return null;\n    }\n    nextStart = self._nextSet(self._row, start.end);\n\n    do {\n        counters = self._toCounters(nextStart, counters);\n        pattern = self._toPattern(counters);\n        if (pattern < 0) {\n            return null;\n        }\n        decodedChar = self._patternToChar(pattern);\n        if (decodedChar < 0){\n            return null;\n        }\n        result.push(decodedChar);\n        lastStart = nextStart;\n        nextStart += ArrayHelper.sum(counters);\n        nextStart = self._nextSet(self._row, nextStart);\n    } while (decodedChar !== '*');\n    result.pop();\n\n    if (!result.length) {\n        return null;\n    }\n\n    if (!self._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\nCode39Reader.prototype._verifyTrailingWhitespace = function(lastStart, nextStart, counters) {\n    var trailingWhitespaceEnd,\n        patternSize = ArrayHelper.sum(counters);\n\n    trailingWhitespaceEnd = nextStart - lastStart - patternSize;\n    if ((trailingWhitespaceEnd * 3) >= patternSize) {\n        return true;\n    }\n    return false;\n};\n\nCode39Reader.prototype._patternToChar = function(pattern) {\n    var i,\n        self = this;\n\n    for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {\n        if (self.CHARACTER_ENCODINGS[i] === pattern) {\n            return String.fromCharCode(self.ALPHABET[i]);\n        }\n    }\n    return -1;\n};\n\nCode39Reader.prototype._findNextWidth = function(counters, current) {\n    var i,\n        minWidth = Number.MAX_VALUE;\n\n    for (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\nCode39Reader.prototype._toPattern = function(counters) {\n    var numCounters = counters.length,\n        maxNarrowWidth = 0,\n        numWideBars = numCounters,\n        wideBarWidth = 0,\n        self = this,\n        pattern,\n        i;\n\n    while (numWideBars > 3) {\n        maxNarrowWidth = self._findNextWidth(counters, maxNarrowWidth);\n        numWideBars = 0;\n        pattern = 0;\n        for (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 (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\nCode39Reader.prototype._findStart = function() {\n    var self = this,\n        offset = self._nextSet(self._row),\n        patternStart = offset,\n        counter = [0, 0, 0, 0, 0, 0, 0, 0, 0],\n        counterPos = 0,\n        isWhite = false,\n        i,\n        j,\n        whiteSpaceMustStart;\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                // find start pattern\n                if (self._toPattern(counter) === self.ASTERISK) {\n                    whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - ((i - patternStart) / 4)));\n                    if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) {\n                        return {\n                            start: patternStart,\n                            end: i\n                        };\n                    }\n                }\n\n                patternStart += counter[0] + counter[1];\n                for ( j = 0; j < 7; j++) {\n                    counter[j] = counter[j + 2];\n                }\n                counter[7] = 0;\n                counter[8] = 0;\n                counterPos--;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nexport default Code39Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_39_reader.js","module.exports = dot\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nfunction dot(a, b) {\n    return a[0] * b[0] + a[1] * b[1]\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/dot.js\n// module id = 32\n// module chunks = 0","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Map.js\n// module id = 33\n// module chunks = 0","var mapCacheClear = require('./_mapCacheClear'),\n    mapCacheDelete = require('./_mapCacheDelete'),\n    mapCacheGet = require('./_mapCacheGet'),\n    mapCacheHas = require('./_mapCacheHas'),\n    mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_MapCache.js\n// module id = 34\n// module chunks = 0","var baseAssignValue = require('./_baseAssignValue'),\n    eq = require('./eq');\n\n/**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignMergeValue(object, key, value) {\n  if ((value !== undefined && !eq(object[key], value)) ||\n      (value === undefined && !(key in object))) {\n    baseAssignValue(object, key, value);\n  }\n}\n\nmodule.exports = assignMergeValue;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assignMergeValue.js\n// module id = 35\n// module chunks = 0","var baseAssignValue = require('./_baseAssignValue'),\n    eq = require('./eq');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n  var objValue = object[key];\n  if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n      (value === undefined && !(key in object))) {\n    baseAssignValue(object, key, value);\n  }\n}\n\nmodule.exports = assignValue;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_assignValue.js\n// module id = 36\n// module chunks = 0","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n  try {\n    var func = getNative(Object, 'defineProperty');\n    func({}, '', {});\n    return func;\n  } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_defineProperty.js\n// module id = 37\n// module chunks = 0","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_freeGlobal.js\n// module id = 38\n// module chunks = 0","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getPrototype.js\n// module id = 39\n// module chunks = 0","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\nmodule.exports = isPrototype;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isPrototype.js\n// module id = 40\n// module chunks = 0","var apply = require('./_apply');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\nfunction overRest(func, start, transform) {\n  start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n  return function() {\n    var args = arguments,\n        index = -1,\n        length = nativeMax(args.length - start, 0),\n        array = Array(length);\n\n    while (++index < length) {\n      array[index] = args[start + index];\n    }\n    index = -1;\n    var otherArgs = Array(start + 1);\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = transform(array);\n    return apply(func, this, otherArgs);\n  };\n}\n\nmodule.exports = overRest;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_overRest.js\n// module id = 41\n// module chunks = 0","var baseSetToString = require('./_baseSetToString'),\n    shortOut = require('./_shortOut');\n\n/**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar setToString = shortOut(baseSetToString);\n\nmodule.exports = setToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_setToString.js\n// module id = 42\n// module chunks = 0","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n  return value;\n}\n\nmodule.exports = identity;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/identity.js\n// module id = 43\n// module chunks = 0","var root = require('./_root'),\n    stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isBuffer.js\n// module id = 44\n// module chunks = 0","var baseIsTypedArray = require('./_baseIsTypedArray'),\n    baseUnary = require('./_baseUnary'),\n    nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isTypedArray.js\n// module id = 45\n// module chunks = 0","var arrayLikeKeys = require('./_arrayLikeKeys'),\n    baseKeysIn = require('./_baseKeysIn'),\n    isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nmodule.exports = keysIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/keysIn.js\n// module id = 46\n// module chunks = 0","var g;\r\n\r\n// This works in non-strict mode\r\ng = (function() {\r\n\treturn this;\r\n})();\r\n\r\ntry {\r\n\t// This works if eval is allowed (see CSP)\r\n\tg = g || Function(\"return this\")() || (1,eval)(\"this\");\r\n} catch(e) {\r\n\t// This works if the window reference is available\r\n\tif(typeof window === \"object\")\r\n\t\tg = window;\r\n}\r\n\r\n// g can still be undefined, but nothing to do about it...\r\n// We return undefined, instead of nothing here, so it's\r\n// easier to handle this case. if(!global) { ...}\r\n\r\nmodule.exports = g;\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/global.js\n// module id = 47\n// module chunks = 0","import TypeDefs from './common/typedefs'; // eslint-disable-line no-unused-vars\nimport ImageWrapper from './common/image_wrapper';\nimport BarcodeLocator from './locator/barcode_locator';\nimport BarcodeDecoder from './decoder/barcode_decoder';\nimport Events from './common/events';\nimport CameraAccess from './input/camera_access';\nimport ImageDebug from './common/image_debug';\nimport ResultCollector from './analytics/result_collector';\nimport Config from './config/config';\nimport InputStream from 'input_stream';\nimport FrameGrabber from 'frame_grabber';\nimport {merge} from 'lodash';\nconst vec2 = {\n    clone: require('gl-vec2/clone')\n};\n\nvar _inputStream,\n    _framegrabber,\n    _stopped,\n    _canvasContainer = {\n        ctx: {\n            image: null,\n            overlay: null\n        },\n        dom: {\n            image: null,\n            overlay: null\n        }\n    },\n    _inputImageWrapper,\n    _boxSize,\n    _decoder,\n    _workerPool = [],\n    _onUIThread = true,\n    _resultCollector,\n    _config = {};\n\nfunction initializeData(imageWrapper) {\n    initBuffers(imageWrapper);\n    _decoder = BarcodeDecoder.create(_config.decoder, _inputImageWrapper);\n}\n\nfunction initInputStream(cb) {\n    var video;\n    if (_config.inputStream.type === \"VideoStream\") {\n        video = document.createElement(\"video\");\n        _inputStream = InputStream.createVideoStream(video);\n    } else if (_config.inputStream.type === \"ImageStream\") {\n        _inputStream = InputStream.createImageStream();\n    } else if (_config.inputStream.type === \"LiveStream\") {\n        var $viewport = getViewPort();\n        if ($viewport) {\n            video = $viewport.querySelector(\"video\");\n            if (!video) {\n                video = document.createElement(\"video\");\n                $viewport.appendChild(video);\n            }\n        }\n        _inputStream = InputStream.createLiveStream(video);\n        CameraAccess.request(video, _config.inputStream.constraints)\n        .then(() => {\n            _inputStream.trigger(\"canrecord\");\n        }).catch((err) => {\n            return cb(err);\n        });\n    }\n\n    _inputStream.setAttribute(\"preload\", \"auto\");\n    _inputStream.setInputStream(_config.inputStream);\n    _inputStream.addEventListener(\"canrecord\", canRecord.bind(undefined, cb));\n}\n\nfunction getViewPort() {\n    var target = _config.inputStream.target;\n    // Check if target is already a DOM element\n    if (target && target.nodeName && target.nodeType === 1) {\n        return target;\n    } else {\n        // Use '#interactive.viewport' as a fallback selector (backwards compatibility)\n        var selector = typeof target === 'string' ? target : '#interactive.viewport';\n        return document.querySelector(selector);\n    }\n}\n\nfunction canRecord(cb) {\n    BarcodeLocator.checkImageConstraints(_inputStream, _config.locator);\n    initCanvas(_config);\n    _framegrabber = FrameGrabber.create(_inputStream, _canvasContainer.dom.image);\n\n    adjustWorkerPool(_config.numOfWorkers, function() {\n        if (_config.numOfWorkers === 0) {\n            initializeData();\n        }\n        ready(cb);\n    });\n}\n\nfunction ready(cb){\n    _inputStream.play();\n    cb();\n}\n\nfunction initCanvas() {\n    if (typeof document !== \"undefined\") {\n        var $viewport = getViewPort();\n        _canvasContainer.dom.image = document.querySelector(\"canvas.imgBuffer\");\n        if (!_canvasContainer.dom.image) {\n            _canvasContainer.dom.image = document.createElement(\"canvas\");\n            _canvasContainer.dom.image.className = \"imgBuffer\";\n            if ($viewport && _config.inputStream.type === \"ImageStream\") {\n                $viewport.appendChild(_canvasContainer.dom.image);\n            }\n        }\n        _canvasContainer.ctx.image = _canvasContainer.dom.image.getContext(\"2d\");\n        _canvasContainer.dom.image.width = _inputStream.getCanvasSize().x;\n        _canvasContainer.dom.image.height = _inputStream.getCanvasSize().y;\n\n        _canvasContainer.dom.overlay = document.querySelector(\"canvas.drawingBuffer\");\n        if (!_canvasContainer.dom.overlay) {\n            _canvasContainer.dom.overlay = document.createElement(\"canvas\");\n            _canvasContainer.dom.overlay.className = \"drawingBuffer\";\n            if ($viewport) {\n                $viewport.appendChild(_canvasContainer.dom.overlay);\n            }\n            var clearFix = document.createElement(\"br\");\n            clearFix.setAttribute(\"clear\", \"all\");\n            if ($viewport) {\n                $viewport.appendChild(clearFix);\n            }\n        }\n        _canvasContainer.ctx.overlay = _canvasContainer.dom.overlay.getContext(\"2d\");\n        _canvasContainer.dom.overlay.width = _inputStream.getCanvasSize().x;\n        _canvasContainer.dom.overlay.height = _inputStream.getCanvasSize().y;\n    }\n}\n\nfunction initBuffers(imageWrapper) {\n    if (imageWrapper) {\n        _inputImageWrapper = imageWrapper;\n    } else {\n        _inputImageWrapper = new ImageWrapper({\n            x: _inputStream.getWidth(),\n            y: _inputStream.getHeight()\n        });\n    }\n\n    if (ENV.development) {\n        console.log(_inputImageWrapper.size);\n    }\n    _boxSize = [\n        vec2.clone([0, 0]),\n        vec2.clone([0, _inputImageWrapper.size.y]),\n        vec2.clone([_inputImageWrapper.size.x, _inputImageWrapper.size.y]),\n        vec2.clone([_inputImageWrapper.size.x, 0])\n    ];\n    BarcodeLocator.init(_inputImageWrapper, _config.locator);\n}\n\nfunction getBoundingBoxes() {\n    if (_config.locate) {\n        return BarcodeLocator.locate();\n    } else {\n        return [[\n            vec2.clone(_boxSize[0]),\n            vec2.clone(_boxSize[1]),\n            vec2.clone(_boxSize[2]),\n            vec2.clone(_boxSize[3])]];\n    }\n}\n\nfunction transformResult(result) {\n    var topRight = _inputStream.getTopRight(),\n        xOffset = topRight.x,\n        yOffset = topRight.y,\n        i;\n\n    if (xOffset === 0 && yOffset === 0) {\n        return;\n    }\n\n    if (result.barcodes) {\n        for (i = 0; i < result.barcodes.length; i++) {\n            transformResult(result.barcodes[i]);\n        }\n    }\n\n    if (result.line && result.line.length === 2) {\n        moveLine(result.line);\n    }\n\n    if (result.box) {\n        moveBox(result.box);\n    }\n\n    if (result.boxes && result.boxes.length > 0) {\n        for (i = 0; i < result.boxes.length; i++) {\n            moveBox(result.boxes[i]);\n        }\n    }\n\n    function moveBox(box) {\n        var corner = box.length;\n\n        while (corner--) {\n            box[corner][0] += xOffset;\n            box[corner][1] += yOffset;\n        }\n    }\n\n    function moveLine(line) {\n        line[0].x += xOffset;\n        line[0].y += yOffset;\n        line[1].x += xOffset;\n        line[1].y += yOffset;\n    }\n}\n\nfunction addResult (result, imageData) {\n    if (!imageData || !_resultCollector) {\n        return;\n    }\n\n    if (result.barcodes) {\n        result.barcodes.filter(barcode => barcode.codeResult)\n            .forEach(barcode => addResult(barcode, imageData));\n    } else if (result.codeResult) {\n        _resultCollector.addResult(imageData, _inputStream.getCanvasSize(), result.codeResult);\n    }\n}\n\nfunction hasCodeResult (result) {\n    return result && (result.barcodes ?\n      result.barcodes.some(barcode => barcode.codeResult) :\n      result.codeResult);\n}\n\nfunction publishResult(result, imageData) {\n    let resultToPublish = result;\n\n    if (result && _onUIThread) {\n        transformResult(result);\n        addResult(result, imageData);\n        resultToPublish = result.barcodes || result;\n    }\n\n    Events.publish(\"processed\", resultToPublish);\n    if (hasCodeResult(result)) {\n        Events.publish(\"detected\", resultToPublish);\n    }\n}\n\nfunction locateAndDecode() {\n    var result,\n        boxes;\n\n    boxes = getBoundingBoxes();\n    if (boxes) {\n        result = _decoder.decodeFromBoundingBoxes(boxes);\n        result = result || {};\n        result.boxes = boxes;\n        publishResult(result, _inputImageWrapper.data);\n    } else {\n        publishResult();\n    }\n}\n\nfunction update() {\n    var availableWorker;\n\n    if (_onUIThread) {\n        if (_workerPool.length > 0) {\n            availableWorker = _workerPool.filter(function(workerThread) {\n                return !workerThread.busy;\n            })[0];\n            if (availableWorker) {\n                _framegrabber.attachData(availableWorker.imageData);\n            } else {\n                return; // all workers are busy\n            }\n        } else {\n            _framegrabber.attachData(_inputImageWrapper.data);\n        }\n        if (_framegrabber.grab()) {\n            if (availableWorker) {\n                availableWorker.busy = true;\n                availableWorker.worker.postMessage({\n                    cmd: 'process',\n                    imageData: availableWorker.imageData\n                }, [availableWorker.imageData.buffer]);\n            } else {\n                locateAndDecode();\n            }\n        }\n    } else {\n        locateAndDecode();\n    }\n}\n\nfunction startContinuousUpdate() {\n    var next = null,\n        delay = 1000 / (_config.frequency || 60);\n\n    _stopped = false;\n    (function frame(timestamp) {\n        next = next || timestamp;\n        if (!_stopped) {\n            if (timestamp >= next) {\n                next += delay;\n                update();\n            }\n            window.requestAnimFrame(frame);\n        }\n    }(performance.now()));\n}\n\nfunction start() {\n    if (_onUIThread && _config.inputStream.type === \"LiveStream\") {\n        startContinuousUpdate();\n    } else {\n        update();\n    }\n}\n\nfunction initWorker(cb) {\n    var blobURL,\n        workerThread = {\n            worker: undefined,\n            imageData: new Uint8Array(_inputStream.getWidth() * _inputStream.getHeight()),\n            busy: true\n        };\n\n    blobURL = generateWorkerBlob();\n    workerThread.worker = new Worker(blobURL);\n\n    workerThread.worker.onmessage = function(e) {\n        if (e.data.event === 'initialized') {\n            URL.revokeObjectURL(blobURL);\n            workerThread.busy = false;\n            workerThread.imageData = new Uint8Array(e.data.imageData);\n            if (ENV.development) {\n                console.log(\"Worker initialized\");\n            }\n            return cb(workerThread);\n        } else if (e.data.event === 'processed') {\n            workerThread.imageData = new Uint8Array(e.data.imageData);\n            workerThread.busy = false;\n            publishResult(e.data.result, workerThread.imageData);\n        } else if (e.data.event === 'error') {\n            if (ENV.development) {\n                console.log(\"Worker error: \" + e.data.message);\n            }\n        }\n    };\n\n    workerThread.worker.postMessage({\n        cmd: 'init',\n        size: {x: _inputStream.getWidth(), y: _inputStream.getHeight()},\n        imageData: workerThread.imageData,\n        config: configForWorker(_config)\n    }, [workerThread.imageData.buffer]);\n}\n\nfunction configForWorker(config) {\n    return {\n        ...config,\n        inputStream: {\n            ...config.inputStream,\n            target: null\n        }\n    };\n}\n\nfunction workerInterface(factory) {\n    /* eslint-disable no-undef*/\n    if (factory) {\n        var Quagga = factory().default;\n        if (!Quagga) {\n            self.postMessage({'event': 'error', message: 'Quagga could not be created'});\n            return;\n        }\n    }\n    var imageWrapper;\n\n    self.onmessage = function(e) {\n        if (e.data.cmd === 'init') {\n            var config = e.data.config;\n            config.numOfWorkers = 0;\n            imageWrapper = new Quagga.ImageWrapper({\n                x: e.data.size.x,\n                y: e.data.size.y\n            }, new Uint8Array(e.data.imageData));\n            Quagga.init(config, ready, imageWrapper);\n            Quagga.onProcessed(onProcessed);\n        } else if (e.data.cmd === 'process') {\n            imageWrapper.data = new Uint8Array(e.data.imageData);\n            Quagga.start();\n        } else if (e.data.cmd === 'setReaders') {\n            Quagga.setReaders(e.data.readers);\n        }\n    };\n\n    function onProcessed(result) {\n        self.postMessage({\n            'event': 'processed',\n            imageData: imageWrapper.data,\n            result: result\n        }, [imageWrapper.data.buffer]);\n    }\n\n    function ready() { // eslint-disable-line\n        self.postMessage({'event': 'initialized', imageData: imageWrapper.data}, [imageWrapper.data.buffer]);\n    }\n\n    /* eslint-enable */\n}\n\nfunction generateWorkerBlob() {\n    var blob,\n        factorySource;\n\n    /* jshint ignore:start */\n    if (typeof __factorySource__ !== 'undefined') {\n        factorySource = __factorySource__; // eslint-disable-line no-undef\n    }\n    /* jshint ignore:end */\n\n    blob = new Blob(['(' + workerInterface.toString() + ')(' + factorySource + ');'],\n        {type: 'text/javascript'});\n\n    return window.URL.createObjectURL(blob);\n}\n\nfunction setReaders(readers) {\n    if (_decoder) {\n        _decoder.setReaders(readers);\n    } else if (_onUIThread && _workerPool.length > 0) {\n        _workerPool.forEach(function(workerThread) {\n            workerThread.worker.postMessage({cmd: 'setReaders', readers: readers});\n        });\n    }\n}\n\nfunction adjustWorkerPool(capacity, cb) {\n    const increaseBy = capacity - _workerPool.length;\n    if (increaseBy === 0) {\n        return cb && cb();\n    }\n    if (increaseBy < 0) {\n        const workersToTerminate = _workerPool.slice(increaseBy);\n        workersToTerminate.forEach(function(workerThread) {\n            workerThread.worker.terminate();\n            if (ENV.development) {\n                console.log(\"Worker terminated!\");\n            }\n        });\n        _workerPool = _workerPool.slice(0, increaseBy);\n        return cb && cb();\n    } else {\n        for (var i = 0; i < increaseBy; i++) {\n            initWorker(workerInitialized);\n        }\n\n        function workerInitialized(workerThread) {\n            _workerPool.push(workerThread);\n            if (_workerPool.length >= capacity){\n                cb && cb();\n            }\n        }\n    }\n}\n\nexport default {\n    init: function(config, cb, imageWrapper) {\n        _config = merge({}, Config, config);\n        if (imageWrapper) {\n            _onUIThread = false;\n            initializeData(imageWrapper);\n            return cb();\n        } else {\n            initInputStream(cb);\n        }\n    },\n    start: function() {\n        start();\n    },\n    stop: function() {\n        _stopped = true;\n        adjustWorkerPool(0);\n        if (_config.inputStream.type === \"LiveStream\") {\n            CameraAccess.release();\n            _inputStream.clearEventHandlers();\n        }\n    },\n    pause: function() {\n        _stopped = true;\n    },\n    onDetected: function(callback) {\n        Events.subscribe(\"detected\", callback);\n    },\n    offDetected: function(callback) {\n        Events.unsubscribe(\"detected\", callback);\n    },\n    onProcessed: function(callback) {\n        Events.subscribe(\"processed\", callback);\n    },\n    offProcessed: function(callback) {\n        Events.unsubscribe(\"processed\", callback);\n    },\n    setReaders: function(readers) {\n        setReaders(readers);\n    },\n    registerResultCollector: function(resultCollector) {\n        if (resultCollector && typeof resultCollector.addResult === 'function') {\n            _resultCollector = resultCollector;\n        }\n    },\n    canvas: _canvasContainer,\n    decodeSingle: function(config, resultCallback) {\n        config = merge({\n            inputStream: {\n                type: \"ImageStream\",\n                sequence: false,\n                size: 800,\n                src: config.src\n            },\n            numOfWorkers: (ENV.development && config.debug) ? 0 : 1,\n            locator: {\n                halfSample: false\n            }\n        }, config);\n        this.init(config, () => {\n            Events.once(\"processed\", (result) => {\n                this.stop();\n                resultCallback.call(null, result);\n            }, true);\n            start();\n        });\n    },\n    ImageWrapper: ImageWrapper,\n    ImageDebug: ImageDebug,\n    ResultCollector: ResultCollector,\n    CameraAccess: CameraAccess,\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/quagga.js","const CVUtils = require('../src/common/cv_utils'),\n      Ndarray = require(\"ndarray\"),\n      Interp2D = require(\"ndarray-linear-interpolate\").d2;\n\nvar FrameGrabber = {};\n\nFrameGrabber.create = function(inputStream) {\n    var _that = {},\n        _streamConfig = inputStream.getConfig(),\n        _video_size = CVUtils.imageRef(inputStream.getRealWidth(), inputStream.getRealHeight()),\n        _canvasSize = inputStream.getCanvasSize(),\n        _size = CVUtils.imageRef(inputStream.getWidth(), inputStream.getHeight()),\n        _topRight = inputStream.getTopRight(),\n        _data = new Uint8Array(_size.x * _size.y),\n        _grayData = new Uint8Array(_video_size.x * _video_size.y),\n        _canvasData = new Uint8Array(_canvasSize.x * _canvasSize.y),\n        _grayImageArray = Ndarray(_grayData, [_video_size.y, _video_size.x]).transpose(1, 0),\n        _canvasImageArray = Ndarray(_canvasData, [_canvasSize.y, _canvasSize.x]).transpose(1, 0),\n        _targetImageArray = _canvasImageArray.hi(_topRight.x + _size.x, _topRight.y + _size.y).lo(_topRight.x, _topRight.y),\n        _stepSizeX = _video_size.x/_canvasSize.x,\n        _stepSizeY = _video_size.y/_canvasSize.y;\n\n    console.log(\"FrameGrabber\", JSON.stringify({\n        videoSize: _grayImageArray.shape,\n        canvasSize: _canvasImageArray.shape,\n        stepSize: [_stepSizeX, _stepSizeY],\n        size: _targetImageArray.shape,\n        topRight: _topRight\n    }));\n\n    /**\n     * Uses the given array as frame-buffer\n     */\n    _that.attachData = function(data) {\n        _data = data;\n    };\n\n    /**\n     * Returns the used frame-buffer\n     */\n    _that.getData = function() {\n        return _data;\n    };\n\n    /**\n     * Fetches a frame from the input-stream and puts into the frame-buffer.\n     * The image-data is converted to gray-scale and then half-sampled if configured.\n     */\n    _that.grab = function() {\n        var frame = inputStream.getFrame();\n\n        if (frame) {\n            this.scaleAndCrop(frame);\n            return true;\n        } else {\n            return false;\n        }\n    };\n\n    _that.scaleAndCrop = function(frame) {\n        var x,\n            y;\n\n        // 1. compute full-sized gray image\n        CVUtils.computeGray(frame.data, _grayData);\n\n        // 2. interpolate\n        for (y = 0; y < _canvasSize.y; y++) {\n            for (x = 0; x < _canvasSize.x; x++) {\n                _canvasImageArray.set(x, y, (Interp2D(_grayImageArray, x * _stepSizeX, y * _stepSizeY)) | 0);\n            }\n        }\n\n        // targetImageArray must be equal to targetSize\n        if (_targetImageArray.shape[0] !== _size.x ||\n            _targetImageArray.shape[1] !== _size.y) {\n            throw new Error(\"Shapes do not match!\");\n        }\n\n        // 3. crop\n        for (y = 0; y < _size.y; y++) {\n            for (x = 0; x < _size.x; x++) {\n                _data[y * _size.x + x] = _targetImageArray.get(x, y);\n            }\n        }\n    },\n\n    _that.getSize = function() {\n        return _size;\n    };\n\n    return _that;\n};\n\nmodule.exports = FrameGrabber;\n\n\n\n// WEBPACK FOOTER //\n// ./lib/frame_grabber.js","const GetPixels = require(\"get-pixels\");\n\nvar InputStream = {};\n\nInputStream.createImageStream = function() {\n    var that = {};\n    var _config = null;\n\n    var width = 0,\n        height = 0,\n        frameIdx = 0,\n        paused = true,\n        loaded = false,\n        frame = null,\n        baseUrl,\n        ended = false,\n        size,\n        calculatedWidth,\n        calculatedHeight,\n        _eventNames = ['canrecord', 'ended'],\n        _eventHandlers = {},\n        _topRight = {x: 0, y: 0},\n        _canvasSize = {x: 0, y: 0};\n\n    function loadImages() {\n        loaded = false;\n        GetPixels(baseUrl, _config.mime, function(err, pixels) {\n            if (err) {\n                console.log(err);\n                exit(1);\n            }\n            loaded = true;\n            console.log(pixels.shape);\n            frame = pixels;\n            width = pixels.shape[0];\n            height = pixels.shape[1];\n            calculatedWidth = _config.size ? width/height > 1 ? _config.size : Math.floor((width/height) * _config.size) : width;\n            calculatedHeight = _config.size ? width/height > 1 ? Math.floor((height/width) * _config.size) : _config.size : height;\n\n            _canvasSize.x = calculatedWidth;\n            _canvasSize.y = calculatedHeight;\n\n            setTimeout(function() {\n                publishEvent(\"canrecord\", []);\n            }, 0);\n        });\n    }\n\n    function publishEvent(eventName, args) {\n        var j,\n            handlers = _eventHandlers[eventName];\n\n        if (handlers && handlers.length > 0) {\n            for ( j = 0; j < handlers.length; j++) {\n                handlers[j].apply(that, args);\n            }\n        }\n    }\n\n\n    that.trigger = publishEvent;\n\n    that.getWidth = function() {\n        return calculatedWidth;\n    };\n\n    that.getHeight = function() {\n        return calculatedHeight;\n    };\n\n    that.setWidth = function(width) {\n        calculatedWidth = width;\n    };\n\n    that.setHeight = function(height) {\n        calculatedHeight = height;\n    };\n\n    that.getRealWidth = function() {\n        return width;\n    };\n\n    that.getRealHeight = function() {\n        return height;\n    };\n\n    that.setInputStream = function(stream) {\n        _config = stream;\n        baseUrl = _config.src;\n        size = 1;\n        loadImages();\n    };\n\n    that.ended = function() {\n        return ended;\n    };\n\n    that.setAttribute = function() {};\n\n    that.getConfig = function() {\n        return _config;\n    };\n\n    that.pause = function() {\n        paused = true;\n    };\n\n    that.play = function() {\n        paused = false;\n    };\n\n    that.setCurrentTime = function(time) {\n        frameIdx = time;\n    };\n\n    that.addEventListener = function(event, f) {\n        if (_eventNames.indexOf(event) !== -1) {\n            if (!_eventHandlers[event]) {\n                _eventHandlers[event] = [];\n            }\n            _eventHandlers[event].push(f);\n        }\n    };\n\n    that.setTopRight = function(topRight) {\n        _topRight.x = topRight.x;\n        _topRight.y = topRight.y;\n    };\n\n    that.getTopRight = function() {\n        return _topRight;\n    };\n\n    that.setCanvasSize = function(size) {\n        _canvasSize.x = size.x;\n        _canvasSize.y = size.y;\n    };\n\n    that.getCanvasSize = function() {\n        return _canvasSize;\n    };\n\n    that.getFrame = function() {\n        if (!loaded){\n            return null;\n        }\n        return frame;\n    };\n\n    return that;\n};\n\nmodule.exports = InputStream;\n\n\n\n// WEBPACK FOOTER //\n// ./lib/input_stream.js","import ImageDebug from '../common/image_debug';\n\nfunction contains(codeResult, list) {\n    if (list) {\n        return list.some(function (item) {\n            return Object.keys(item).every(function (key) {\n                return item[key] === codeResult[key];\n            });\n        });\n    }\n    return false;\n}\n\nfunction passesFilter(codeResult, filter) {\n    if (typeof filter === 'function') {\n        return filter(codeResult);\n    }\n    return true;\n}\n\nexport default {\n    create: function(config) {\n        var canvas = document.createElement(\"canvas\"),\n            ctx = canvas.getContext(\"2d\"),\n            results = [],\n            capacity = config.capacity || 20,\n            capture = config.capture === true;\n\n        function matchesConstraints(codeResult) {\n            return capacity\n                && codeResult\n                && !contains(codeResult, config.blacklist)\n                && passesFilter(codeResult, config.filter);\n        }\n\n        return {\n            addResult: function(data, imageSize, codeResult) {\n                var result = {};\n\n                if (matchesConstraints(codeResult)) {\n                    capacity--;\n                    result.codeResult = codeResult;\n                    if (capture) {\n                        canvas.width = imageSize.x;\n                        canvas.height = imageSize.y;\n                        ImageDebug.drawImage(data, imageSize, ctx);\n                        result.frame = canvas.toDataURL();\n                    }\n                    results.push(result);\n                }\n            },\n            getResults: function() {\n                return results;\n            }\n        };\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/analytics/result_collector.js","const vec2 = {\n    clone: require('gl-vec2/clone'),\n    dot: require('gl-vec2/dot')\n}\n    /**\n     * Creates a cluster for grouping similar orientations of datapoints\n     */\nexport default {\n    create: function(point, threshold) {\n        var points = [],\n            center = {\n                rad: 0,\n                vec: vec2.clone([0, 0])\n            },\n            pointMap = {};\n\n        function init() {\n            add(point);\n            updateCenter();\n        }\n\n        function add(pointToAdd) {\n            pointMap[pointToAdd.id] = pointToAdd;\n            points.push(pointToAdd);\n        }\n\n        function updateCenter() {\n            var i, sum = 0;\n            for ( i = 0; i < points.length; i++) {\n                sum += points[i].rad;\n            }\n            center.rad = sum / points.length;\n            center.vec = vec2.clone([Math.cos(center.rad), Math.sin(center.rad)]);\n        }\n\n        init();\n\n        return {\n            add: function(pointToAdd) {\n                if (!pointMap[pointToAdd.id]) {\n                    add(pointToAdd);\n                    updateCenter();\n                }\n            },\n            fits: function(otherPoint) {\n                // check cosine similarity to center-angle\n                var similarity = Math.abs(vec2.dot(otherPoint.point.vec, center.vec));\n                if (similarity > threshold) {\n                    return true;\n                }\n                return false;\n            },\n            getPoints: function() {\n                return points;\n            },\n            getCenter: function() {\n                return center;\n            }\n        };\n    },\n    createPoint: function(newPoint, id, property) {\n        return {\n            rad: newPoint[property],\n            point: newPoint,\n            id: id\n        };\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/cluster.js","export default (function() {\n    var events = {};\n\n    function getEvent(eventName) {\n        if (!events[eventName]) {\n            events[eventName] = {\n                subscribers: []\n            };\n        }\n        return events[eventName];\n    }\n\n    function clearEvents(){\n        events = {};\n    }\n\n    function publishSubscription(subscription, data) {\n        if (subscription.async) {\n            setTimeout(function() {\n                subscription.callback(data);\n            }, 4);\n        } else {\n            subscription.callback(data);\n        }\n    }\n\n    function subscribe(event, callback, async) {\n        var subscription;\n\n        if ( typeof callback === \"function\") {\n            subscription = {\n                callback: callback,\n                async: 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).subscribers.push(subscription);\n    }\n\n    return {\n        subscribe: function(event, callback, async) {\n            return subscribe(event, callback, async);\n        },\n        publish: function(eventName, data) {\n            var event = getEvent(eventName),\n                subscribers = event.subscribers;\n\n            // Publish one-time subscriptions\n            subscribers.filter(function(subscriber) {\n                return !!subscriber.once;\n            }).forEach((subscriber) => {\n                publishSubscription(subscriber, data);\n            });\n\n            // remove them from the subscriber\n            event.subscribers = subscribers.filter(function(subscriber) {\n                return !subscriber.once;\n            });\n\n            // publish the rest\n            event.subscribers.forEach((subscriber) => {\n                publishSubscription(subscriber, data);\n            });\n        },\n        once: function(event, callback, async) {\n            subscribe(event, {\n                callback: callback,\n                async: async,\n                once: true\n            });\n        },\n        unsubscribe: function(eventName, callback) {\n            var event;\n\n            if (eventName) {\n                event = getEvent(eventName);\n                if (event && callback) {\n                    event.subscribers = event.subscribers.filter(function(subscriber){\n                        return subscriber.callback !== callback;\n                    });\n                } else {\n                    event.subscribers = [];\n                }\n            } else {\n                clearEvents();\n            }\n        }\n    };\n})();\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/events.js","\nexport function enumerateDevices() {\n    if (navigator.mediaDevices\n            && 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) {\n    if (navigator.mediaDevices\n            && typeof navigator.mediaDevices.getUserMedia === 'function') {\n        return navigator.mediaDevices\n            .getUserMedia(constraints);\n    }\n    return Promise.reject(new Error('getUserMedia is not defined'));\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/mediaDevices.js","/**\n * Construct representing a part of another {ImageWrapper}. Shares data\n * between the parent and the child.\n * @param from {ImageRef} The position where to start the {SubImage} from. (top-left corner)\n * @param size {ImageRef} The size of the resulting image\n * @param I {ImageWrapper} The {ImageWrapper} to share from\n * @returns {SubImage} A shared part of the original image\n */\nfunction SubImage(from, size, I) {\n    if (!I) {\n        I = {\n            data: null,\n            size: size\n        };\n    }\n    this.data = I.data;\n    this.originalSize = I.size;\n    this.I = I;\n\n    this.from = from;\n    this.size = size;\n}\n\n/**\n * Displays the {SubImage} in a given canvas\n * @param canvas {Canvas} The canvas element to write to\n * @param scale {Number} Scale which is applied to each pixel-value\n */\nSubImage.prototype.show = function(canvas, scale) {\n    var ctx,\n        frame,\n        data,\n        current,\n        y,\n        x,\n        pixel;\n\n    if (!scale) {\n        scale = 1.0;\n    }\n    ctx = canvas.getContext('2d');\n    canvas.width = this.size.x;\n    canvas.height = this.size.y;\n    frame = ctx.getImageData(0, 0, canvas.width, canvas.height);\n    data = frame.data;\n    current = 0;\n    for (y = 0; y < this.size.y; y++) {\n        for (x = 0; x < this.size.x; x++) {\n            pixel = y * this.size.x + x;\n            current = this.get(x, y) * scale;\n            data[pixel * 4 + 0] = current;\n            data[pixel * 4 + 1] = current;\n            data[pixel * 4 + 2] = current;\n            data[pixel * 4 + 3] = 255;\n        }\n    }\n    frame.data = data;\n    ctx.putImageData(frame, 0, 0);\n};\n\n/**\n * Retrieves a given pixel position from the {SubImage}\n * @param x {Number} The x-position\n * @param y {Number} The y-position\n * @returns {Number} The grayscale value at the pixel-position\n */\nSubImage.prototype.get = function(x, y) {\n    return this.data[(this.from.y + y) * this.originalSize.x + this.from.x + x];\n};\n\n/**\n * Updates the underlying data from a given {ImageWrapper}\n * @param image {ImageWrapper} The updated image\n */\nSubImage.prototype.updateData = function(image) {\n    this.originalSize = image.size;\n    this.data = image.data;\n};\n\n/**\n * Updates the position of the shared area\n * @param from {x,y} The new location\n * @returns {SubImage} returns {this} for possible chaining\n */\nSubImage.prototype.updateFrom = function(from) {\n    this.from = from;\n    return this;\n};\n\nexport default (SubImage);\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/subImage.js","/*\n * typedefs.js\n * Normalizes browser-specific prefixes\n */\n\nif (typeof window !== 'undefined') {\n    window.requestAnimFrame = (function () {\n        return window.requestAnimationFrame ||\n            window.webkitRequestAnimationFrame ||\n            window.mozRequestAnimationFrame ||\n            window.oRequestAnimationFrame ||\n            window.msRequestAnimationFrame ||\n            function (/* function FrameRequestCallback */ callback) {\n                window.setTimeout(callback, 1000 / 60);\n            };\n    })();\n}\nMath.imul = Math.imul || function(a, b) {\n    var ah = (a >>> 16) & 0xffff,\n        al = a & 0xffff,\n        bh = (b >>> 16) & 0xffff,\n        bl = b & 0xffff;\n    // the shift by 0 fixes the sign on the high part\n    // the final |0 converts the unsigned value into a signed value\n    return ((al * bl) + (((ah * bl + al * bh) << 16) >>> 0) | 0);\n};\n\nif (typeof Object.assign !== 'function') {\n    Object.assign = function(target) { // .length of function is 2\n        'use strict';\n        if (target === null) { // TypeError if undefined or null\n            throw new TypeError('Cannot convert undefined or null to object');\n        }\n\n        var to = Object(target);\n\n        for (var index = 1; index < arguments.length; index++) {\n            var nextSource = arguments[index];\n\n            if (nextSource !== null) { // Skip over if undefined or null\n                for (var nextKey in nextSource) {\n                    // Avoid bugs when hasOwnProperty is shadowed\n                    if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {\n                        to[nextKey] = nextSource[nextKey];\n                    }\n                }\n            }\n        }\n        return to;\n    };\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/common/typedefs.js","let config;\n\nif (ENV.development){\n    config = require('./config.dev.js');\n} else if (ENV.node) {\n    config = require('./config.node.js');\n} else {\n    config = require('./config.prod.js');\n}\n\nexport default config;\n\n\n\n// WEBPACK FOOTER //\n// ./src/config/config.js","module.exports = {\n    inputStream: {\n        type: \"ImageStream\",\n        sequence: false,\n        size: 800,\n        area: {\n            top: \"0%\",\n            right: \"0%\",\n            left: \"0%\",\n            bottom: \"0%\"\n        },\n        singleChannel: false // true: only the red color-channel is read\n    },\n    locate: true,\n    numOfWorkers: 0,\n    decoder: {\n        readers: [\n            'code_128_reader'\n        ]\n    },\n    locator: {\n        halfSample: true,\n        patchSize: \"medium\" // x-small, small, medium, large, x-large\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/config/config.node.js","import Bresenham from './bresenham';\nimport ImageDebug from '../common/image_debug';\nimport Code128Reader from '../reader/code_128_reader';\nimport EANReader from '../reader/ean_reader';\nimport Code39Reader from '../reader/code_39_reader';\nimport Code39VINReader from '../reader/code_39_vin_reader';\nimport CodabarReader from '../reader/codabar_reader';\nimport UPCReader from '../reader/upc_reader';\nimport EAN8Reader from '../reader/ean_8_reader';\nimport EAN2Reader from '../reader/ean_2_reader';\nimport EAN5Reader from '../reader/ean_5_reader';\nimport UPCEReader from '../reader/upc_e_reader';\nimport I2of5Reader from '../reader/i2of5_reader';\nimport TwoOfFiveReader from '../reader/2of5_reader';\nimport Code93Reader from '../reader/code_93_reader';\n\nconst READERS = {\n    code_128_reader: Code128Reader,\n    ean_reader: EANReader,\n    ean_5_reader: EAN5Reader,\n    ean_2_reader: EAN2Reader,\n    ean_8_reader: EAN8Reader,\n    code_39_reader: Code39Reader,\n    code_39_vin_reader: Code39VINReader,\n    codabar_reader: CodabarReader,\n    upc_reader: UPCReader,\n    upc_e_reader: UPCEReader,\n    i2of5_reader: I2of5Reader,\n    '2of5_reader': TwoOfFiveReader,\n    code_93_reader: Code93Reader\n};\nexport default {\n    create: function(config, inputImageWrapper) {\n        var _canvas = {\n                ctx: {\n                    frequency: null,\n                    pattern: null,\n                    overlay: null\n                },\n                dom: {\n                    frequency: null,\n                    pattern: null,\n                    overlay: null\n                }\n            },\n            _barcodeReaders = [];\n\n        initCanvas();\n        initReaders();\n        initConfig();\n\n        function initCanvas() {\n            if (ENV.development && typeof document !== 'undefined') {\n                var $debug = document.querySelector(\"#debug.detection\");\n                _canvas.dom.frequency = document.querySelector(\"canvas.frequency\");\n                if (!_canvas.dom.frequency) {\n                    _canvas.dom.frequency = document.createElement(\"canvas\");\n                    _canvas.dom.frequency.className = \"frequency\";\n                    if ($debug) {\n                        $debug.appendChild(_canvas.dom.frequency);\n                    }\n                }\n                _canvas.ctx.frequency = _canvas.dom.frequency.getContext(\"2d\");\n\n                _canvas.dom.pattern = document.querySelector(\"canvas.patternBuffer\");\n                if (!_canvas.dom.pattern) {\n                    _canvas.dom.pattern = document.createElement(\"canvas\");\n                    _canvas.dom.pattern.className = \"patternBuffer\";\n                    if ($debug) {\n                        $debug.appendChild(_canvas.dom.pattern);\n                    }\n                }\n                _canvas.ctx.pattern = _canvas.dom.pattern.getContext(\"2d\");\n\n                _canvas.dom.overlay = document.querySelector(\"canvas.drawingBuffer\");\n                if (_canvas.dom.overlay) {\n                    _canvas.ctx.overlay = _canvas.dom.overlay.getContext(\"2d\");\n                }\n            }\n        }\n\n        function initReaders() {\n            config.readers.forEach(function(readerConfig) {\n                var reader,\n                    configuration = {},\n                    supplements = [];\n\n                if (typeof readerConfig === 'object') {\n                    reader = readerConfig.format;\n                    configuration = readerConfig.config;\n                } else if (typeof readerConfig === 'string') {\n                    reader = readerConfig;\n                }\n                if (ENV.development) {\n                    console.log(\"Before registering reader: \", reader);\n                }\n                if (configuration.supplements) {\n                    supplements = configuration\n                        .supplements.map((supplement) => {\n                            return new READERS[supplement]();\n                        });\n                }\n                _barcodeReaders.push(new READERS[reader](configuration, supplements));\n            });\n            if (ENV.development) {\n                console.log(\"Registered Readers: \" + _barcodeReaders\n                    .map((reader) => JSON.stringify({format: reader.FORMAT, config: reader.config}))\n                    .join(', '));\n            }\n        }\n\n        function initConfig() {\n            if (ENV.development && typeof document !== 'undefined') {\n                var i,\n                    vis = [{\n                        node: _canvas.dom.frequency,\n                        prop: config.debug.showFrequency\n                    }, {\n                        node: _canvas.dom.pattern,\n                        prop: config.debug.showPattern\n                    }];\n\n                for (i = 0; i < vis.length; i++) {\n                    if (vis[i].prop === true) {\n                        vis[i].node.style.display = \"block\";\n                    } else {\n                        vis[i].node.style.display = \"none\";\n                    }\n                }\n            }\n        }\n\n        /**\n         * extend the line on both ends\n         * @param {Array} line\n         * @param {Number} angle\n         */\n        function getExtendedLine(line, angle, ext) {\n            function extendLine(amount) {\n                var 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            // check if inside image\n            extendLine(ext);\n            while (ext > 1 && (!inputImageWrapper.inImageWithBorder(line[0], 0)\n                    || !inputImageWrapper.inImageWithBorder(line[1], 0))) {\n                ext -= Math.ceil(ext / 2);\n                extendLine(-ext);\n            }\n            return line;\n        }\n\n        function getLine(box) {\n            return [{\n                x: (box[1][0] - box[0][0]) / 2 + box[0][0],\n                y: (box[1][1] - box[0][1]) / 2 + box[0][1]\n            }, {\n                x: (box[3][0] - box[2][0]) / 2 + box[2][0],\n                y: (box[3][1] - box[2][1]) / 2 + box[2][1]\n            }];\n        }\n\n        function tryDecode(line) {\n            var result = null,\n                i,\n                barcodeLine = Bresenham.getBarcodeLine(inputImageWrapper, line[0], line[1]);\n\n            if (ENV.development && config.debug.showFrequency) {\n                ImageDebug.drawPath(line, {x: 'x', y: 'y'}, _canvas.ctx.overlay, {color: 'red', lineWidth: 3});\n                Bresenham.debug.printFrequency(barcodeLine.line, _canvas.dom.frequency);\n            }\n\n            Bresenham.toBinaryLine(barcodeLine);\n\n            if (ENV.development && config.debug.showPattern) {\n                Bresenham.debug.printPattern(barcodeLine.line, _canvas.dom.pattern);\n            }\n\n            for ( i = 0; i < _barcodeReaders.length && result === null; i++) {\n                result = _barcodeReaders[i].decodePattern(barcodeLine.line);\n            }\n            if (result === null){\n                return null;\n            }\n            return {\n                codeResult: result,\n                barcodeLine: barcodeLine\n            };\n        }\n\n        /**\n         * This method slices the given area apart and tries to detect a barcode-pattern\n         * for each slice. It returns the decoded barcode, or null if nothing was found\n         * @param {Array} box\n         * @param {Array} line\n         * @param {Number} lineAngle\n         */\n        function tryDecodeBruteForce(box, line, lineAngle) {\n            var sideLength = Math.sqrt(Math.pow(box[1][0] - box[0][0], 2) + Math.pow((box[1][1] - box[0][1]), 2)),\n                i,\n                slices = 16,\n                result = null,\n                dir,\n                extension,\n                xdir = Math.sin(lineAngle),\n                ydir = Math.cos(lineAngle);\n\n            for ( i = 1; i < slices && result === null; i++) {\n                // move line perpendicular to angle\n                dir = sideLength / slices * i * (i % 2 === 0 ? -1 : 1);\n                extension = {\n                    y: dir * xdir,\n                    x: dir * ydir\n                };\n                line[0].y += extension.x;\n                line[0].x -= extension.y;\n                line[1].y += extension.x;\n                line[1].x -= extension.y;\n\n                result = tryDecode(line);\n            }\n            return result;\n        }\n\n        function getLineLength(line) {\n            return Math.sqrt(\n                Math.pow(Math.abs(line[1].y - line[0].y), 2) +\n                Math.pow(Math.abs(line[1].x - line[0].x), 2));\n        }\n\n        /**\n         * With the help of the configured readers (Code128 or EAN) this function tries to detect a\n         * valid barcode pattern within the given area.\n         * @param {Object} box The area to search in\n         * @returns {Object} the result {codeResult, line, angle, pattern, threshold}\n         */\n        function decodeFromBoundingBox(box) {\n            var line,\n                lineAngle,\n                ctx = _canvas.ctx.overlay,\n                result,\n                lineLength;\n\n            if (ENV.development) {\n                if (config.debug.drawBoundingBox && ctx) {\n                    ImageDebug.drawPath(box, {x: 0, y: 1}, ctx, {color: \"blue\", lineWidth: 2});\n                }\n            }\n\n            line = getLine(box);\n            lineLength = getLineLength(line);\n            lineAngle = Math.atan2(line[1].y - line[0].y, line[1].x - line[0].x);\n            line = getExtendedLine(line, lineAngle, Math.floor(lineLength * 0.1));\n            if (line === null){\n                return null;\n            }\n\n            result = tryDecode(line);\n            if (result === null) {\n                result = tryDecodeBruteForce(box, line, lineAngle);\n            }\n\n            if (result === null) {\n                return null;\n            }\n\n            if (ENV.development && result && config.debug.drawScanline && ctx) {\n                ImageDebug.drawPath(line, {x: 'x', y: 'y'}, ctx, {color: 'red', lineWidth: 3});\n            }\n\n            return {\n                codeResult: result.codeResult,\n                line: line,\n                angle: lineAngle,\n                pattern: result.barcodeLine.line,\n                threshold: result.barcodeLine.threshold\n            };\n        }\n\n        return {\n            decodeFromBoundingBox: function(box) {\n                return decodeFromBoundingBox(box);\n            },\n            decodeFromBoundingBoxes: function(boxes) {\n                var i, result,\n                    barcodes = [],\n                    multiple = config.multiple;\n\n                for ( i = 0; i < boxes.length; i++) {\n                    const box = boxes[i];\n                    result = decodeFromBoundingBox(box) || {};\n                    result.box = box;\n\n                    if (multiple) {\n                        barcodes.push(result);\n                    } else if (result.codeResult) {\n                        return result;\n                    }\n                }\n\n                if (multiple) {\n                    return {\n                        barcodes\n                    };\n                }\n            },\n            setReaders: function(readers) {\n                config.readers = readers;\n                _barcodeReaders.length = 0;\n                initReaders();\n            }\n        };\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/decoder/barcode_decoder.js","import ImageWrapper from '../common/image_wrapper';\n\nvar Bresenham = {};\n\nvar Slope = {\n    DIR: {\n        UP: 1,\n        DOWN: -1\n    }\n};\n/**\n * Scans a line of the given image from point p1 to p2 and returns a result object containing\n * gray-scale values (0-255) of the underlying pixels in addition to the min\n * and max values.\n * @param {Object} imageWrapper\n * @param {Object} p1 The start point {x,y}\n * @param {Object} p2 The end point {x,y}\n * @returns {line, min, max}\n */\nBresenham.getBarcodeLine = function(imageWrapper, p1, p2) {\n    var x0 = p1.x | 0,\n        y0 = p1.y | 0,\n        x1 = p2.x | 0,\n        y1 = p2.y | 0,\n        steep = Math.abs(y1 - y0) > Math.abs(x1 - x0),\n        deltax,\n        deltay,\n        error,\n        ystep,\n        y,\n        tmp,\n        x,\n        line = [],\n        imageData = imageWrapper.data,\n        width = imageWrapper.size.x,\n        sum = 0,\n        val,\n        min = 255,\n        max = 0;\n\n    function read(a, b) {\n        val = imageData[b * width + a];\n        sum += val;\n        min = val < min ? val : min;\n        max = val > max ? val : max;\n        line.push(val);\n    }\n\n    if (steep) {\n        tmp = x0;\n        x0 = y0;\n        y0 = tmp;\n\n        tmp = x1;\n        x1 = y1;\n        y1 = tmp;\n    }\n    if (x0 > x1) {\n        tmp = x0;\n        x0 = x1;\n        x1 = tmp;\n\n        tmp = y0;\n        y0 = y1;\n        y1 = tmp;\n    }\n    deltax = x1 - x0;\n    deltay = Math.abs(y1 - y0);\n    error = (deltax / 2) | 0;\n    y = y0;\n    ystep = y0 < y1 ? 1 : -1;\n    for ( x = x0; x < x1; x++) {\n        if (steep){\n            read(y, x);\n        } else {\n            read(x, y);\n        }\n        error = error - deltay;\n        if (error < 0) {\n            y = y + ystep;\n            error = error + deltax;\n        }\n    }\n\n    return {\n        line: line,\n        min: min,\n        max: max\n    };\n};\n\n/**\n * Converts the result from getBarcodeLine into a binary representation\n * also considering the frequency and slope of the signal for more robust results\n * @param {Object} result {line, min, max}\n */\nBresenham.toBinaryLine = function(result) {\n    var min = result.min,\n        max = result.max,\n        line = result.line,\n        slope,\n        slope2,\n        center = min + (max - min) / 2,\n        extrema = [],\n        currentDir,\n        dir,\n        threshold = (max - min) / 12,\n        rThreshold = -threshold,\n        i,\n        j;\n\n    // 1. find extrema\n    currentDir = line[0] > center ? Slope.DIR.UP : Slope.DIR.DOWN;\n    extrema.push({\n        pos: 0,\n        val: line[0]\n    });\n    for ( i = 0; i < line.length - 2; i++) {\n        slope = (line[i + 1] - line[i]);\n        slope2 = (line[i + 2] - line[i + 1]);\n        if ((slope + slope2) < rThreshold && line[i + 1] < (center * 1.5)) {\n            dir = Slope.DIR.DOWN;\n        } else if ((slope + slope2) > threshold && line[i + 1] > (center * 0.5)) {\n            dir = Slope.DIR.UP;\n        } else {\n            dir = currentDir;\n        }\n\n        if (currentDir !== dir) {\n            extrema.push({\n                pos: i,\n                val: line[i]\n            });\n            currentDir = dir;\n        }\n    }\n    extrema.push({\n        pos: line.length,\n        val: line[line.length - 1]\n    });\n\n    for ( j = extrema[0].pos; j < extrema[1].pos; j++) {\n        line[j] = line[j] > center ? 0 : 1;\n    }\n\n    // iterate over extrema and convert to binary based on avg between minmax\n    for ( i = 1; i < extrema.length - 1; i++) {\n        if (extrema[i + 1].val > extrema[i].val) {\n            threshold = (extrema[i].val + ((extrema[i + 1].val - extrema[i].val) / 3) * 2) | 0;\n        } else {\n            threshold = (extrema[i + 1].val + ((extrema[i].val - extrema[i + 1].val) / 3)) | 0;\n        }\n\n        for ( j = extrema[i].pos; j < extrema[i + 1].pos; j++) {\n            line[j] = line[j] > threshold ? 0 : 1;\n        }\n    }\n\n    return {\n        line: line,\n        threshold: threshold\n    };\n};\n\n/**\n * Used for development only\n */\nBresenham.debug = {\n    printFrequency: function(line, canvas) {\n        var i,\n            ctx = canvas.getContext(\"2d\");\n        canvas.width = line.length;\n        canvas.height = 256;\n\n        ctx.beginPath();\n        ctx.strokeStyle = \"blue\";\n        for ( i = 0; i < line.length; i++) {\n            ctx.moveTo(i, 255);\n            ctx.lineTo(i, 255 - line[i]);\n        }\n        ctx.stroke();\n        ctx.closePath();\n    },\n\n    printPattern: function(line, canvas) {\n        var ctx = canvas.getContext(\"2d\"), i;\n\n        canvas.width = line.length;\n        ctx.fillColor = \"black\";\n        for ( i = 0; i < line.length; i++) {\n            if (line[i] === 1) {\n                ctx.fillRect(i, 0, 1, 100);\n            }\n        }\n    }\n};\n\nexport default Bresenham;\n\n\n\n// WEBPACK FOOTER //\n// ./src/decoder/bresenham.js","import {omit, pick} from 'lodash';\nimport {getUserMedia, enumerateDevices} from 'mediaDevices';\n\nconst facingMatching = {\n    \"user\": /front/i,\n    \"environment\": /back/i\n};\n\nvar streamRef;\n\nfunction waitForVideo(video) {\n    return new Promise((resolve, reject) => {\n        let attempts = 10;\n\n        function checkVideo() {\n            if (attempts > 0) {\n                if (video.videoWidth > 10 && video.videoHeight > 10) {\n                    if (ENV.development) {\n                        console.log(video.videoWidth + \"px x \" + video.videoHeight + \"px\");\n                    }\n                    resolve();\n                } else {\n                    window.setTimeout(checkVideo, 500);\n                }\n            } else {\n                reject('Unable to play video stream. Is webcam working?');\n            }\n            attempts--;\n        }\n        checkVideo();\n    });\n}\n\n/**\n * Tries to attach the camera-stream to a given video-element\n * and calls the callback function when the content is ready\n * @param {Object} constraints\n * @param {Object} video\n */\nfunction initCamera(video, constraints) {\n    return getUserMedia(constraints)\n    .then((stream) => {\n        return new Promise((resolve) => {\n            streamRef = stream;\n            video.setAttribute(\"autoplay\", true);\n            video.setAttribute('muted', true);\n            video.setAttribute('playsinline', true);\n            video.srcObject = stream;\n            video.addEventListener('loadedmetadata', () => {\n                video.play();\n                resolve();\n            });\n        });\n    })\n    .then(waitForVideo.bind(null, video));\n}\n\nfunction deprecatedConstraints(videoConstraints) {\n    const normalized = pick(videoConstraints, [\"width\", \"height\", \"facingMode\",\n            \"aspectRatio\", \"deviceId\"]);\n\n    if (typeof videoConstraints.minAspectRatio !== 'undefined' &&\n            videoConstraints.minAspectRatio > 0) {\n        normalized.aspectRatio = videoConstraints.minAspectRatio;\n        console.log(\"WARNING: Constraint 'minAspectRatio' is deprecated; Use 'aspectRatio' instead\");\n    }\n    if (typeof videoConstraints.facing !== 'undefined') {\n        normalized.facingMode = videoConstraints.facing;\n        console.log(\"WARNING: Constraint 'facing' is deprecated. Use 'facingMode' instead'\");\n    }\n    return normalized;\n}\n\nexport function pickConstraints(videoConstraints) {\n    const normalizedConstraints = {\n        audio: false,\n        video: deprecatedConstraints(videoConstraints)\n    };\n\n    if (normalizedConstraints.video.deviceId\n            && normalizedConstraints.video.facingMode) {\n        delete normalizedConstraints.video.facingMode;\n    }\n    return Promise.resolve(normalizedConstraints);\n}\n\nfunction enumerateVideoDevices() {\n    return enumerateDevices()\n    .then(devices => devices.filter(device => device.kind === 'videoinput'));\n}\n\nfunction getActiveTrack() {\n    if (streamRef) {\n        const tracks = streamRef.getVideoTracks();\n        if (tracks && tracks.length) {\n            return tracks[0];\n        }\n    }\n}\n\nexport default {\n    request: function(video, videoConstraints) {\n        return pickConstraints(videoConstraints)\n            .then(initCamera.bind(null, video));\n    },\n    release: function() {\n        var tracks = streamRef && streamRef.getVideoTracks();\n        if (tracks && tracks.length) {\n            tracks[0].stop();\n        }\n        streamRef = null;\n    },\n    enumerateVideoDevices,\n    getActiveStreamLabel: function() {\n        const track = getActiveTrack();\n        return track ? track.label : '';\n    },\n    getActiveTrack\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/input/camera_access.js","import ImageWrapper from '../common/image_wrapper';\nimport {\n    calculatePatchSize,\n    otsuThreshold,\n    hsv2rgb,\n    cluster,\n    topGeneric,\n    imageRef,\n    halfSample,\n    computeImageArea\n} from '../common/cv_utils';\nimport ArrayHelper from '../common/array_helper';\nimport ImageDebug from '../common/image_debug';\nimport Rasterizer from './rasterizer';\nimport Tracer from './tracer';\nimport skeletonizer from './skeletonizer';\nconst vec2 = {\n    clone: require('gl-vec2/clone'),\n    dot:  require('gl-vec2/dot'),\n    scale: require('gl-vec2/scale'),\n    transformMat2: require('gl-vec2/transformMat2')\n};\nconst mat2 = {\n    copy: require('gl-mat2/copy'),\n    create: require('gl-mat2/create'),\n    invert: require('gl-mat2/invert')\n}\n\nvar _config,\n    _currentImageWrapper,\n    _skelImageWrapper,\n    _subImageWrapper,\n    _labelImageWrapper,\n    _patchGrid,\n    _patchLabelGrid,\n    _imageToPatchGrid,\n    _binaryImageWrapper,\n    _patchSize,\n    _canvasContainer = {\n        ctx: {\n            binary: null\n        },\n        dom: {\n            binary: null\n        }\n    },\n    _numPatches = {x: 0, y: 0},\n    _inputImageWrapper,\n    _skeletonizer;\n\nfunction initBuffers() {\n    var skeletonImageData;\n\n    if (_config.halfSample) {\n        _currentImageWrapper = new ImageWrapper({\n            x: _inputImageWrapper.size.x / 2 | 0,\n            y: _inputImageWrapper.size.y / 2 | 0\n        });\n    } else {\n        _currentImageWrapper = _inputImageWrapper;\n    }\n\n    _patchSize = calculatePatchSize(_config.patchSize, _currentImageWrapper.size);\n\n    _numPatches.x = _currentImageWrapper.size.x / _patchSize.x | 0;\n    _numPatches.y = _currentImageWrapper.size.y / _patchSize.y | 0;\n\n    _binaryImageWrapper = new ImageWrapper(_currentImageWrapper.size, undefined, Uint8Array, false);\n\n    _labelImageWrapper = new ImageWrapper(_patchSize, undefined, Array, true);\n\n    skeletonImageData = new ArrayBuffer(64 * 1024);\n    _subImageWrapper = new ImageWrapper(_patchSize,\n        new Uint8Array(skeletonImageData, 0, _patchSize.x * _patchSize.y));\n    _skelImageWrapper = new ImageWrapper(_patchSize,\n        new Uint8Array(skeletonImageData, _patchSize.x * _patchSize.y * 3, _patchSize.x * _patchSize.y),\n        undefined, true);\n    _skeletonizer = skeletonizer((typeof window !== 'undefined') ? window : (typeof self !== 'undefined') ? self : global, {\n        size: _patchSize.x\n    }, skeletonImageData);\n\n    _imageToPatchGrid = new ImageWrapper({\n        x: (_currentImageWrapper.size.x / _subImageWrapper.size.x) | 0,\n        y: (_currentImageWrapper.size.y / _subImageWrapper.size.y) | 0\n    }, undefined, Array, true);\n    _patchGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, undefined, true);\n    _patchLabelGrid = new ImageWrapper(_imageToPatchGrid.size, undefined, Int32Array, true);\n}\n\nfunction initCanvas() {\n    if (_config.useWorker || typeof document === 'undefined') {\n        return;\n    }\n    _canvasContainer.dom.binary = document.createElement(\"canvas\");\n    _canvasContainer.dom.binary.className = \"binaryBuffer\";\n    if (ENV.development && _config.debug.showCanvas === true) {\n        document.querySelector(\"#debug\").appendChild(_canvasContainer.dom.binary);\n    }\n    _canvasContainer.ctx.binary = _canvasContainer.dom.binary.getContext(\"2d\");\n    _canvasContainer.dom.binary.width = _binaryImageWrapper.size.x;\n    _canvasContainer.dom.binary.height = _binaryImageWrapper.size.y;\n}\n\n/**\n * Creates a bounding box which encloses all the given patches\n * @returns {Array} The minimal bounding box\n */\nfunction boxFromPatches(patches) {\n    var overAvg,\n        i,\n        j,\n        patch,\n        transMat,\n        minx =\n        _binaryImageWrapper.size.x,\n        miny = _binaryImageWrapper.size.y,\n        maxx = -_binaryImageWrapper.size.x,\n        maxy = -_binaryImageWrapper.size.y,\n        box,\n        scale;\n\n    // draw all patches which are to be taken into consideration\n    overAvg = 0;\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        overAvg += patch.rad;\n        if (ENV.development && _config.debug.showPatches) {\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary, {color: \"red\"});\n        }\n    }\n\n    overAvg /= patches.length;\n    overAvg = (overAvg * 180 / Math.PI + 90) % 180 - 90;\n    if (overAvg < 0) {\n        overAvg += 180;\n    }\n\n    overAvg = (180 - overAvg) * Math.PI / 180;\n    transMat = mat2.copy(mat2.create(), [Math.cos(overAvg), Math.sin(overAvg), -Math.sin(overAvg), Math.cos(overAvg)]);\n\n    // iterate over patches and rotate by angle\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        for ( j = 0; j < 4; j++) {\n            vec2.transformMat2(patch.box[j], patch.box[j], transMat);\n        }\n\n        if (ENV.development && _config.debug.boxFromPatches.showTransformed) {\n            ImageDebug.drawPath(patch.box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#99ff00', lineWidth: 2});\n        }\n    }\n\n    // find bounding box\n    for ( i = 0; i < patches.length; i++) {\n        patch = patches[i];\n        for ( j = 0; j < 4; j++) {\n            if (patch.box[j][0] < minx) {\n                minx = patch.box[j][0];\n            }\n            if (patch.box[j][0] > maxx) {\n                maxx = patch.box[j][0];\n            }\n            if (patch.box[j][1] < miny) {\n                miny = patch.box[j][1];\n            }\n            if (patch.box[j][1] > maxy) {\n                maxy = patch.box[j][1];\n            }\n        }\n    }\n\n    box = [[minx, miny], [maxx, miny], [maxx, maxy], [minx, maxy]];\n\n    if (ENV.development && _config.debug.boxFromPatches.showTransformedBox) {\n        ImageDebug.drawPath(box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#ff0000', lineWidth: 2});\n    }\n\n    scale = _config.halfSample ? 2 : 1;\n    // reverse rotation;\n    transMat = mat2.invert(transMat, transMat);\n    for ( j = 0; j < 4; j++) {\n        vec2.transformMat2(box[j], box[j], transMat);\n    }\n\n    if (ENV.development && _config.debug.boxFromPatches.showBB) {\n        ImageDebug.drawPath(box, {x: 0, y: 1}, _canvasContainer.ctx.binary, {color: '#ff0000', lineWidth: 2});\n    }\n\n    for ( j = 0; j < 4; j++) {\n        vec2.scale(box[j], box[j], scale);\n    }\n\n    return box;\n}\n\n/**\n * Creates a binary image of the current image\n */\nfunction binarizeImage() {\n    otsuThreshold(_currentImageWrapper, _binaryImageWrapper);\n    _binaryImageWrapper.zeroBorder();\n    if (ENV.development && _config.debug.showCanvas) {\n        _binaryImageWrapper.show(_canvasContainer.dom.binary, 255);\n    }\n}\n\n/**\n * Iterate over the entire image\n * extract patches\n */\nfunction findPatches() {\n    var i,\n        j,\n        x,\n        y,\n        moments,\n        patchesFound = [],\n        rasterizer,\n        rasterResult,\n        patch;\n    for (i = 0; i < _numPatches.x; i++) {\n        for (j = 0; j < _numPatches.y; j++) {\n            x = _subImageWrapper.size.x * i;\n            y = _subImageWrapper.size.y * j;\n\n            // seperate parts\n            skeletonize(x, y);\n\n            // Rasterize, find individual bars\n            _skelImageWrapper.zeroBorder();\n            ArrayHelper.init(_labelImageWrapper.data, 0);\n            rasterizer = Rasterizer.create(_skelImageWrapper, _labelImageWrapper);\n            rasterResult = rasterizer.rasterize(0);\n\n            if (ENV.development && _config.debug.showLabels) {\n                _labelImageWrapper.overlay(_canvasContainer.dom.binary, Math.floor(360 / rasterResult.count),\n                    {x: x, y: y});\n            }\n\n            // calculate moments from the skeletonized patch\n            moments = _labelImageWrapper.moments(rasterResult.count);\n\n            // extract eligible patches\n            patchesFound = patchesFound.concat(describePatch(moments, [i, j], x, y));\n        }\n    }\n\n    if (ENV.development && _config.debug.showFoundPatches) {\n        for ( i = 0; i < patchesFound.length; i++) {\n            patch = patchesFound[i];\n            ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                {color: \"#99ff00\", lineWidth: 2});\n        }\n    }\n\n    return patchesFound;\n}\n\n/**\n * Finds those connected areas which contain at least 6 patches\n * and returns them ordered DESC by the number of contained patches\n * @param {Number} maxLabel\n */\nfunction findBiggestConnectedAreas(maxLabel){\n    var i,\n        sum,\n        labelHist = [],\n        topLabels = [];\n\n    for ( i = 0; i < maxLabel; i++) {\n        labelHist.push(0);\n    }\n    sum = _patchLabelGrid.data.length;\n    while (sum--) {\n        if (_patchLabelGrid.data[sum] > 0) {\n            labelHist[_patchLabelGrid.data[sum] - 1]++;\n        }\n    }\n\n    labelHist = labelHist.map(function(val, idx) {\n        return {\n            val: val,\n            label: idx + 1\n        };\n    });\n\n    labelHist.sort(function(a, b) {\n        return b.val - a.val;\n    });\n\n    // extract top areas with at least 6 patches present\n    topLabels = labelHist.filter(function(el) {\n        return el.val >= 5;\n    });\n\n    return topLabels;\n}\n\n/**\n *\n */\nfunction findBoxes(topLabels, maxLabel) {\n    var i,\n        j,\n        sum,\n        patches = [],\n        patch,\n        box,\n        boxes = [],\n        hsv = [0, 1, 1],\n        rgb = [0, 0, 0];\n\n    for ( i = 0; i < topLabels.length; i++) {\n        sum = _patchLabelGrid.data.length;\n        patches.length = 0;\n        while (sum--) {\n            if (_patchLabelGrid.data[sum] === topLabels[i].label) {\n                patch = _imageToPatchGrid.data[sum];\n                patches.push(patch);\n            }\n        }\n        box = boxFromPatches(patches);\n        if (box) {\n            boxes.push(box);\n\n            // draw patch-labels if requested\n            if (ENV.development && _config.debug.showRemainingPatchLabels) {\n                for ( j = 0; j < patches.length; j++) {\n                    patch = patches[j];\n                    hsv[0] = (topLabels[i].label / (maxLabel + 1)) * 360;\n                    hsv2rgb(hsv, rgb);\n                    ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                        {color: \"rgb(\" + rgb.join(\",\") + \")\", lineWidth: 2});\n                }\n            }\n        }\n    }\n    return boxes;\n}\n\n/**\n * Find similar moments (via cluster)\n * @param {Object} moments\n */\nfunction similarMoments(moments) {\n    var clusters = cluster(moments, 0.90);\n    var topCluster = topGeneric(clusters, 1, function(e) {\n        return e.getPoints().length;\n    });\n    var points = [], result = [];\n    if (topCluster.length === 1) {\n        points = topCluster[0].item.getPoints();\n        for (var i = 0; i < points.length; i++) {\n            result.push(points[i].point);\n        }\n    }\n    return result;\n}\n\nfunction skeletonize(x, y) {\n    _binaryImageWrapper.subImageAsCopy(_subImageWrapper, imageRef(x, y));\n    _skeletonizer.skeletonize();\n\n    // Show skeleton if requested\n    if (ENV.development && _config.debug.showSkeleton) {\n        _skelImageWrapper.overlay(_canvasContainer.dom.binary, 360, imageRef(x, y));\n    }\n}\n\n/**\n * Extracts and describes those patches which seem to contain a barcode pattern\n * @param {Array} moments\n * @param {Object} patchPos,\n * @param {Number} x\n * @param {Number} y\n * @returns {Array} list of patches\n */\nfunction describePatch(moments, patchPos, x, y) {\n    var k,\n        avg,\n        eligibleMoments = [],\n        matchingMoments,\n        patch,\n        patchesFound = [],\n        minComponentWeight = Math.ceil(_patchSize.x / 3);\n\n    if (moments.length >= 2) {\n        // only collect moments which's area covers at least minComponentWeight pixels.\n        for ( k = 0; k < moments.length; k++) {\n            if (moments[k].m00 > minComponentWeight) {\n                eligibleMoments.push(moments[k]);\n            }\n        }\n\n        // if at least 2 moments are found which have at least minComponentWeights covered\n        if (eligibleMoments.length >= 2) {\n            matchingMoments = similarMoments(eligibleMoments);\n            avg = 0;\n            // determine the similarity of the moments\n            for ( k = 0; k < matchingMoments.length; k++) {\n                avg += matchingMoments[k].rad;\n            }\n\n            // Only two of the moments are allowed not to fit into the equation\n            // add the patch to the set\n            if (matchingMoments.length > 1\n                    && matchingMoments.length >= (eligibleMoments.length / 4) * 3\n                    && matchingMoments.length > moments.length / 4) {\n                avg /= matchingMoments.length;\n                patch = {\n                    index: patchPos[1] * _numPatches.x + patchPos[0],\n                    pos: {\n                        x: x,\n                        y: y\n                    },\n                    box: [\n                        vec2.clone([x, y]),\n                        vec2.clone([x + _subImageWrapper.size.x, y]),\n                        vec2.clone([x + _subImageWrapper.size.x, y + _subImageWrapper.size.y]),\n                        vec2.clone([x, y + _subImageWrapper.size.y])\n                    ],\n                    moments: matchingMoments,\n                    rad: avg,\n                    vec: vec2.clone([Math.cos(avg), Math.sin(avg)])\n                };\n                patchesFound.push(patch);\n            }\n        }\n    }\n    return patchesFound;\n}\n\n/**\n * finds patches which are connected and share the same orientation\n * @param {Object} patchesFound\n */\nfunction rasterizeAngularSimilarity(patchesFound) {\n    var label = 0,\n        threshold = 0.95,\n        currIdx = 0,\n        j,\n        patch,\n        hsv = [0, 1, 1],\n        rgb = [0, 0, 0];\n\n    function notYetProcessed() {\n        var i;\n        for ( i = 0; i < _patchLabelGrid.data.length; i++) {\n            if (_patchLabelGrid.data[i] === 0 && _patchGrid.data[i] === 1) {\n                return i;\n            }\n        }\n        return _patchLabelGrid.length;\n    }\n\n    function trace(currentIdx) {\n        var x,\n            y,\n            currentPatch,\n            idx,\n            dir,\n            current = {\n                x: currentIdx % _patchLabelGrid.size.x,\n                y: (currentIdx / _patchLabelGrid.size.x) | 0\n            },\n            similarity;\n\n        if (currentIdx < _patchLabelGrid.data.length) {\n            currentPatch = _imageToPatchGrid.data[currentIdx];\n            // assign label\n            _patchLabelGrid.data[currentIdx] = label;\n            for ( dir = 0; dir < Tracer.searchDirections.length; dir++) {\n                y = current.y + Tracer.searchDirections[dir][0];\n                x = current.x + Tracer.searchDirections[dir][1];\n                idx = y * _patchLabelGrid.size.x + x;\n\n                // continue if patch empty\n                if (_patchGrid.data[idx] === 0) {\n                    _patchLabelGrid.data[idx] = Number.MAX_VALUE;\n                    continue;\n                }\n\n                if (_patchLabelGrid.data[idx] === 0) {\n                    similarity = Math.abs(vec2.dot(_imageToPatchGrid.data[idx].vec, currentPatch.vec));\n                    if (similarity > threshold) {\n                        trace(idx);\n                    }\n                }\n            }\n        }\n    }\n\n    // prepare for finding the right patches\n    ArrayHelper.init(_patchGrid.data, 0);\n    ArrayHelper.init(_patchLabelGrid.data, 0);\n    ArrayHelper.init(_imageToPatchGrid.data, null);\n\n    for ( j = 0; j < patchesFound.length; j++) {\n        patch = patchesFound[j];\n        _imageToPatchGrid.data[patch.index] = patch;\n        _patchGrid.data[patch.index] = 1;\n    }\n\n    // rasterize the patches found to determine area\n    _patchGrid.zeroBorder();\n\n    while (( currIdx = notYetProcessed()) < _patchLabelGrid.data.length) {\n        label++;\n        trace(currIdx);\n    }\n\n    // draw patch-labels if requested\n    if (ENV.development && _config.debug.showPatchLabels) {\n        for ( j = 0; j < _patchLabelGrid.data.length; j++) {\n            if (_patchLabelGrid.data[j] > 0 && _patchLabelGrid.data[j] <= label) {\n                patch = _imageToPatchGrid.data[j];\n                hsv[0] = (_patchLabelGrid.data[j] / (label + 1)) * 360;\n                hsv2rgb(hsv, rgb);\n                ImageDebug.drawRect(patch.pos, _subImageWrapper.size, _canvasContainer.ctx.binary,\n                    {color: \"rgb(\" + rgb.join(\",\") + \")\", lineWidth: 2});\n            }\n        }\n    }\n\n    return label;\n}\n\nexport default {\n    init: function(inputImageWrapper, config) {\n        _config = config;\n        _inputImageWrapper = inputImageWrapper;\n\n        initBuffers();\n        initCanvas();\n    },\n\n    locate: function() {\n        var patchesFound,\n            topLabels,\n            boxes;\n\n        if (_config.halfSample) {\n            halfSample(_inputImageWrapper, _currentImageWrapper);\n        }\n\n        binarizeImage();\n        patchesFound = findPatches();\n        // return unless 5% or more patches are found\n        if (patchesFound.length < _numPatches.x * _numPatches.y * 0.05) {\n            return null;\n        }\n\n        // rasterrize area by comparing angular similarity;\n        var maxLabel = rasterizeAngularSimilarity(patchesFound);\n        if (maxLabel < 1) {\n            return null;\n        }\n\n        // search for area with the most patches (biggest connected area)\n        topLabels = findBiggestConnectedAreas(maxLabel);\n        if (topLabels.length === 0) {\n            return null;\n        }\n\n        boxes = findBoxes(topLabels, maxLabel);\n        return boxes;\n    },\n\n    checkImageConstraints: function(inputStream, config) {\n        var patchSize,\n            width = inputStream.getWidth(),\n            height = inputStream.getHeight(),\n            halfSample = config.halfSample ? 0.5 : 1,\n            size,\n            area;\n\n        // calculate width and height based on area\n        if (inputStream.getConfig().area) {\n            area = computeImageArea(width, height, inputStream.getConfig().area);\n            inputStream.setTopRight({x: area.sx, y: area.sy});\n            inputStream.setCanvasSize({x: width, y: height});\n            width = area.sw;\n            height = area.sh;\n        }\n\n        size = {\n            x: Math.floor(width * halfSample),\n            y: Math.floor(height * halfSample)\n        };\n\n        patchSize = calculatePatchSize(config.patchSize, size);\n        if (ENV.development) {\n            console.log(\"Patch-Size: \" + JSON.stringify(patchSize));\n        }\n\n        inputStream.setWidth(Math.floor(Math.floor(size.x / patchSize.x) * (1 / halfSample) * patchSize.x));\n        inputStream.setHeight(Math.floor(Math.floor(size.y / patchSize.y) * (1 / halfSample) * patchSize.y));\n\n        if ((inputStream.getWidth() % patchSize.x) === 0 && (inputStream.getHeight() % patchSize.y) === 0) {\n            return true;\n        }\n\n        throw new Error(\"Image dimensions do not comply with the current settings: Width (\" +\n            width + \" )and height (\" + height +\n            \") must a multiple of \" + patchSize.x);\n    }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/barcode_locator.js","import Tracer from './tracer';\n\n/**\n * http://www.codeproject.com/Tips/407172/Connected-Component-Labeling-and-Vectorization\n */\nvar Rasterizer = {\n    createContour2D: function() {\n        return {\n            dir: null,\n            index: null,\n            firstVertex: null,\n            insideContours: null,\n            nextpeer: null,\n            prevpeer: null\n        };\n    },\n    CONTOUR_DIR: {\n        CW_DIR: 0,\n        CCW_DIR: 1,\n        UNKNOWN_DIR: 2\n    },\n    DIR: {\n        OUTSIDE_EDGE: -32767,\n        INSIDE_EDGE: -32766\n    },\n    create: function(imageWrapper, labelWrapper) {\n        var imageData = imageWrapper.data,\n            labelData = labelWrapper.data,\n            width = imageWrapper.size.x,\n            height = imageWrapper.size.y,\n            tracer = Tracer.create(imageWrapper, labelWrapper);\n\n        return {\n            rasterize: function(depthlabel) {\n                var color,\n                    bc,\n                    lc,\n                    labelindex,\n                    cx,\n                    cy,\n                    colorMap = [],\n                    vertex,\n                    p,\n                    cc,\n                    sc,\n                    pos,\n                    connectedCount = 0,\n                    i;\n\n                for ( i = 0; i < 400; i++) {\n                    colorMap[i] = 0;\n                }\n\n                colorMap[0] = imageData[0];\n                cc = null;\n                for ( cy = 1; cy < height - 1; cy++) {\n                    labelindex = 0;\n                    bc = colorMap[0];\n                    for ( cx = 1; cx < width - 1; cx++) {\n                        pos = cy * width + cx;\n                        if (labelData[pos] === 0) {\n                            color = imageData[pos];\n                            if (color !== bc) {\n                                if (labelindex === 0) {\n                                    lc = connectedCount + 1;\n                                    colorMap[lc] = color;\n                                    bc = color;\n                                    vertex = tracer.contourTracing(cy, cx, lc, color, Rasterizer.DIR.OUTSIDE_EDGE);\n                                    if (vertex !== null) {\n                                        connectedCount++;\n                                        labelindex = lc;\n                                        p = Rasterizer.createContour2D();\n                                        p.dir = Rasterizer.CONTOUR_DIR.CW_DIR;\n                                        p.index = labelindex;\n                                        p.firstVertex = vertex;\n                                        p.nextpeer = cc;\n                                        p.insideContours = null;\n                                        if (cc !== null) {\n                                            cc.prevpeer = p;\n                                        }\n                                        cc = p;\n                                    }\n                                } else {\n                                    vertex = tracer\n                                        .contourTracing(cy, cx, Rasterizer.DIR.INSIDE_EDGE, color, labelindex);\n                                    if (vertex !== null) {\n                                        p = Rasterizer.createContour2D();\n                                        p.firstVertex = vertex;\n                                        p.insideContours = null;\n                                        if (depthlabel === 0) {\n                                            p.dir = Rasterizer.CONTOUR_DIR.CCW_DIR;\n                                        } else {\n                                            p.dir = Rasterizer.CONTOUR_DIR.CW_DIR;\n                                        }\n                                        p.index = depthlabel;\n                                        sc = cc;\n                                        while ((sc !== null) && sc.index !== labelindex) {\n                                            sc = sc.nextpeer;\n                                        }\n                                        if (sc !== null) {\n                                            p.nextpeer = sc.insideContours;\n                                            if (sc.insideContours !== null) {\n                                                sc.insideContours.prevpeer = p;\n                                            }\n                                            sc.insideContours = p;\n                                        }\n                                    }\n                                }\n                            } else {\n                                labelData[pos] = labelindex;\n                            }\n                        } else if (labelData[pos] === Rasterizer.DIR.OUTSIDE_EDGE\n                                || labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) {\n                            labelindex = 0;\n                            if (labelData[pos] === Rasterizer.DIR.INSIDE_EDGE) {\n                                bc = imageData[pos];\n                            } else {\n                                bc = colorMap[0];\n                            }\n                        } else {\n                            labelindex = labelData[pos];\n                            bc = colorMap[labelindex];\n                        }\n                    }\n                }\n                sc = cc;\n                while (sc !== null) {\n                    sc.index = depthlabel;\n                    sc = sc.nextpeer;\n                }\n                return {\n                    cc: cc,\n                    count: connectedCount\n                };\n            },\n            debug: {\n                drawContour: function(canvas, firstContour) {\n                    var ctx = canvas.getContext(\"2d\"),\n                        pq = firstContour,\n                        iq,\n                        q,\n                        p;\n\n                    ctx.strokeStyle = \"red\";\n                    ctx.fillStyle = \"red\";\n                    ctx.lineWidth = 1;\n\n                    if (pq !== null) {\n                        iq = pq.insideContours;\n                    } else {\n                        iq = null;\n                    }\n\n                    while (pq !== null) {\n                        if (iq !== null) {\n                            q = iq;\n                            iq = iq.nextpeer;\n                        } else {\n                            q = pq;\n                            pq = pq.nextpeer;\n                            if (pq !== null) {\n                                iq = pq.insideContours;\n                            } else {\n                                iq = null;\n                            }\n                        }\n\n                        switch (q.dir) {\n                        case Rasterizer.CONTOUR_DIR.CW_DIR:\n                            ctx.strokeStyle = \"red\";\n                            break;\n                        case Rasterizer.CONTOUR_DIR.CCW_DIR:\n                            ctx.strokeStyle = \"blue\";\n                            break;\n                        case Rasterizer.CONTOUR_DIR.UNKNOWN_DIR:\n                            ctx.strokeStyle = \"green\";\n                            break;\n                        }\n\n                        p = q.firstVertex;\n                        ctx.beginPath();\n                        ctx.moveTo(p.x, p.y);\n                        do {\n                            p = p.next;\n                            ctx.lineTo(p.x, p.y);\n                        } while (p !== q.firstVertex);\n                        ctx.stroke();\n                    }\n                }\n            }\n        };\n    }\n};\n\nexport default Rasterizer;\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/rasterizer.js","/* @preserve ASM BEGIN */\n/* eslint-disable eqeqeq*/\nfunction Skeletonizer(stdlib, foreign, buffer) {\n    \"use asm\";\n\n    var images = new stdlib.Uint8Array(buffer),\n        size = foreign.size | 0,\n        imul = stdlib.Math.imul;\n\n    function erode(inImagePtr, outImagePtr) {\n        inImagePtr = inImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var v = 0,\n            u = 0,\n            sum = 0,\n            yStart1 = 0,\n            yStart2 = 0,\n            xStart1 = 0,\n            xStart2 = 0,\n            offset = 0;\n\n        for ( v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\n            offset = (offset + size) | 0;\n            for ( u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\n                yStart1 = (offset - size) | 0;\n                yStart2 = (offset + size) | 0;\n                xStart1 = (u - 1) | 0;\n                xStart2 = (u + 1) | 0;\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\n                if ((sum | 0) == (5 | 0)) {\n                    images[(outImagePtr + offset + u) | 0] = 1;\n                } else {\n                    images[(outImagePtr + offset + u) | 0] = 0;\n                }\n            }\n        }\n        return;\n    }\n\n    function subtract(aImagePtr, bImagePtr, outImagePtr) {\n        aImagePtr = aImagePtr | 0;\n        bImagePtr = bImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(outImagePtr + length) | 0] =\n                ((images[(aImagePtr + length) | 0] | 0) - (images[(bImagePtr + length) | 0] | 0)) | 0;\n        }\n    }\n\n    function bitwiseOr(aImagePtr, bImagePtr, outImagePtr) {\n        aImagePtr = aImagePtr | 0;\n        bImagePtr = bImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(outImagePtr + length) | 0] =\n                ((images[(aImagePtr + length) | 0] | 0) | (images[(bImagePtr + length) | 0] | 0)) | 0;\n        }\n    }\n\n    function countNonZero(imagePtr) {\n        imagePtr = imagePtr | 0;\n\n        var sum = 0,\n            length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            sum = ((sum | 0) + (images[(imagePtr + length) | 0] | 0)) | 0;\n        }\n\n        return (sum | 0);\n    }\n\n    function init(imagePtr, value) {\n        imagePtr = imagePtr | 0;\n        value = value | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(imagePtr + length) | 0] = value;\n        }\n    }\n\n    function dilate(inImagePtr, outImagePtr) {\n        inImagePtr = inImagePtr | 0;\n        outImagePtr = outImagePtr | 0;\n\n        var v = 0,\n            u = 0,\n            sum = 0,\n            yStart1 = 0,\n            yStart2 = 0,\n            xStart1 = 0,\n            xStart2 = 0,\n            offset = 0;\n\n        for ( v = 1; (v | 0) < ((size - 1) | 0); v = (v + 1) | 0) {\n            offset = (offset + size) | 0;\n            for ( u = 1; (u | 0) < ((size - 1) | 0); u = (u + 1) | 0) {\n                yStart1 = (offset - size) | 0;\n                yStart2 = (offset + size) | 0;\n                xStart1 = (u - 1) | 0;\n                xStart2 = (u + 1) | 0;\n                sum = ((images[(inImagePtr + yStart1 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart1 + xStart2) | 0] | 0)\n                    + (images[(inImagePtr + offset + u) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart1) | 0] | 0)\n                    + (images[(inImagePtr + yStart2 + xStart2) | 0] | 0)) | 0;\n                if ((sum | 0) > (0 | 0)) {\n                    images[(outImagePtr + offset + u) | 0] = 1;\n                } else {\n                    images[(outImagePtr + offset + u) | 0] = 0;\n                }\n            }\n        }\n        return;\n    }\n\n    function memcpy(srcImagePtr, dstImagePtr) {\n        srcImagePtr = srcImagePtr | 0;\n        dstImagePtr = dstImagePtr | 0;\n\n        var length = 0;\n\n        length = imul(size, size) | 0;\n\n        while ((length | 0) > 0) {\n            length = (length - 1) | 0;\n            images[(dstImagePtr + length) | 0] = (images[(srcImagePtr + length) | 0] | 0);\n        }\n    }\n\n    function zeroBorder(imagePtr) {\n        imagePtr = imagePtr | 0;\n\n        var x = 0,\n            y = 0;\n\n        for ( x = 0; (x | 0) < ((size - 1) | 0); x = (x + 1) | 0) {\n            images[(imagePtr + x) | 0] = 0;\n            images[(imagePtr + y) | 0] = 0;\n            y = ((y + size) - 1) | 0;\n            images[(imagePtr + y) | 0] = 0;\n            y = (y + 1) | 0;\n        }\n        for ( x = 0; (x | 0) < (size | 0); x = (x + 1) | 0) {\n            images[(imagePtr + y) | 0] = 0;\n            y = (y + 1) | 0;\n        }\n    }\n\n    function skeletonize() {\n        var subImagePtr = 0,\n            erodedImagePtr = 0,\n            tempImagePtr = 0,\n            skelImagePtr = 0,\n            sum = 0,\n            done = 0;\n\n        erodedImagePtr = imul(size, size) | 0;\n        tempImagePtr = (erodedImagePtr + erodedImagePtr) | 0;\n        skelImagePtr = (tempImagePtr + erodedImagePtr) | 0;\n\n        // init skel-image\n        init(skelImagePtr, 0);\n        zeroBorder(subImagePtr);\n\n        do {\n            erode(subImagePtr, erodedImagePtr);\n            dilate(erodedImagePtr, tempImagePtr);\n            subtract(subImagePtr, tempImagePtr, tempImagePtr);\n            bitwiseOr(skelImagePtr, tempImagePtr, skelImagePtr);\n            memcpy(erodedImagePtr, subImagePtr);\n            sum = countNonZero(subImagePtr) | 0;\n            done = ((sum | 0) == 0 | 0);\n        } while (!done);\n    }\n    return {\n        skeletonize: skeletonize\n    };\n}\n/* @preserve ASM END */\nexport default Skeletonizer;\n/* eslint-enable eqeqeq*/\n\n\n\n// WEBPACK FOOTER //\n// ./src/locator/skeletonizer.js","import BarcodeReader from './barcode_reader';\n\nfunction TwoOfFiveReader(opts) {\n    BarcodeReader.call(this, opts);\n    this.barSpaceRatio = [1, 1];\n}\n\nvar N = 1,\n    W = 3,\n    properties = {\n        START_PATTERN: {value: [W, N, W, N, N, N]},\n        STOP_PATTERN: {value: [W, N, N, N, W]},\n        CODE_PATTERN: {value: [\n            [N, N, W, W, N],\n            [W, N, N, N, W],\n            [N, W, N, N, W],\n            [W, W, N, N, N],\n            [N, N, W, N, W],\n            [W, N, W, N, N],\n            [N, W, W, N, N],\n            [N, N, N, W, W],\n            [W, N, N, W, N],\n            [N, W, N, W, N]\n        ]},\n        SINGLE_CODE_ERROR: {value: 0.78, writable: true},\n        AVG_CODE_ERROR: {value: 0.30, writable: true},\n        FORMAT: {value: \"2of5\"}\n    };\n\nconst startPatternLength = properties.START_PATTERN.value.reduce((sum, val) => sum + val, 0);\n\nTwoOfFiveReader.prototype = Object.create(BarcodeReader.prototype, properties);\nTwoOfFiveReader.prototype.constructor = TwoOfFiveReader;\n\nTwoOfFiveReader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder) {\n    var counter = [],\n        self = this,\n        i,\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        },\n        error,\n        j,\n        sum,\n        epsilon = self.AVG_CODE_ERROR;\n\n    isWhite = isWhite || false;\n    tryHarder = tryHarder || false;\n\n    if (!offset) {\n        offset = self._nextSet(self._row);\n    }\n\n    for ( i = 0; i < pattern.length; i++) {\n        counter[i] = 0;\n    }\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                sum = 0;\n                for ( j = 0; j < counter.length; j++) {\n                    sum += counter[j];\n                }\n                error = self._matchPattern(counter, pattern);\n                if (error < epsilon) {\n                    bestMatch.error = error;\n                    bestMatch.start = i - sum;\n                    bestMatch.end = i;\n                    return bestMatch;\n                }\n                if (tryHarder) {\n                    for (j = 0; j < counter.length - 2; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[counter.length - 2] = 0;\n                    counter[counter.length - 1] = 0;\n                    counterPos--;\n                } else {\n                    return null;\n                }\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nTwoOfFiveReader.prototype._findStart = function() {\n    var self = this,\n        leadingWhitespaceStart,\n        offset = self._nextSet(self._row),\n        startInfo,\n        narrowBarWidth = 1;\n\n    while (!startInfo) {\n        startInfo = self._findPattern(self.START_PATTERN, offset, false, true);\n        if (!startInfo) {\n            return null;\n        }\n        narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / startPatternLength);\n        leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5;\n        if (leadingWhitespaceStart >= 0) {\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                return startInfo;\n            }\n        }\n        offset = startInfo.end;\n        startInfo = null;\n    }\n};\n\nTwoOfFiveReader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n    return null;\n};\n\nTwoOfFiveReader.prototype._findEnd = function() {\n    var self = this,\n        endInfo,\n        tmp,\n        offset;\n\n    self._row.reverse();\n    offset = self._nextSet(self._row);\n    endInfo = self._findPattern(self.STOP_PATTERN, offset, false, true);\n    self._row.reverse();\n\n    if (endInfo === null) {\n        return null;\n    }\n\n    // reverse numbers\n    tmp = endInfo.start;\n    endInfo.start = self._row.length - endInfo.end;\n    endInfo.end = self._row.length - tmp;\n\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\n};\n\nTwoOfFiveReader.prototype._decodeCode = function(counter) {\n    var j,\n        self = this,\n        sum = 0,\n        normalized,\n        error,\n        epsilon = self.AVG_CODE_ERROR,\n        code,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        };\n\n    for ( j = 0; j < counter.length; j++) {\n        sum += counter[j];\n    }\n    for (code = 0; code < self.CODE_PATTERN.length; code++) {\n        error = self._matchPattern(counter, self.CODE_PATTERN[code]);\n        if (error < bestMatch.error) {\n            bestMatch.code = code;\n            bestMatch.error = error;\n        }\n    }\n    if (bestMatch.error < epsilon) {\n        return bestMatch;\n    }\n};\n\nTwoOfFiveReader.prototype._decodePayload = function(counters, result, decodedCodes) {\n    var i,\n        self = this,\n        pos = 0,\n        counterLength = counters.length,\n        counter = [0, 0, 0, 0, 0],\n        code;\n\n    while (pos < counterLength) {\n        for (i = 0; i < 5; i++) {\n            counter[i] = counters[pos] * this.barSpaceRatio[0];\n            pos += 2;\n        }\n        code = self._decodeCode(counter);\n        if (!code) {\n            return null;\n        }\n        result.push(code.code + \"\");\n        decodedCodes.push(code);\n    }\n    return code;\n};\n\nTwoOfFiveReader.prototype._verifyCounterLength = function(counters) {\n    return (counters.length % 10 === 0);\n};\n\nTwoOfFiveReader.prototype._decode = function() {\n    var startInfo,\n        endInfo,\n        self = this,\n        code,\n        result = [],\n        decodedCodes = [],\n        counters;\n\n    startInfo = self._findStart();\n    if (!startInfo) {\n        return null;\n    }\n    decodedCodes.push(startInfo);\n\n    endInfo = self._findEnd();\n    if (!endInfo) {\n        return null;\n    }\n\n    counters = self._fillCounters(startInfo.end, endInfo.start, false);\n    if (!self._verifyCounterLength(counters)) {\n        return null;\n    }\n    code = self._decodePayload(counters, result, decodedCodes);\n    if (!code) {\n        return null;\n    }\n    if (result.length < 5) {\n        return null;\n    }\n\n    decodedCodes.push(endInfo);\n    return {\n        code: result.join(\"\"),\n        start: startInfo.start,\n        end: endInfo.end,\n        startInfo: startInfo,\n        decodedCodes: decodedCodes\n    };\n};\n\nexport default TwoOfFiveReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/2of5_reader.js","import BarcodeReader from './barcode_reader';\n\nfunction CodabarReader() {\n    BarcodeReader.call(this);\n    this._counters = [];\n}\n\nvar properties = {\n    ALPHABETH_STRING: {value: \"0123456789-$:/.+ABCD\"},\n    ALPHABET: {value: [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 45, 36, 58, 47, 46, 43, 65, 66, 67, 68]},\n    CHARACTER_ENCODINGS: {value: [0x003, 0x006, 0x009, 0x060, 0x012, 0x042, 0x021, 0x024, 0x030, 0x048, 0x00c, 0x018,\n        0x045, 0x051, 0x054, 0x015, 0x01A, 0x029, 0x00B, 0x00E]},\n    START_END: {value: [0x01A, 0x029, 0x00B, 0x00E]},\n    MIN_ENCODED_CHARS: {value: 4},\n    MAX_ACCEPTABLE: {value: 2.0},\n    PADDING: {value: 1.5},\n    FORMAT: {value: \"codabar\", writeable: false}\n};\n\nCodabarReader.prototype = Object.create(BarcodeReader.prototype, properties);\nCodabarReader.prototype.constructor = CodabarReader;\n\nCodabarReader.prototype._decode = function() {\n    var self = this,\n        result = [],\n        start,\n        decodedChar,\n        pattern,\n        nextStart,\n        end;\n\n    this._counters = self._fillCounters();\n    start = self._findStart();\n    if (!start) {\n        return null;\n    }\n    nextStart = start.startCounter;\n\n    do {\n        pattern = self._toPattern(nextStart);\n        if (pattern < 0) {\n            return null;\n        }\n        decodedChar = self._patternToChar(pattern);\n        if (decodedChar < 0){\n            return null;\n        }\n        result.push(decodedChar);\n        nextStart += 8;\n        if (result.length > 1 && self._isStartEnd(pattern)) {\n            break;\n        }\n    } while (nextStart < self._counters.length);\n\n    // verify end\n    if ((result.length - 2) < self.MIN_ENCODED_CHARS || !self._isStartEnd(pattern)) {\n        return null;\n    }\n\n    // verify end white space\n    if (!self._verifyWhitespace(start.startCounter, nextStart - 8)){\n        return null;\n    }\n\n    if (!self._validateResult(result, start.startCounter)){\n        return null;\n    }\n\n    nextStart = nextStart > self._counters.length ? self._counters.length : nextStart;\n    end = start.start + self._sumCounters(start.startCounter, nextStart - 8);\n\n    return {\n        code: result.join(\"\"),\n        start: start.start,\n        end: end,\n        startInfo: start,\n        decodedCodes: result\n    };\n};\n\nCodabarReader.prototype._verifyWhitespace = function(startCounter, endCounter) {\n    if ((startCounter - 1 <= 0)\n            || this._counters[startCounter - 1] >= (this._calculatePatternLength(startCounter) / 2.0)) {\n        if ((endCounter + 8 >= this._counters.length)\n                || this._counters[endCounter + 7] >= (this._calculatePatternLength(endCounter) / 2.0)) {\n            return true;\n        }\n    }\n    return false;\n};\n\nCodabarReader.prototype._calculatePatternLength = function(offset) {\n    var i,\n        sum = 0;\n\n    for (i = offset; i < offset + 7; i++) {\n        sum += this._counters[i];\n    }\n\n    return sum;\n};\n\nCodabarReader.prototype._thresholdResultPattern = function(result, startCounter){\n    var self = this,\n        categorization = {\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        kind,\n        cat,\n        i,\n        j,\n        pos = startCounter,\n        pattern;\n\n    for (i = 0; i < result.length; i++){\n        pattern = self._charToPattern(result[i]);\n        for (j = 6; j >= 0; j--) {\n            kind = (j & 1) === 2 ? categorization.bar : categorization.space;\n            cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\n            cat.size += self._counters[pos + j];\n            cat.counts++;\n            pattern >>= 1;\n        }\n        pos += 8;\n    }\n\n    [\"space\", \"bar\"].forEach(function(key) {\n        var newkind = categorization[key];\n        newkind.wide.min =\n            Math.floor((newkind.narrow.size / newkind.narrow.counts + newkind.wide.size / newkind.wide.counts) / 2);\n        newkind.narrow.max = Math.ceil(newkind.wide.min);\n        newkind.wide.max = Math.ceil((newkind.wide.size * self.MAX_ACCEPTABLE + self.PADDING) / newkind.wide.counts);\n    });\n\n    return categorization;\n};\n\nCodabarReader.prototype._charToPattern = function(char) {\n    var self = this,\n        charCode = char.charCodeAt(0),\n        i;\n\n    for (i = 0; i < self.ALPHABET.length; i++) {\n        if (self.ALPHABET[i] === charCode){\n            return self.CHARACTER_ENCODINGS[i];\n        }\n    }\n    return 0x0;\n};\n\nCodabarReader.prototype._validateResult = function(result, startCounter) {\n    var self = this,\n        thresholds = self._thresholdResultPattern(result, startCounter),\n        i,\n        j,\n        kind,\n        cat,\n        size,\n        pos = startCounter,\n        pattern;\n\n    for (i = 0; i < result.length; i++) {\n        pattern = self._charToPattern(result[i]);\n        for (j = 6; j >= 0; j--) {\n            kind = (j & 1) === 0 ? thresholds.bar : thresholds.space;\n            cat = (pattern & 1) === 1 ? kind.wide : kind.narrow;\n            size = self._counters[pos + j];\n            if (size < cat.min || size > cat.max) {\n                return false;\n            }\n            pattern >>= 1;\n        }\n        pos += 8;\n    }\n    return true;\n};\n\nCodabarReader.prototype._patternToChar = function(pattern) {\n    var i,\n        self = this;\n\n    for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {\n        if (self.CHARACTER_ENCODINGS[i] === pattern) {\n            return String.fromCharCode(self.ALPHABET[i]);\n        }\n    }\n    return -1;\n};\n\nCodabarReader.prototype._computeAlternatingThreshold = function(offset, end) {\n    var i,\n        min = Number.MAX_VALUE,\n        max = 0,\n        counter;\n\n    for (i = offset; i < end; i += 2){\n        counter = this._counters[i];\n        if (counter > max) {\n            max = counter;\n        }\n        if (counter < min) {\n            min = counter;\n        }\n    }\n\n    return ((min + max) / 2.0) | 0;\n};\n\nCodabarReader.prototype._toPattern = function(offset) {\n    var numCounters = 7,\n        end = offset + numCounters,\n        barThreshold,\n        spaceThreshold,\n        bitmask = 1 << (numCounters - 1),\n        pattern = 0,\n        i,\n        threshold;\n\n    if (end > this._counters.length) {\n        return -1;\n    }\n\n    barThreshold = this._computeAlternatingThreshold(offset, end);\n    spaceThreshold = this._computeAlternatingThreshold(offset + 1, end);\n\n    for (i = 0; i < numCounters; i++){\n        threshold = (i & 1) === 0 ? barThreshold : spaceThreshold;\n        if (this._counters[offset + i] > threshold) {\n            pattern |= bitmask;\n        }\n        bitmask >>= 1;\n    }\n\n    return pattern;\n};\n\nCodabarReader.prototype._isStartEnd = function(pattern) {\n    var i;\n\n    for (i = 0; i < this.START_END.length; i++) {\n        if (this.START_END[i] === pattern) {\n            return true;\n        }\n    }\n    return false;\n};\n\nCodabarReader.prototype._sumCounters = function(start, end) {\n    var i,\n        sum = 0;\n\n    for (i = start; i < end; i++) {\n        sum += this._counters[i];\n    }\n    return sum;\n};\n\nCodabarReader.prototype._findStart = function() {\n    var self = this,\n        i,\n        pattern,\n        start = self._nextUnset(self._row),\n        end;\n\n    for (i = 1; i < this._counters.length; i++) {\n        pattern = self._toPattern(i);\n        if (pattern !== -1 && self._isStartEnd(pattern)) {\n            // TODO: Look for whitespace ahead\n            start += self._sumCounters(0, i);\n            end = start + self._sumCounters(i, i + 8);\n            return {\n                start: start,\n                end: end,\n                startCounter: i,\n                endCounter: i + 8\n            };\n        }\n    }\n};\n\nexport default CodabarReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/codabar_reader.js","import BarcodeReader from './barcode_reader';\n\nfunction Code128Reader() {\n    BarcodeReader.call(this);\n}\n\nvar properties = {\n    CODE_SHIFT: {value: 98},\n    CODE_C: {value: 99},\n    CODE_B: {value: 100},\n    CODE_A: {value: 101},\n    START_CODE_A: {value: 103},\n    START_CODE_B: {value: 104},\n    START_CODE_C: {value: 105},\n    STOP_CODE: {value: 106},\n    CODE_PATTERN: {value: [\n        [2, 1, 2, 2, 2, 2],\n        [2, 2, 2, 1, 2, 2],\n        [2, 2, 2, 2, 2, 1],\n        [1, 2, 1, 2, 2, 3],\n        [1, 2, 1, 3, 2, 2],\n        [1, 3, 1, 2, 2, 2],\n        [1, 2, 2, 2, 1, 3],\n        [1, 2, 2, 3, 1, 2],\n        [1, 3, 2, 2, 1, 2],\n        [2, 2, 1, 2, 1, 3],\n        [2, 2, 1, 3, 1, 2],\n        [2, 3, 1, 2, 1, 2],\n        [1, 1, 2, 2, 3, 2],\n        [1, 2, 2, 1, 3, 2],\n        [1, 2, 2, 2, 3, 1],\n        [1, 1, 3, 2, 2, 2],\n        [1, 2, 3, 1, 2, 2],\n        [1, 2, 3, 2, 2, 1],\n        [2, 2, 3, 2, 1, 1],\n        [2, 2, 1, 1, 3, 2],\n        [2, 2, 1, 2, 3, 1],\n        [2, 1, 3, 2, 1, 2],\n        [2, 2, 3, 1, 1, 2],\n        [3, 1, 2, 1, 3, 1],\n        [3, 1, 1, 2, 2, 2],\n        [3, 2, 1, 1, 2, 2],\n        [3, 2, 1, 2, 2, 1],\n        [3, 1, 2, 2, 1, 2],\n        [3, 2, 2, 1, 1, 2],\n        [3, 2, 2, 2, 1, 1],\n        [2, 1, 2, 1, 2, 3],\n        [2, 1, 2, 3, 2, 1],\n        [2, 3, 2, 1, 2, 1],\n        [1, 1, 1, 3, 2, 3],\n        [1, 3, 1, 1, 2, 3],\n        [1, 3, 1, 3, 2, 1],\n        [1, 1, 2, 3, 1, 3],\n        [1, 3, 2, 1, 1, 3],\n        [1, 3, 2, 3, 1, 1],\n        [2, 1, 1, 3, 1, 3],\n        [2, 3, 1, 1, 1, 3],\n        [2, 3, 1, 3, 1, 1],\n        [1, 1, 2, 1, 3, 3],\n        [1, 1, 2, 3, 3, 1],\n        [1, 3, 2, 1, 3, 1],\n        [1, 1, 3, 1, 2, 3],\n        [1, 1, 3, 3, 2, 1],\n        [1, 3, 3, 1, 2, 1],\n        [3, 1, 3, 1, 2, 1],\n        [2, 1, 1, 3, 3, 1],\n        [2, 3, 1, 1, 3, 1],\n        [2, 1, 3, 1, 1, 3],\n        [2, 1, 3, 3, 1, 1],\n        [2, 1, 3, 1, 3, 1],\n        [3, 1, 1, 1, 2, 3],\n        [3, 1, 1, 3, 2, 1],\n        [3, 3, 1, 1, 2, 1],\n        [3, 1, 2, 1, 1, 3],\n        [3, 1, 2, 3, 1, 1],\n        [3, 3, 2, 1, 1, 1],\n        [3, 1, 4, 1, 1, 1],\n        [2, 2, 1, 4, 1, 1],\n        [4, 3, 1, 1, 1, 1],\n        [1, 1, 1, 2, 2, 4],\n        [1, 1, 1, 4, 2, 2],\n        [1, 2, 1, 1, 2, 4],\n        [1, 2, 1, 4, 2, 1],\n        [1, 4, 1, 1, 2, 2],\n        [1, 4, 1, 2, 2, 1],\n        [1, 1, 2, 2, 1, 4],\n        [1, 1, 2, 4, 1, 2],\n        [1, 2, 2, 1, 1, 4],\n        [1, 2, 2, 4, 1, 1],\n        [1, 4, 2, 1, 1, 2],\n        [1, 4, 2, 2, 1, 1],\n        [2, 4, 1, 2, 1, 1],\n        [2, 2, 1, 1, 1, 4],\n        [4, 1, 3, 1, 1, 1],\n        [2, 4, 1, 1, 1, 2],\n        [1, 3, 4, 1, 1, 1],\n        [1, 1, 1, 2, 4, 2],\n        [1, 2, 1, 1, 4, 2],\n        [1, 2, 1, 2, 4, 1],\n        [1, 1, 4, 2, 1, 2],\n        [1, 2, 4, 1, 1, 2],\n        [1, 2, 4, 2, 1, 1],\n        [4, 1, 1, 2, 1, 2],\n        [4, 2, 1, 1, 1, 2],\n        [4, 2, 1, 2, 1, 1],\n        [2, 1, 2, 1, 4, 1],\n        [2, 1, 4, 1, 2, 1],\n        [4, 1, 2, 1, 2, 1],\n        [1, 1, 1, 1, 4, 3],\n        [1, 1, 1, 3, 4, 1],\n        [1, 3, 1, 1, 4, 1],\n        [1, 1, 4, 1, 1, 3],\n        [1, 1, 4, 3, 1, 1],\n        [4, 1, 1, 1, 1, 3],\n        [4, 1, 1, 3, 1, 1],\n        [1, 1, 3, 1, 4, 1],\n        [1, 1, 4, 1, 3, 1],\n        [3, 1, 1, 1, 4, 1],\n        [4, 1, 1, 1, 3, 1],\n        [2, 1, 1, 4, 1, 2],\n        [2, 1, 1, 2, 1, 4],\n        [2, 1, 1, 2, 3, 2],\n        [2, 3, 3, 1, 1, 1, 2]\n    ]},\n    SINGLE_CODE_ERROR: {value: 0.64},\n    AVG_CODE_ERROR: {value: 0.30},\n    FORMAT: {value: \"code_128\", writeable: false},\n    MODULE_INDICES: {value: {bar: [0, 2, 4], space: [1, 3, 5]}}\n};\n\nCode128Reader.prototype = Object.create(BarcodeReader.prototype, properties);\nCode128Reader.prototype.constructor = Code128Reader;\n\nCode128Reader.prototype._decodeCode = function(start, correction) {\n    var counter = [0, 0, 0, 0, 0, 0],\n        i,\n        self = this,\n        offset = start,\n        isWhite = !self._row[offset],\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: start,\n            end: start,\n            correction: {\n                bar: 1,\n                space: 1\n            }\n        },\n        code,\n        error;\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                if (correction) {\n                    self._correct(counter, correction);\n                }\n                for (code = 0; code < self.CODE_PATTERN.length; code++) {\n                    error = self._matchPattern(counter, self.CODE_PATTERN[code]);\n                    if (error < bestMatch.error) {\n                        bestMatch.code = code;\n                        bestMatch.error = error;\n                    }\n                }\n                bestMatch.end = i;\n                if (bestMatch.code === -1 || bestMatch.error > self.AVG_CODE_ERROR) {\n                    return null;\n                }\n                if (self.CODE_PATTERN[bestMatch.code]) {\n                    bestMatch.correction.bar = calculateCorrection(\n                        self.CODE_PATTERN[bestMatch.code], counter,\n                        this.MODULE_INDICES.bar);\n                    bestMatch.correction.space = calculateCorrection(\n                        self.CODE_PATTERN[bestMatch.code], counter,\n                        this.MODULE_INDICES.space);\n                }\n                return bestMatch;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nCode128Reader.prototype._correct = function(counter, correction) {\n    this._correctBars(counter, correction.bar, this.MODULE_INDICES.bar);\n    this._correctBars(counter, correction.space, this.MODULE_INDICES.space);\n};\n\nCode128Reader.prototype._findStart = function() {\n    var counter = [0, 0, 0, 0, 0, 0],\n        i,\n        self = this,\n        offset = self._nextSet(self._row),\n        isWhite = false,\n        counterPos = 0,\n        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        code,\n        error,\n        j,\n        sum;\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                sum = 0;\n                for ( j = 0; j < counter.length; j++) {\n                    sum += counter[j];\n                }\n                for (code = self.START_CODE_A; code <= self.START_CODE_C; code++) {\n                    error = self._matchPattern(counter, self.CODE_PATTERN[code]);\n                    if (error < bestMatch.error) {\n                        bestMatch.code = code;\n                        bestMatch.error = error;\n                    }\n                }\n                if (bestMatch.error < self.AVG_CODE_ERROR) {\n                    bestMatch.start = i - sum;\n                    bestMatch.end = i;\n                    bestMatch.correction.bar = calculateCorrection(\n                        self.CODE_PATTERN[bestMatch.code], counter,\n                        this.MODULE_INDICES.bar);\n                    bestMatch.correction.space = calculateCorrection(\n                        self.CODE_PATTERN[bestMatch.code], counter,\n                        this.MODULE_INDICES.space);\n                    return bestMatch;\n                }\n\n                for ( j = 0; j < 4; j++) {\n                    counter[j] = counter[j + 2];\n                }\n                counter[4] = 0;\n                counter[5] = 0;\n                counterPos--;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nCode128Reader.prototype._decode = function() {\n    var self = this,\n        startInfo = self._findStart(),\n        code = null,\n        done = false,\n        result = [],\n        multiplier = 0,\n        checksum = 0,\n        codeset,\n        rawResult = [],\n        decodedCodes = [],\n        shiftNext = false,\n        unshift,\n        removeLastCharacter = true;\n\n    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    switch (code.code) {\n    case self.START_CODE_A:\n        codeset = self.CODE_A;\n        break;\n    case self.START_CODE_B:\n        codeset = self.CODE_B;\n        break;\n    case self.START_CODE_C:\n        codeset = self.CODE_C;\n        break;\n    default:\n        return null;\n    }\n\n    while (!done) {\n        unshift = shiftNext;\n        shiftNext = false;\n        code = self._decodeCode(code.end, code.correction);\n        if (code !== null) {\n            if (code.code !== self.STOP_CODE) {\n                removeLastCharacter = true;\n            }\n\n            if (code.code !== self.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 self.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 !== self.STOP_CODE) {\n                        removeLastCharacter = false;\n                    }\n                    switch (code.code) {\n                    case self.CODE_SHIFT:\n                        shiftNext = true;\n                        codeset = self.CODE_B;\n                        break;\n                    case self.CODE_B:\n                        codeset = self.CODE_B;\n                        break;\n                    case self.CODE_C:\n                        codeset = self.CODE_C;\n                        break;\n                    case self.STOP_CODE:\n                        done = true;\n                        break;\n                    }\n                }\n                break;\n            case self.CODE_B:\n                if (code.code < 96) {\n                    result.push(String.fromCharCode(32 + code.code));\n                } else {\n                    if (code.code !== self.STOP_CODE) {\n                        removeLastCharacter = false;\n                    }\n                    switch (code.code) {\n                    case self.CODE_SHIFT:\n                        shiftNext = true;\n                        codeset = self.CODE_A;\n                        break;\n                    case self.CODE_A:\n                        codeset = self.CODE_A;\n                        break;\n                    case self.CODE_C:\n                        codeset = self.CODE_C;\n                        break;\n                    case self.STOP_CODE:\n                        done = true;\n                        break;\n                    }\n                }\n                break;\n            case self.CODE_C:\n                if (code.code < 100) {\n                    result.push(code.code < 10 ? \"0\" + code.code : code.code);\n                } else {\n                    if (code.code !== self.STOP_CODE) {\n                        removeLastCharacter = false;\n                    }\n                    switch (code.code) {\n                    case self.CODE_A:\n                        codeset = self.CODE_A;\n                        break;\n                    case self.CODE_B:\n                        codeset = self.CODE_B;\n                        break;\n                    case self.STOP_CODE:\n                        done = true;\n                        break;\n                    }\n                }\n                break;\n            }\n        } else {\n            done = true;\n        }\n        if (unshift) {\n            codeset = codeset === self.CODE_A ? self.CODE_B : self.CODE_A;\n        }\n    }\n\n    if (code === null) {\n        return null;\n    }\n\n    code.end = self._nextUnset(self._row, code.end);\n    if (!self._verifyTrailingWhitespace(code)){\n        return null;\n    }\n\n    checksum -= multiplier * rawResult[rawResult.length - 1];\n    if (checksum % 103 !== rawResult[rawResult.length - 1]) {\n        return null;\n    }\n\n    if (!result.length) {\n        return null;\n    }\n\n    // remove last code from result (checksum)\n    if (removeLastCharacter) {\n        result.splice(result.length - 1, 1);\n    }\n\n\n    return {\n        code: result.join(\"\"),\n        start: startInfo.start,\n        end: code.end,\n        codeset: codeset,\n        startInfo: startInfo,\n        decodedCodes: decodedCodes,\n        endInfo: code\n    };\n};\n\n\nBarcodeReader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n    return null;\n};\n\nfunction calculateCorrection(expected, normalized, indices) {\n    var length = indices.length,\n        sumNormalized = 0,\n        sumExpected = 0;\n\n    while(length--) {\n        sumExpected += expected[indices[length]];\n        sumNormalized += normalized[indices[length]];\n    }\n    return sumExpected/sumNormalized;\n}\n\nexport default Code128Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_128_reader.js","import Code39Reader from './code_39_reader';\n\nfunction Code39VINReader() {\n    Code39Reader.call(this);\n}\n\nvar patterns = {\n    IOQ: /[IOQ]/g,\n    AZ09: /[A-Z0-9]{17}/\n};\n\nCode39VINReader.prototype = Object.create(Code39Reader.prototype);\nCode39VINReader.prototype.constructor = Code39VINReader;\n\n// Cribbed from:\n// https://github.com/zxing/zxing/blob/master/core/src/main/java/com/google/zxing/client/result/VINResultParser.java\nCode39VINReader.prototype._decode = function() {\n    var result = Code39Reader.prototype._decode.apply(this);\n    if (!result) {\n        return null;\n    }\n\n    var code = result.code;\n\n    if (!code) {\n        return null;\n    }\n\n    code = code.replace(patterns.IOQ, '');\n\n    if (!code.match(patterns.AZ09)) {\n        if (ENV.development) {\n            console.log('Failed AZ09 pattern code:', code);\n        }\n        return null;\n    }\n\n    if (!this._checkChecksum(code)) {\n        return null;\n    }\n\n    result.code = code;\n    return result;\n};\n\nCode39VINReader.prototype._checkChecksum = function(code) {\n    // TODO\n    return !!code;\n};\n\nexport default Code39VINReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_39_vin_reader.js","import BarcodeReader from './barcode_reader';\nimport ArrayHelper from '../common/array_helper';\n\nfunction Code93Reader() {\n    BarcodeReader.call(this);\n}\n\nconst ALPHABETH_STRING = \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*\";\n\nvar properties = {\n    ALPHABETH_STRING: {value: ALPHABETH_STRING},\n    ALPHABET: {value: ALPHABETH_STRING.split('').map(char => char.charCodeAt(0))},\n    CHARACTER_ENCODINGS: {value: [\n        0x114, 0x148, 0x144, 0x142, 0x128, 0x124, 0x122, 0x150, 0x112, 0x10A,\n        0x1A8, 0x1A4, 0x1A2, 0x194, 0x192, 0x18A, 0x168, 0x164, 0x162, 0x134,\n        0x11A, 0x158, 0x14C, 0x146, 0x12C, 0x116, 0x1B4, 0x1B2, 0x1AC, 0x1A6,\n        0x196, 0x19A, 0x16C, 0x166, 0x136, 0x13A, 0x12E, 0x1D4, 0x1D2, 0x1CA,\n        0x16E, 0x176, 0x1AE, 0x126, 0x1DA, 0x1D6, 0x132, 0x15E\n    ]},\n    ASTERISK: {value: 0x15E},\n    FORMAT: {value: \"code_93\", writeable: false}\n};\n\nCode93Reader.prototype = Object.create(BarcodeReader.prototype, properties);\nCode93Reader.prototype.constructor = Code93Reader;\n\nCode93Reader.prototype._decode = function() {\n    var self = this,\n        counters = [0, 0, 0, 0, 0, 0],\n        result = [],\n        start = self._findStart(),\n        decodedChar,\n        lastStart,\n        pattern,\n        nextStart;\n\n    if (!start) {\n        return null;\n    }\n    nextStart = self._nextSet(self._row, start.end);\n\n    do {\n        counters = self._toCounters(nextStart, counters);\n        pattern = self._toPattern(counters);\n        if (pattern < 0) {\n            return null;\n        }\n        decodedChar = self._patternToChar(pattern);\n        if (decodedChar < 0){\n            return null;\n        }\n        result.push(decodedChar);\n        lastStart = nextStart;\n        nextStart += ArrayHelper.sum(counters);\n        nextStart = self._nextSet(self._row, nextStart);\n    } while (decodedChar !== '*');\n    result.pop();\n\n    if (!result.length) {\n        return null;\n    }\n\n    if (!self._verifyEnd(lastStart, nextStart, counters)) {\n        return null;\n    }\n\n    if (!self._verifyChecksums(result)) {\n        return null;\n    }\n\n    result = result.slice(0, result.length - 2);\n    if ((result = self._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\nCode93Reader.prototype._verifyEnd = function(lastStart, nextStart) {\n    if (lastStart === nextStart || !this._row[nextStart]) {\n        return false;\n    }\n    return true;\n};\n\nCode93Reader.prototype._patternToChar = function(pattern) {\n    var i,\n        self = this;\n\n    for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {\n        if (self.CHARACTER_ENCODINGS[i] === pattern) {\n            return String.fromCharCode(self.ALPHABET[i]);\n        }\n    }\n    return -1;\n};\n\nCode93Reader.prototype._toPattern = function(counters) {\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\nCode93Reader.prototype._findStart = function() {\n    var self = this,\n        offset = self._nextSet(self._row),\n        patternStart = offset,\n        counter = [0, 0, 0, 0, 0, 0],\n        counterPos = 0,\n        isWhite = false,\n        i,\n        j,\n        whiteSpaceMustStart;\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                // find start pattern\n                if (self._toPattern(counter) === self.ASTERISK) {\n                    whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - ((i - patternStart) / 4)));\n                    if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) {\n                        return {\n                            start: patternStart,\n                            end: i\n                        };\n                    }\n                }\n\n                patternStart += counter[0] + counter[1];\n                for ( j = 0; j < 4; j++) {\n                    counter[j] = counter[j + 2];\n                }\n                counter[4] = 0;\n                counter[5] = 0;\n                counterPos--;\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nCode93Reader.prototype._decodeExtended = function(charArray) {\n    const length = charArray.length;\n    const result = [];\n    for (let i = 0; i < length; i++) {\n        const char = charArray[i];\n        if (char >= 'a' && char <= 'd') {\n            if (i > (length - 2)) {\n                return null;\n            }\n            const nextChar = charArray[++i];\n            const nextCharCode = nextChar.charCodeAt(0);\n            let decodedChar;\n            switch (char) {\n            case 'a':\n                if (nextChar >= 'A' && nextChar <= 'Z') {\n                    decodedChar = String.fromCharCode(nextCharCode - 64);\n                } else {\n                    return null;\n                }\n                break;\n            case 'b':\n                if (nextChar >= 'A' && nextChar <= 'E') {\n                    decodedChar = String.fromCharCode(nextCharCode - 38);\n                } else if (nextChar >= 'F' && nextChar <= 'J') {\n                    decodedChar = String.fromCharCode(nextCharCode - 11);\n                } else if (nextChar >= 'K' && nextChar <= 'O') {\n                    decodedChar = String.fromCharCode(nextCharCode + 16);\n                } else if (nextChar >= 'P' && nextChar <= 'S') {\n                    decodedChar = String.fromCharCode(nextCharCode + 43);\n                } else if (nextChar >= 'T' && nextChar <= 'Z') {\n                    decodedChar = String.fromCharCode(127);\n                } else {\n                    return null;\n                }\n                break;\n            case 'c':\n                if (nextChar >= 'A' && nextChar <= 'O') {\n                    decodedChar = String.fromCharCode(nextCharCode - 32);\n                } else if (nextChar === 'Z') {\n                    decodedChar = ':';\n                } else {\n                    return null;\n                }\n                break;\n            case 'd':\n                if (nextChar >= 'A' && nextChar <= 'Z') {\n                    decodedChar = String.fromCharCode(nextCharCode + 32);\n                } else {\n                    return null;\n                }\n                break;\n            }\n            result.push(decodedChar);\n        } else {\n            result.push(char);\n        }\n    }\n    return result;\n};\n\nCode93Reader.prototype._verifyChecksums = function(charArray) {\n    return this._matchCheckChar(charArray, charArray.length - 2, 20)\n        && this._matchCheckChar(charArray, charArray.length - 1, 15);\n};\n\nCode93Reader.prototype._matchCheckChar = function(charArray, index, maxWeight) {\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 = this.ALPHABET.indexOf(char.charCodeAt(0));\n        return sum + (weight * value);\n    }, 0);\n\n    const checkChar = this.ALPHABET[(weightedSums % 47)];\n    return checkChar === charArray[index].charCodeAt(0);\n};\n\nexport default Code93Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/code_93_reader.js","import EANReader from './ean_reader';\n\nfunction EAN2Reader() {\n    EANReader.call(this);\n}\n\nvar properties = {\n    FORMAT: {value: \"ean_2\", writeable: false}\n};\n\nEAN2Reader.prototype = Object.create(EANReader.prototype, properties);\nEAN2Reader.prototype.constructor = EAN2Reader;\n\nEAN2Reader.prototype.decode = function(row, start) {\n    this._row = row;\n    var counters = [0, 0, 0, 0],\n        codeFrequency = 0,\n        i = 0,\n        offset = start,\n        end = this._row.length,\n        code,\n        result = [],\n        decodedCodes = [];\n\n    for (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    return {\n        code: result.join(\"\"),\n        decodedCodes,\n        end: code.end\n    };\n};\n\nexport default EAN2Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_2_reader.js","import EANReader from './ean_reader';\n\nfunction EAN5Reader() {\n    EANReader.call(this);\n}\n\nvar properties = {\n    FORMAT: {value: \"ean_5\", writeable: false}\n};\n\nconst CHECK_DIGIT_ENCODINGS = [24, 20, 18, 17, 12, 6, 3, 10, 9, 5];\n\nEAN5Reader.prototype = Object.create(EANReader.prototype, properties);\nEAN5Reader.prototype.constructor = EAN5Reader;\n\nEAN5Reader.prototype.decode = function(row, start) {\n    this._row = row;\n    var counters = [0, 0, 0, 0],\n        codeFrequency = 0,\n        i = 0,\n        offset = start,\n        end = this._row.length,\n        code,\n        result = [],\n        decodedCodes = [];\n\n    for (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 (extensionChecksum(result) !== determineCheckDigit(codeFrequency)) {\n        return null;\n    }\n    return {\n        code: result.join(\"\"),\n        decodedCodes,\n        end: code.end\n    };\n};\n\nfunction determineCheckDigit(codeFrequency) {\n    var i;\n    for (i = 0; i < 10; i++) {\n        if (codeFrequency === CHECK_DIGIT_ENCODINGS[i]) {\n            return i;\n        }\n    }\n    return null;\n}\n\n\nfunction extensionChecksum(result) {\n    var length = result.length,\n        sum = 0,\n        i;\n\n    for (i = length - 2; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    sum *= 3;\n    for (i = length - 1; i >= 0; i -= 2) {\n        sum += result[i];\n    }\n    sum *= 3;\n    return sum % 10;\n}\n\nexport default EAN5Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_5_reader.js","import EANReader from './ean_reader';\n\nfunction EAN8Reader(opts, supplements) {\n    EANReader.call(this, opts, supplements);\n}\n\nvar properties = {\n    FORMAT: {value: \"ean_8\", writeable: false}\n};\n\nEAN8Reader.prototype = Object.create(EANReader.prototype, properties);\nEAN8Reader.prototype.constructor = EAN8Reader;\n\nEAN8Reader.prototype._decodePayload = function(code, result, decodedCodes) {\n    var i,\n        self = this;\n\n    for ( i = 0; i < 4; i++) {\n        code = self._decodeCode(code.end, self.CODE_G_START);\n        if (!code) {\n            return null;\n        }\n        result.push(code.code);\n        decodedCodes.push(code);\n    }\n\n    code = self._findPattern(self.MIDDLE_PATTERN, code.end, true, false);\n    if (code === null) {\n        return null;\n    }\n    decodedCodes.push(code);\n\n    for ( i = 0; i < 4; i++) {\n        code = self._decodeCode(code.end, self.CODE_G_START);\n        if (!code) {\n            return null;\n        }\n        decodedCodes.push(code);\n        result.push(code.code);\n    }\n\n    return code;\n};\n\nexport default EAN8Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/ean_8_reader.js","import BarcodeReader from './barcode_reader';\nimport {merge} from 'lodash';\n\nfunction I2of5Reader(opts) {\n    opts = merge(getDefaulConfig(), opts);\n    BarcodeReader.call(this, opts);\n    this.barSpaceRatio = [1, 1];\n    if (opts.normalizeBarSpaceWidth) {\n        this.SINGLE_CODE_ERROR = 0.38;\n        this.AVG_CODE_ERROR = 0.09;\n    }\n}\n\nfunction getDefaulConfig() {\n    var config = {};\n\n    Object.keys(I2of5Reader.CONFIG_KEYS).forEach(function(key) {\n        config[key] = I2of5Reader.CONFIG_KEYS[key].default;\n    });\n    return config;\n}\n\nvar N = 1,\n    W = 3,\n    properties = {\n        START_PATTERN: {value: [N, N, N, N]},\n        STOP_PATTERN: {value: [N, N, W]},\n        CODE_PATTERN: {value: [\n            [N, N, W, W, N],\n            [W, N, N, N, W],\n            [N, W, N, N, W],\n            [W, W, N, N, N],\n            [N, N, W, N, W],\n            [W, N, W, N, N],\n            [N, W, W, N, N],\n            [N, N, N, W, W],\n            [W, N, N, W, N],\n            [N, W, N, W, N]\n        ]},\n        SINGLE_CODE_ERROR: {value: 0.78, writable: true},\n        AVG_CODE_ERROR: {value: 0.38, writable: true},\n        MAX_CORRECTION_FACTOR: {value: 5},\n        FORMAT: {value: \"i2of5\"}\n    };\n\nI2of5Reader.prototype = Object.create(BarcodeReader.prototype, properties);\nI2of5Reader.prototype.constructor = I2of5Reader;\n\nI2of5Reader.prototype._matchPattern = function(counter, code) {\n    if (this.config.normalizeBarSpaceWidth) {\n        var i,\n            counterSum = [0, 0],\n            codeSum = [0, 0],\n            correction = [0, 0],\n            correctionRatio = this.MAX_CORRECTION_FACTOR,\n            correctionRatioInverse = 1 / correctionRatio;\n\n        for (i = 0; i < counter.length; i++) {\n            counterSum[i % 2] += counter[i];\n            codeSum[i % 2] += code[i];\n        }\n        correction[0] = codeSum[0] / counterSum[0];\n        correction[1] = codeSum[1] / counterSum[1];\n\n        correction[0] = Math.max(Math.min(correction[0], correctionRatio), correctionRatioInverse);\n        correction[1] = Math.max(Math.min(correction[1], correctionRatio), correctionRatioInverse);\n        this.barSpaceRatio = correction;\n        for (i = 0; i < counter.length; i++) {\n            counter[i] *= this.barSpaceRatio[i % 2];\n        }\n    }\n    return BarcodeReader.prototype._matchPattern.call(this, counter, code);\n};\n\nI2of5Reader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder) {\n    var counter = [],\n        self = this,\n        i,\n        counterPos = 0,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        },\n        error,\n        j,\n        sum,\n        normalized,\n        epsilon = self.AVG_CODE_ERROR;\n\n    isWhite = isWhite || false;\n    tryHarder = tryHarder || false;\n\n    if (!offset) {\n        offset = self._nextSet(self._row);\n    }\n\n    for ( i = 0; i < pattern.length; i++) {\n        counter[i] = 0;\n    }\n\n    for ( i = offset; i < self._row.length; i++) {\n        if (self._row[i] ^ isWhite) {\n            counter[counterPos]++;\n        } else {\n            if (counterPos === counter.length - 1) {\n                sum = 0;\n                for ( j = 0; j < counter.length; j++) {\n                    sum += counter[j];\n                }\n                error = self._matchPattern(counter, pattern);\n                if (error < epsilon) {\n                    bestMatch.error = error;\n                    bestMatch.start = i - sum;\n                    bestMatch.end = i;\n                    return bestMatch;\n                }\n                if (tryHarder) {\n                    for (j = 0; j < counter.length - 2; j++) {\n                        counter[j] = counter[j + 2];\n                    }\n                    counter[counter.length - 2] = 0;\n                    counter[counter.length - 1] = 0;\n                    counterPos--;\n                } else {\n                    return null;\n                }\n            } else {\n                counterPos++;\n            }\n            counter[counterPos] = 1;\n            isWhite = !isWhite;\n        }\n    }\n    return null;\n};\n\nI2of5Reader.prototype._findStart = function() {\n    var self = this,\n        leadingWhitespaceStart,\n        offset = self._nextSet(self._row),\n        startInfo,\n        narrowBarWidth = 1;\n\n    while (!startInfo) {\n        startInfo = self._findPattern(self.START_PATTERN, offset, false, true);\n        if (!startInfo) {\n            return null;\n        }\n        narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / 4);\n        leadingWhitespaceStart = startInfo.start - narrowBarWidth * 10;\n        if (leadingWhitespaceStart >= 0) {\n            if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {\n                return startInfo;\n            }\n        }\n        offset = startInfo.end;\n        startInfo = null;\n    }\n};\n\nI2of5Reader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n    return null;\n};\n\nI2of5Reader.prototype._findEnd = function() {\n    var self = this,\n        endInfo,\n        tmp;\n\n    self._row.reverse();\n    endInfo = self._findPattern(self.STOP_PATTERN);\n    self._row.reverse();\n\n    if (endInfo === null) {\n        return null;\n    }\n\n    // reverse numbers\n    tmp = endInfo.start;\n    endInfo.start = self._row.length - endInfo.end;\n    endInfo.end = self._row.length - tmp;\n\n    return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;\n};\n\nI2of5Reader.prototype._decodePair = function(counterPair) {\n    var i,\n        code,\n        codes = [],\n        self = this;\n\n    for (i = 0; i < counterPair.length; i++) {\n        code = self._decodeCode(counterPair[i]);\n        if (!code) {\n            return null;\n        }\n        codes.push(code);\n    }\n    return codes;\n};\n\nI2of5Reader.prototype._decodeCode = function(counter) {\n    var j,\n        self = this,\n        sum = 0,\n        normalized,\n        error,\n        epsilon = self.AVG_CODE_ERROR,\n        code,\n        bestMatch = {\n            error: Number.MAX_VALUE,\n            code: -1,\n            start: 0,\n            end: 0\n        };\n\n    for ( j = 0; j < counter.length; j++) {\n        sum += counter[j];\n    }\n    for (code = 0; code < self.CODE_PATTERN.length; code++) {\n        error = self._matchPattern(counter, self.CODE_PATTERN[code]);\n        if (error < bestMatch.error) {\n            bestMatch.code = code;\n            bestMatch.error = error;\n        }\n    }\n    if (bestMatch.error < epsilon) {\n        return bestMatch;\n    }\n};\n\nI2of5Reader.prototype._decodePayload = function(counters, result, decodedCodes) {\n    var i,\n        self = this,\n        pos = 0,\n        counterLength = counters.length,\n        counterPair = [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0]],\n        codes;\n\n    while (pos < counterLength) {\n        for (i = 0; i < 5; i++) {\n            counterPair[0][i] = counters[pos] * this.barSpaceRatio[0];\n            counterPair[1][i] = counters[pos + 1] * this.barSpaceRatio[1];\n            pos += 2;\n        }\n        codes = self._decodePair(counterPair);\n        if (!codes) {\n            return null;\n        }\n        for (i = 0; i < codes.length; i++) {\n            result.push(codes[i].code + \"\");\n            decodedCodes.push(codes[i]);\n        }\n    }\n    return codes;\n};\n\nI2of5Reader.prototype._verifyCounterLength = function(counters) {\n    return (counters.length % 10 === 0);\n};\n\nI2of5Reader.prototype._decode = function() {\n    var startInfo,\n        endInfo,\n        self = this,\n        code,\n        result = [],\n        decodedCodes = [],\n        counters;\n\n    startInfo = self._findStart();\n    if (!startInfo) {\n        return null;\n    }\n    decodedCodes.push(startInfo);\n\n    endInfo = self._findEnd();\n    if (!endInfo) {\n        return null;\n    }\n\n    counters = self._fillCounters(startInfo.end, endInfo.start, false);\n    if (!self._verifyCounterLength(counters)) {\n        return null;\n    }\n    code = self._decodePayload(counters, result, decodedCodes);\n    if (!code) {\n        return null;\n    }\n    if (result.length % 2 !== 0 ||\n            result.length < 6) {\n        return null;\n    }\n\n    decodedCodes.push(endInfo);\n    return {\n        code: result.join(\"\"),\n        start: startInfo.start,\n        end: endInfo.end,\n        startInfo: startInfo,\n        decodedCodes: decodedCodes\n    };\n};\n\nI2of5Reader.CONFIG_KEYS = {\n    normalizeBarSpaceWidth: {\n        'type': 'boolean',\n        'default': false,\n        'description': 'If true, the reader tries to normalize the' +\n        'width-difference between bars and spaces'\n    }\n};\n\nexport default I2of5Reader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/i2of5_reader.js","import EANReader from './ean_reader';\n\nfunction UPCEReader(opts, supplements) {\n    EANReader.call(this, opts, supplements);\n}\n\nvar properties = {\n    CODE_FREQUENCY: {value: [\n        [ 56, 52, 50, 49, 44, 38, 35, 42, 41, 37 ],\n        [7, 11, 13, 14, 19, 25, 28, 21, 22, 26]]},\n    STOP_PATTERN: { value: [1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7, 1 / 6 * 7]},\n    FORMAT: {value: \"upc_e\", writeable: false}\n};\n\nUPCEReader.prototype = Object.create(EANReader.prototype, properties);\nUPCEReader.prototype.constructor = UPCEReader;\n\nUPCEReader.prototype._decodePayload = function(code, result, decodedCodes) {\n    var i,\n        self = this,\n        codeFrequency = 0x0;\n\n    for ( i = 0; i < 6; i++) {\n        code = self._decodeCode(code.end);\n        if (!code) {\n            return null;\n        }\n        if (code.code >= self.CODE_G_START) {\n            code.code = code.code - self.CODE_G_START;\n            codeFrequency |= 1 << (5 - i);\n        }\n        result.push(code.code);\n        decodedCodes.push(code);\n    }\n    if (!self._determineParity(codeFrequency, result)) {\n        return null;\n    }\n\n    return code;\n};\n\nUPCEReader.prototype._determineParity = function(codeFrequency, result) {\n    var i,\n        nrSystem;\n\n    for (nrSystem = 0; nrSystem < this.CODE_FREQUENCY.length; nrSystem++){\n        for ( i = 0; i < this.CODE_FREQUENCY[nrSystem].length; i++) {\n            if (codeFrequency === this.CODE_FREQUENCY[nrSystem][i]) {\n                result.unshift(nrSystem);\n                result.push(i);\n                return true;\n            }\n        }\n    }\n    return false;\n};\n\nUPCEReader.prototype._convertToUPCA = function(result) {\n    var upca = [result[0]],\n        lastDigit = result[result.length - 2];\n\n    if (lastDigit <= 2) {\n        upca = upca.concat(result.slice(1, 3))\n            .concat([lastDigit, 0, 0, 0, 0])\n            .concat(result.slice(3, 6));\n    } else if (lastDigit === 3) {\n        upca = upca.concat(result.slice(1, 4))\n            .concat([0, 0, 0, 0, 0])\n            .concat(result.slice(4, 6));\n    } else if (lastDigit === 4) {\n        upca = upca.concat(result.slice(1, 5))\n            .concat([0, 0, 0, 0, 0, result[5]]);\n    } else {\n        upca = upca.concat(result.slice(1, 6))\n            .concat([0, 0, 0, 0, lastDigit]);\n    }\n\n    upca.push(result[result.length - 1]);\n    return upca;\n};\n\nUPCEReader.prototype._checksum = function(result) {\n    return EANReader.prototype._checksum.call(this, this._convertToUPCA(result));\n};\n\nUPCEReader.prototype._findEnd = function(offset, isWhite) {\n    isWhite = true;\n    return EANReader.prototype._findEnd.call(this, offset, isWhite);\n};\n\nUPCEReader.prototype._verifyTrailingWhitespace = function(endInfo) {\n    var self = this,\n        trailingWhitespaceEnd;\n\n    trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);\n    if (trailingWhitespaceEnd < self._row.length) {\n        if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {\n            return endInfo;\n        }\n    }\n};\n\nexport default UPCEReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/upc_e_reader.js","import EANReader from './ean_reader';\n\nfunction UPCReader(opts, supplements) {\n    EANReader.call(this, opts, supplements);\n}\n\nvar properties = {\n    FORMAT: {value: \"upc_a\", writeable: false}\n};\n\nUPCReader.prototype = Object.create(EANReader.prototype, properties);\nUPCReader.prototype.constructor = UPCReader;\n\nUPCReader.prototype._decode = function() {\n    var result = EANReader.prototype._decode.call(this);\n\n    if (result && result.code && result.code.length === 13 && result.code.charAt(0) === \"0\") {\n        result.code = result.code.substring(1);\n        return result;\n    }\n    return null;\n};\n\nexport default UPCReader;\n\n\n\n// WEBPACK FOOTER //\n// ./src/reader/upc_reader.js","module.exports = copy\n\n/**\n * Copy the values from one mat2 to another\n *\n * @alias mat2.copy\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nfunction copy(out, a) {\n  out[0] = a[0]\n  out[1] = a[1]\n  out[2] = a[2]\n  out[3] = a[3]\n  return out\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/copy.js\n// module id = 76\n// module chunks = 0","module.exports = create\n\n/**\n * Creates a new identity mat2\n *\n * @alias mat2.create\n * @returns {mat2} a new 2x2 matrix\n */\nfunction create() {\n  var out = new Float32Array(4)\n  out[0] = 1\n  out[1] = 0\n  out[2] = 0\n  out[3] = 1\n  return out\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/create.js\n// module id = 77\n// module chunks = 0","module.exports = invert\n\n/**\n * Inverts a mat2\n *\n * @alias mat2.invert\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nfunction invert(out, a) {\n  var a0 = a[0]\n  var a1 = a[1]\n  var a2 = a[2]\n  var a3 = a[3]\n  var det = a0 * a3 - a2 * a1\n\n  if (!det) return null\n  det = 1.0 / det\n\n  out[0] =  a3 * det\n  out[1] = -a1 * det\n  out[2] = -a2 * det\n  out[3] =  a0 * det\n\n  return out\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-mat2/invert.js\n// module id = 78\n// module chunks = 0","module.exports = scale\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nfunction scale(out, a, b) {\n    out[0] = a[0] * b\n    out[1] = a[1] * b\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/scale.js\n// module id = 79\n// module chunks = 0","module.exports = transformMat2\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat2(out, a, m) {\n    var x = a[0],\n        y = a[1]\n    out[0] = m[0] * x + m[2] * y\n    out[1] = m[1] * x + m[3] * y\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec2/transformMat2.js\n// module id = 80\n// module chunks = 0","module.exports = clone;\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {vec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nfunction clone(a) {\n    var out = new Float32Array(3)\n    out[0] = a[0]\n    out[1] = a[1]\n    out[2] = a[2]\n    return out\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/gl-vec3/clone.js\n// module id = 81\n// module chunks = 0","var hashClear = require('./_hashClear'),\n    hashDelete = require('./_hashDelete'),\n    hashGet = require('./_hashGet'),\n    hashHas = require('./_hashHas'),\n    hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Hash.js\n// module id = 82\n// module chunks = 0","var ListCache = require('./_ListCache'),\n    stackClear = require('./_stackClear'),\n    stackDelete = require('./_stackDelete'),\n    stackGet = require('./_stackGet'),\n    stackHas = require('./_stackHas'),\n    stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n  var data = this.__data__ = new ListCache(entries);\n  this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Stack.js\n// module id = 83\n// module chunks = 0","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_Uint8Array.js\n// module id = 84\n// module chunks = 0","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n  switch (args.length) {\n    case 0: return func.call(thisArg);\n    case 1: return func.call(thisArg, args[0]);\n    case 2: return func.call(thisArg, args[0], args[1]);\n    case 3: return func.call(thisArg, args[0], args[1], args[2]);\n  }\n  return func.apply(thisArg, args);\n}\n\nmodule.exports = apply;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_apply.js\n// module id = 85\n// module chunks = 0","var baseTimes = require('./_baseTimes'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isBuffer = require('./isBuffer'),\n    isIndex = require('./_isIndex'),\n    isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n  var isArr = isArray(value),\n      isArg = !isArr && isArguments(value),\n      isBuff = !isArr && !isArg && isBuffer(value),\n      isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n      skipIndexes = isArr || isArg || isBuff || isType,\n      result = skipIndexes ? baseTimes(value.length, String) : [],\n      length = result.length;\n\n  for (var key in value) {\n    if ((inherited || hasOwnProperty.call(value, key)) &&\n        !(skipIndexes && (\n           // Safari 9 has enumerable `arguments.length` in strict mode.\n           key == 'length' ||\n           // Node.js 0.10 has enumerable non-index properties on buffers.\n           (isBuff && (key == 'offset' || key == 'parent')) ||\n           // PhantomJS 2 has enumerable non-index properties on typed arrays.\n           (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n           // Skip index properties.\n           isIndex(key, length)\n        ))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = arrayLikeKeys;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayLikeKeys.js\n// module id = 86\n// module chunks = 0","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n  var index = -1,\n      length = array == null ? 0 : array.length,\n      result = Array(length);\n\n  while (++index < length) {\n    result[index] = iteratee(array[index], index, array);\n  }\n  return result;\n}\n\nmodule.exports = arrayMap;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayMap.js\n// module id = 87\n// module chunks = 0","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n  var index = -1,\n      length = values.length,\n      offset = array.length;\n\n  while (++index < length) {\n    array[offset + index] = values[index];\n  }\n  return array;\n}\n\nmodule.exports = arrayPush;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_arrayPush.js\n// module id = 88\n// module chunks = 0","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n  function object() {}\n  return function(proto) {\n    if (!isObject(proto)) {\n      return {};\n    }\n    if (objectCreate) {\n      return objectCreate(proto);\n    }\n    object.prototype = proto;\n    var result = new object;\n    object.prototype = undefined;\n    return result;\n  };\n}());\n\nmodule.exports = baseCreate;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseCreate.js\n// module id = 89\n// module chunks = 0","var arrayPush = require('./_arrayPush'),\n    isFlattenable = require('./_isFlattenable');\n\n/**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, predicate, isStrict, result) {\n  var index = -1,\n      length = array.length;\n\n  predicate || (predicate = isFlattenable);\n  result || (result = []);\n\n  while (++index < length) {\n    var value = array[index];\n    if (depth > 0 && predicate(value)) {\n      if (depth > 1) {\n        // Recursively flatten arrays (susceptible to call stack limits).\n        baseFlatten(value, depth - 1, predicate, isStrict, result);\n      } else {\n        arrayPush(result, value);\n      }\n    } else if (!isStrict) {\n      result[result.length] = value;\n    }\n  }\n  return result;\n}\n\nmodule.exports = baseFlatten;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseFlatten.js\n// module id = 90\n// module chunks = 0","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseFor.js\n// module id = 91\n// module chunks = 0","var castPath = require('./_castPath'),\n    toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n  path = castPath(path, object);\n\n  var index = 0,\n      length = path.length;\n\n  while (object != null && index < length) {\n    object = object[toKey(path[index++])];\n  }\n  return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseGet.js\n// module id = 92\n// module chunks = 0","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n  return object != null && key in Object(object);\n}\n\nmodule.exports = baseHasIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseHasIn.js\n// module id = 93\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n  return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsArguments.js\n// module id = 94\n// module chunks = 0","var isFunction = require('./isFunction'),\n    isMasked = require('./_isMasked'),\n    isObject = require('./isObject'),\n    toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n *  else `false`.\n */\nfunction baseIsNative(value) {\n  if (!isObject(value) || isMasked(value)) {\n    return false;\n  }\n  var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n  return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsNative.js\n// module id = 95\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    isLength = require('./isLength'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseIsTypedArray.js\n// module id = 96\n// module chunks = 0","var isObject = require('./isObject'),\n    isPrototype = require('./_isPrototype'),\n    nativeKeysIn = require('./_nativeKeysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n  if (!isObject(object)) {\n    return nativeKeysIn(object);\n  }\n  var isProto = isPrototype(object),\n      result = [];\n\n  for (var key in object) {\n    if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = baseKeysIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseKeysIn.js\n// module id = 97\n// module chunks = 0","var Stack = require('./_Stack'),\n    assignMergeValue = require('./_assignMergeValue'),\n    baseFor = require('./_baseFor'),\n    baseMergeDeep = require('./_baseMergeDeep'),\n    isObject = require('./isObject'),\n    keysIn = require('./keysIn');\n\n/**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n  if (object === source) {\n    return;\n  }\n  baseFor(source, function(srcValue, key) {\n    if (isObject(srcValue)) {\n      stack || (stack = new Stack);\n      baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n    }\n    else {\n      var newValue = customizer\n        ? customizer(object[key], srcValue, (key + ''), object, source, stack)\n        : undefined;\n\n      if (newValue === undefined) {\n        newValue = srcValue;\n      }\n      assignMergeValue(object, key, newValue);\n    }\n  }, keysIn);\n}\n\nmodule.exports = baseMerge;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseMerge.js\n// module id = 98\n// module chunks = 0","var assignMergeValue = require('./_assignMergeValue'),\n    cloneBuffer = require('./_cloneBuffer'),\n    cloneTypedArray = require('./_cloneTypedArray'),\n    copyArray = require('./_copyArray'),\n    initCloneObject = require('./_initCloneObject'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isArrayLikeObject = require('./isArrayLikeObject'),\n    isBuffer = require('./isBuffer'),\n    isFunction = require('./isFunction'),\n    isObject = require('./isObject'),\n    isPlainObject = require('./isPlainObject'),\n    isTypedArray = require('./isTypedArray'),\n    toPlainObject = require('./toPlainObject');\n\n/**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n  var objValue = object[key],\n      srcValue = source[key],\n      stacked = stack.get(srcValue);\n\n  if (stacked) {\n    assignMergeValue(object, key, stacked);\n    return;\n  }\n  var newValue = customizer\n    ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n    : undefined;\n\n  var isCommon = newValue === undefined;\n\n  if (isCommon) {\n    var isArr = isArray(srcValue),\n        isBuff = !isArr && isBuffer(srcValue),\n        isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n    newValue = srcValue;\n    if (isArr || isBuff || isTyped) {\n      if (isArray(objValue)) {\n        newValue = objValue;\n      }\n      else if (isArrayLikeObject(objValue)) {\n        newValue = copyArray(objValue);\n      }\n      else if (isBuff) {\n        isCommon = false;\n        newValue = cloneBuffer(srcValue, true);\n      }\n      else if (isTyped) {\n        isCommon = false;\n        newValue = cloneTypedArray(srcValue, true);\n      }\n      else {\n        newValue = [];\n      }\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      newValue = objValue;\n      if (isArguments(objValue)) {\n        newValue = toPlainObject(objValue);\n      }\n      else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) {\n        newValue = initCloneObject(srcValue);\n      }\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    stack.set(srcValue, newValue);\n    mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n    stack['delete'](srcValue);\n  }\n  assignMergeValue(object, key, newValue);\n}\n\nmodule.exports = baseMergeDeep;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseMergeDeep.js\n// module id = 99\n// module chunks = 0","var basePickBy = require('./_basePickBy'),\n    hasIn = require('./hasIn');\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, paths) {\n  return basePickBy(object, paths, function(value, path) {\n    return hasIn(object, path);\n  });\n}\n\nmodule.exports = basePick;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_basePick.js\n// module id = 100\n// module chunks = 0","var baseGet = require('./_baseGet'),\n    baseSet = require('./_baseSet'),\n    castPath = require('./_castPath');\n\n/**\n * The base implementation of  `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\nfunction basePickBy(object, paths, predicate) {\n  var index = -1,\n      length = paths.length,\n      result = {};\n\n  while (++index < length) {\n    var path = paths[index],\n        value = baseGet(object, path);\n\n    if (predicate(value, path)) {\n      baseSet(result, castPath(path, object), value);\n    }\n  }\n  return result;\n}\n\nmodule.exports = basePickBy;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_basePickBy.js\n// module id = 101\n// module chunks = 0","var identity = require('./identity'),\n    overRest = require('./_overRest'),\n    setToString = require('./_setToString');\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n  return setToString(overRest(func, start, identity), func + '');\n}\n\nmodule.exports = baseRest;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseRest.js\n// module id = 102\n// module chunks = 0","var assignValue = require('./_assignValue'),\n    castPath = require('./_castPath'),\n    isIndex = require('./_isIndex'),\n    isObject = require('./isObject'),\n    toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n  if (!isObject(object)) {\n    return object;\n  }\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length,\n      lastIndex = length - 1,\n      nested = object;\n\n  while (nested != null && ++index < length) {\n    var key = toKey(path[index]),\n        newValue = value;\n\n    if (index != lastIndex) {\n      var objValue = nested[key];\n      newValue = customizer ? customizer(objValue, key, nested) : undefined;\n      if (newValue === undefined) {\n        newValue = isObject(objValue)\n          ? objValue\n          : (isIndex(path[index + 1]) ? [] : {});\n      }\n    }\n    assignValue(nested, key, newValue);\n    nested = nested[key];\n  }\n  return object;\n}\n\nmodule.exports = baseSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseSet.js\n// module id = 103\n// module chunks = 0","var constant = require('./constant'),\n    defineProperty = require('./_defineProperty'),\n    identity = require('./identity');\n\n/**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar baseSetToString = !defineProperty ? identity : function(func, string) {\n  return defineProperty(func, 'toString', {\n    'configurable': true,\n    'enumerable': false,\n    'value': constant(string),\n    'writable': true\n  });\n};\n\nmodule.exports = baseSetToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseSetToString.js\n// module id = 104\n// module chunks = 0","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n  var index = -1,\n      result = Array(n);\n\n  while (++index < n) {\n    result[index] = iteratee(index);\n  }\n  return result;\n}\n\nmodule.exports = baseTimes;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseTimes.js\n// module id = 105\n// module chunks = 0","var Symbol = require('./_Symbol'),\n    arrayMap = require('./_arrayMap'),\n    isArray = require('./isArray'),\n    isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n  // Exit early for strings to avoid a performance hit in some environments.\n  if (typeof value == 'string') {\n    return value;\n  }\n  if (isArray(value)) {\n    // Recursively convert values (susceptible to call stack limits).\n    return arrayMap(value, baseToString) + '';\n  }\n  if (isSymbol(value)) {\n    return symbolToString ? symbolToString.call(value) : '';\n  }\n  var result = (value + '');\n  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseToString.js\n// module id = 106\n// module chunks = 0","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n  return function(value) {\n    return func(value);\n  };\n}\n\nmodule.exports = baseUnary;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_baseUnary.js\n// module id = 107\n// module chunks = 0","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n  new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n  return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneArrayBuffer.js\n// module id = 108\n// module chunks = 0","var root = require('./_root');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n    allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of  `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n  if (isDeep) {\n    return buffer.slice();\n  }\n  var length = buffer.length,\n      result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n  buffer.copy(result);\n  return result;\n}\n\nmodule.exports = cloneBuffer;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneBuffer.js\n// module id = 109\n// module chunks = 0","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_cloneTypedArray.js\n// module id = 110\n// module chunks = 0","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n  var index = -1,\n      length = source.length;\n\n  array || (array = Array(length));\n  while (++index < length) {\n    array[index] = source[index];\n  }\n  return array;\n}\n\nmodule.exports = copyArray;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_copyArray.js\n// module id = 111\n// module chunks = 0","var assignValue = require('./_assignValue'),\n    baseAssignValue = require('./_baseAssignValue');\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n  var isNew = !object;\n  object || (object = {});\n\n  var index = -1,\n      length = props.length;\n\n  while (++index < length) {\n    var key = props[index];\n\n    var newValue = customizer\n      ? customizer(object[key], source[key], key, object, source)\n      : undefined;\n\n    if (newValue === undefined) {\n      newValue = source[key];\n    }\n    if (isNew) {\n      baseAssignValue(object, key, newValue);\n    } else {\n      assignValue(object, key, newValue);\n    }\n  }\n  return object;\n}\n\nmodule.exports = copyObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_copyObject.js\n// module id = 112\n// module chunks = 0","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_coreJsData.js\n// module id = 113\n// module chunks = 0","var baseRest = require('./_baseRest'),\n    isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\nfunction createAssigner(assigner) {\n  return baseRest(function(object, sources) {\n    var index = -1,\n        length = sources.length,\n        customizer = length > 1 ? sources[length - 1] : undefined,\n        guard = length > 2 ? sources[2] : undefined;\n\n    customizer = (assigner.length > 3 && typeof customizer == 'function')\n      ? (length--, customizer)\n      : undefined;\n\n    if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n      customizer = length < 3 ? undefined : customizer;\n      length = 1;\n    }\n    object = Object(object);\n    while (++index < length) {\n      var source = sources[index];\n      if (source) {\n        assigner(object, source, index, customizer);\n      }\n    }\n    return object;\n  });\n}\n\nmodule.exports = createAssigner;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_createAssigner.js\n// module id = 114\n// module chunks = 0","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n  return function(object, iteratee, keysFunc) {\n    var index = -1,\n        iterable = Object(object),\n        props = keysFunc(object),\n        length = props.length;\n\n    while (length--) {\n      var key = props[fromRight ? length : ++index];\n      if (iteratee(iterable[key], key, iterable) === false) {\n        break;\n      }\n    }\n    return object;\n  };\n}\n\nmodule.exports = createBaseFor;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_createBaseFor.js\n// module id = 115\n// module chunks = 0","var flatten = require('./flatten'),\n    overRest = require('./_overRest'),\n    setToString = require('./_setToString');\n\n/**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\nfunction flatRest(func) {\n  return setToString(overRest(func, undefined, flatten), func + '');\n}\n\nmodule.exports = flatRest;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_flatRest.js\n// module id = 116\n// module chunks = 0","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n  var isOwn = hasOwnProperty.call(value, symToStringTag),\n      tag = value[symToStringTag];\n\n  try {\n    value[symToStringTag] = undefined;\n    var unmasked = true;\n  } catch (e) {}\n\n  var result = nativeObjectToString.call(value);\n  if (unmasked) {\n    if (isOwn) {\n      value[symToStringTag] = tag;\n    } else {\n      delete value[symToStringTag];\n    }\n  }\n  return result;\n}\n\nmodule.exports = getRawTag;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getRawTag.js\n// module id = 117\n// module chunks = 0","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_getValue.js\n// module id = 118\n// module chunks = 0","var castPath = require('./_castPath'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isIndex = require('./_isIndex'),\n    isLength = require('./isLength'),\n    toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length,\n      result = false;\n\n  while (++index < length) {\n    var key = toKey(path[index]);\n    if (!(result = object != null && hasFunc(object, key))) {\n      break;\n    }\n    object = object[key];\n  }\n  if (result || ++index != length) {\n    return result;\n  }\n  length = object == null ? 0 : object.length;\n  return !!length && isLength(length) && isIndex(key, length) &&\n    (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hasPath.js\n// module id = 119\n// module chunks = 0","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n  this.__data__ = nativeCreate ? nativeCreate(null) : {};\n  this.size = 0;\n}\n\nmodule.exports = hashClear;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashClear.js\n// module id = 120\n// module chunks = 0","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n  var result = this.has(key) && delete this.__data__[key];\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nmodule.exports = hashDelete;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashDelete.js\n// module id = 121\n// module chunks = 0","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n  var data = this.__data__;\n  if (nativeCreate) {\n    var result = data[key];\n    return result === HASH_UNDEFINED ? undefined : result;\n  }\n  return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashGet.js\n// module id = 122\n// module chunks = 0","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n  var data = this.__data__;\n  return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashHas.js\n// module id = 123\n// module chunks = 0","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n  var data = this.__data__;\n  this.size += this.has(key) ? 0 : 1;\n  data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n  return this;\n}\n\nmodule.exports = hashSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_hashSet.js\n// module id = 124\n// module chunks = 0","var baseCreate = require('./_baseCreate'),\n    getPrototype = require('./_getPrototype'),\n    isPrototype = require('./_isPrototype');\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n  return (typeof object.constructor == 'function' && !isPrototype(object))\n    ? baseCreate(getPrototype(object))\n    : {};\n}\n\nmodule.exports = initCloneObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_initCloneObject.js\n// module id = 125\n// module chunks = 0","var Symbol = require('./_Symbol'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray');\n\n/** Built-in value references. */\nvar spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;\n\n/**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\nfunction isFlattenable(value) {\n  return isArray(value) || isArguments(value) ||\n    !!(spreadableSymbol && value && value[spreadableSymbol]);\n}\n\nmodule.exports = isFlattenable;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isFlattenable.js\n// module id = 126\n// module chunks = 0","var eq = require('./eq'),\n    isArrayLike = require('./isArrayLike'),\n    isIndex = require('./_isIndex'),\n    isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n *  else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n  if (!isObject(object)) {\n    return false;\n  }\n  var type = typeof index;\n  if (type == 'number'\n        ? (isArrayLike(object) && isIndex(index, object.length))\n        : (type == 'string' && index in object)\n      ) {\n    return eq(object[index], value);\n  }\n  return false;\n}\n\nmodule.exports = isIterateeCall;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isIterateeCall.js\n// module id = 127\n// module chunks = 0","var isArray = require('./isArray'),\n    isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n    reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n  if (isArray(value)) {\n    return false;\n  }\n  var type = typeof value;\n  if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n      value == null || isSymbol(value)) {\n    return true;\n  }\n  return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n    (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isKey.js\n// module id = 128\n// module chunks = 0","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n  var type = typeof value;\n  return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n    ? (value !== '__proto__')\n    : (value === null);\n}\n\nmodule.exports = isKeyable;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isKeyable.js\n// module id = 129\n// module chunks = 0","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n  return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_isMasked.js\n// module id = 130\n// module chunks = 0","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n  this.__data__ = [];\n  this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheClear.js\n// module id = 131\n// module chunks = 0","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    return false;\n  }\n  var lastIndex = data.length - 1;\n  if (index == lastIndex) {\n    data.pop();\n  } else {\n    splice.call(data, index, 1);\n  }\n  --this.size;\n  return true;\n}\n\nmodule.exports = listCacheDelete;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheDelete.js\n// module id = 132\n// module chunks = 0","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheGet.js\n// module id = 133\n// module chunks = 0","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n  return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheHas.js\n// module id = 134\n// module chunks = 0","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    ++this.size;\n    data.push([key, value]);\n  } else {\n    data[index][1] = value;\n  }\n  return this;\n}\n\nmodule.exports = listCacheSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_listCacheSet.js\n// module id = 135\n// module chunks = 0","var Hash = require('./_Hash'),\n    ListCache = require('./_ListCache'),\n    Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n  this.size = 0;\n  this.__data__ = {\n    'hash': new Hash,\n    'map': new (Map || ListCache),\n    'string': new Hash\n  };\n}\n\nmodule.exports = mapCacheClear;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheClear.js\n// module id = 136\n// module chunks = 0","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n  var result = getMapData(this, key)['delete'](key);\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nmodule.exports = mapCacheDelete;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheDelete.js\n// module id = 137\n// module chunks = 0","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n  return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheGet.js\n// module id = 138\n// module chunks = 0","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n  return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheHas.js\n// module id = 139\n// module chunks = 0","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n  var data = getMapData(this, key),\n      size = data.size;\n\n  data.set(key, value);\n  this.size += data.size == size ? 0 : 1;\n  return this;\n}\n\nmodule.exports = mapCacheSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_mapCacheSet.js\n// module id = 140\n// module chunks = 0","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n  var result = memoize(func, function(key) {\n    if (cache.size === MAX_MEMOIZE_SIZE) {\n      cache.clear();\n    }\n    return key;\n  });\n\n  var cache = result.cache;\n  return result;\n}\n\nmodule.exports = memoizeCapped;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_memoizeCapped.js\n// module id = 141\n// module chunks = 0","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n  var result = [];\n  if (object != null) {\n    for (var key in Object(object)) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = nativeKeysIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nativeKeysIn.js\n// module id = 142\n// module chunks = 0","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n  try {\n    return freeProcess && freeProcess.binding && freeProcess.binding('util');\n  } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_nodeUtil.js\n// module id = 143\n// module chunks = 0","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n  return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_objectToString.js\n// module id = 144\n// module chunks = 0","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\n}\n\nmodule.exports = overArg;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_overArg.js\n// module id = 145\n// module chunks = 0","/** Used to detect hot functions by number of calls within a span of milliseconds. */\nvar HOT_COUNT = 800,\n    HOT_SPAN = 16;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeNow = Date.now;\n\n/**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\nfunction shortOut(func) {\n  var count = 0,\n      lastCalled = 0;\n\n  return function() {\n    var stamp = nativeNow(),\n        remaining = HOT_SPAN - (stamp - lastCalled);\n\n    lastCalled = stamp;\n    if (remaining > 0) {\n      if (++count >= HOT_COUNT) {\n        return arguments[0];\n      }\n    } else {\n      count = 0;\n    }\n    return func.apply(undefined, arguments);\n  };\n}\n\nmodule.exports = shortOut;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_shortOut.js\n// module id = 146\n// module chunks = 0","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n  this.__data__ = new ListCache;\n  this.size = 0;\n}\n\nmodule.exports = stackClear;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackClear.js\n// module id = 147\n// module chunks = 0","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n  var data = this.__data__,\n      result = data['delete'](key);\n\n  this.size = data.size;\n  return result;\n}\n\nmodule.exports = stackDelete;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackDelete.js\n// module id = 148\n// module chunks = 0","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n  return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackGet.js\n// module id = 149\n// module chunks = 0","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n  return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackHas.js\n// module id = 150\n// module chunks = 0","var ListCache = require('./_ListCache'),\n    Map = require('./_Map'),\n    MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n  var data = this.__data__;\n  if (data instanceof ListCache) {\n    var pairs = data.__data__;\n    if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n      pairs.push([key, value]);\n      this.size = ++data.size;\n      return this;\n    }\n    data = this.__data__ = new MapCache(pairs);\n  }\n  data.set(key, value);\n  this.size = data.size;\n  return this;\n}\n\nmodule.exports = stackSet;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stackSet.js\n// module id = 151\n// module chunks = 0","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar reLeadingDot = /^\\./,\n    rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n  var result = [];\n  if (reLeadingDot.test(string)) {\n    result.push('');\n  }\n  string.replace(rePropName, function(match, number, quote, string) {\n    result.push(quote ? string.replace(reEscapeChar, '$1') : (number || match));\n  });\n  return result;\n});\n\nmodule.exports = stringToPath;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_stringToPath.js\n// module id = 152\n// module chunks = 0","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n  if (func != null) {\n    try {\n      return funcToString.call(func);\n    } catch (e) {}\n    try {\n      return (func + '');\n    } catch (e) {}\n  }\n  return '';\n}\n\nmodule.exports = toSource;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/_toSource.js\n// module id = 153\n// module chunks = 0","/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\nfunction constant(value) {\n  return function() {\n    return value;\n  };\n}\n\nmodule.exports = constant;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/constant.js\n// module id = 154\n// module chunks = 0","var baseFlatten = require('./_baseFlatten');\n\n/**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\nfunction flatten(array) {\n  var length = array == null ? 0 : array.length;\n  return length ? baseFlatten(array, 1) : [];\n}\n\nmodule.exports = flatten;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/flatten.js\n// module id = 155\n// module chunks = 0","var baseHasIn = require('./_baseHasIn'),\n    hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n  return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/hasIn.js\n// module id = 156\n// module chunks = 0","var isArrayLike = require('./isArrayLike'),\n    isObjectLike = require('./isObjectLike');\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n *  else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\n}\n\nmodule.exports = isArrayLikeObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isArrayLikeObject.js\n// module id = 157\n// module chunks = 0","var baseGetTag = require('./_baseGetTag'),\n    getPrototype = require('./_getPrototype'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n  if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n    return false;\n  }\n  var proto = getPrototype(value);\n  if (proto === null) {\n    return true;\n  }\n  var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n  return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n    funcToString.call(Ctor) == objectCtorString;\n}\n\nmodule.exports = isPlainObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/isPlainObject.js\n// module id = 158\n// module chunks = 0","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n  if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  var memoized = function() {\n    var args = arguments,\n        key = resolver ? resolver.apply(this, args) : args[0],\n        cache = memoized.cache;\n\n    if (cache.has(key)) {\n      return cache.get(key);\n    }\n    var result = func.apply(this, args);\n    memoized.cache = cache.set(key, result) || cache;\n    return result;\n  };\n  memoized.cache = new (memoize.Cache || MapCache);\n  return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/memoize.js\n// module id = 159\n// module chunks = 0","var basePick = require('./_basePick'),\n    flatRest = require('./_flatRest');\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\nvar pick = flatRest(function(object, paths) {\n  return object == null ? {} : basePick(object, paths);\n});\n\nmodule.exports = pick;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/pick.js\n// module id = 160\n// module chunks = 0","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n  return false;\n}\n\nmodule.exports = stubFalse;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/stubFalse.js\n// module id = 161\n// module chunks = 0","var copyObject = require('./_copyObject'),\n    keysIn = require('./keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\nfunction toPlainObject(value) {\n  return copyObject(value, keysIn(value));\n}\n\nmodule.exports = toPlainObject;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/toPlainObject.js\n// module id = 162\n// module chunks = 0","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n  return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/lodash/toString.js\n// module id = 163\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_164__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"get-pixels\"\n// module id = 164\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_165__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"ndarray\"\n// module id = 165\n// module chunks = 0","module.exports = __WEBPACK_EXTERNAL_MODULE_166__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"ndarray-linear-interpolate\"\n// module id = 166\n// module chunks = 0"],"sourceRoot":""}
\ No newline at end of file
diff --git a/package.json b/package.json
index c1664fe..1f3bbc8 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "quagga",
- "version": "0.11.6",
+ "version": "0.12.1",
"description": "An advanced barcode-scanner written in JavaScript",
"main": "lib/quagga.js",
"browser": "dist/quagga.min.js",
diff --git a/src/common/cv_utils.js b/src/common/cv_utils.js
index d41727d..1a865b4 100644
--- a/src/common/cv_utils.js
+++ b/src/common/cv_utils.js
@@ -488,7 +488,7 @@ export function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {
while (bottomRowIdx < endIdx) {
for ( i = 0; i < outWidth; i++) {
- outArray[outImgIdx] = Math.floor((
+ outArray[outImgIdx] = (
(0.299 * canvasData[topRowIdx * 4 + 0] +
0.587 * canvasData[topRowIdx * 4 + 1] +
0.114 * canvasData[topRowIdx * 4 + 2]) +
@@ -500,7 +500,7 @@ export function grayAndHalfSampleFromCanvasData(canvasData, size, outArray) {
0.114 * canvasData[(bottomRowIdx) * 4 + 2]) +
(0.299 * canvasData[(bottomRowIdx + 1) * 4 + 0] +
0.587 * canvasData[(bottomRowIdx + 1) * 4 + 1] +
- 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4);
+ 0.114 * canvasData[(bottomRowIdx + 1) * 4 + 2])) / 4;
outImgIdx++;
topRowIdx = topRowIdx + 2;
bottomRowIdx = bottomRowIdx + 2;
@@ -521,8 +521,8 @@ export function computeGray(imageData, outArray, config) {
}
} else {
for (i = 0; i < l; i++) {
- outArray[i] = Math.floor(
- 0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2]);
+ outArray[i] =
+ 0.299 * imageData[i * 4 + 0] + 0.587 * imageData[i * 4 + 1] + 0.114 * imageData[i * 4 + 2];
}
}
};
diff --git a/src/decoder/barcode_decoder.js b/src/decoder/barcode_decoder.js
index 4c68ee6..e5dbecf 100644
--- a/src/decoder/barcode_decoder.js
+++ b/src/decoder/barcode_decoder.js
@@ -11,6 +11,8 @@ import EAN2Reader from '../reader/ean_2_reader';
import EAN5Reader from '../reader/ean_5_reader';
import UPCEReader from '../reader/upc_e_reader';
import I2of5Reader from '../reader/i2of5_reader';
+import TwoOfFiveReader from '../reader/2of5_reader';
+import Code93Reader from '../reader/code_93_reader';
const READERS = {
code_128_reader: Code128Reader,
@@ -23,7 +25,9 @@ const READERS = {
codabar_reader: CodabarReader,
upc_reader: UPCReader,
upc_e_reader: UPCEReader,
- i2of5_reader: I2of5Reader
+ i2of5_reader: I2of5Reader,
+ '2of5_reader': TwoOfFiveReader,
+ code_93_reader: Code93Reader
};
export default {
create: function(config, inputImageWrapper) {
diff --git a/src/input/camera_access.js b/src/input/camera_access.js
index 54f8e1b..5df6982 100644
--- a/src/input/camera_access.js
+++ b/src/input/camera_access.js
@@ -14,7 +14,7 @@ function waitForVideo(video) {
function checkVideo() {
if (attempts > 0) {
- if (video.videoWidth > 0 && video.videoHeight > 0) {
+ if (video.videoWidth > 10 && video.videoHeight > 10) {
if (ENV.development) {
console.log(video.videoWidth + "px x " + video.videoHeight + "px");
}
@@ -42,7 +42,9 @@ function initCamera(video, constraints) {
.then((stream) => {
return new Promise((resolve) => {
streamRef = stream;
- video.setAttribute("autoplay", 'true');
+ video.setAttribute("autoplay", true);
+ video.setAttribute('muted', true);
+ video.setAttribute('playsinline', true);
video.srcObject = stream;
video.addEventListener('loadedmetadata', () => {
video.play();
@@ -87,6 +89,15 @@ function enumerateVideoDevices() {
.then(devices => devices.filter(device => device.kind === 'videoinput'));
}
+function getActiveTrack() {
+ if (streamRef) {
+ const tracks = streamRef.getVideoTracks();
+ if (tracks && tracks.length) {
+ return tracks[0];
+ }
+ }
+}
+
export default {
request: function(video, videoConstraints) {
return pickConstraints(videoConstraints)
@@ -101,11 +112,8 @@ export default {
},
enumerateVideoDevices,
getActiveStreamLabel: function() {
- if (streamRef) {
- const tracks = streamRef.getVideoTracks();
- if (tracks && tracks.length) {
- return tracks[0].label;
- }
- }
- }
+ const track = getActiveTrack();
+ return track ? track.label : '';
+ },
+ getActiveTrack
};
diff --git a/src/reader/2of5_reader.js b/src/reader/2of5_reader.js
new file mode 100644
index 0000000..a048e07
--- /dev/null
+++ b/src/reader/2of5_reader.js
@@ -0,0 +1,257 @@
+import BarcodeReader from './barcode_reader';
+
+function TwoOfFiveReader(opts) {
+ BarcodeReader.call(this, opts);
+ this.barSpaceRatio = [1, 1];
+}
+
+var N = 1,
+ W = 3,
+ properties = {
+ START_PATTERN: {value: [W, N, W, N, N, N]},
+ STOP_PATTERN: {value: [W, N, N, N, W]},
+ CODE_PATTERN: {value: [
+ [N, N, W, W, N],
+ [W, N, N, N, W],
+ [N, W, N, N, W],
+ [W, W, N, N, N],
+ [N, N, W, N, W],
+ [W, N, W, N, N],
+ [N, W, W, N, N],
+ [N, N, N, W, W],
+ [W, N, N, W, N],
+ [N, W, N, W, N]
+ ]},
+ SINGLE_CODE_ERROR: {value: 0.78, writable: true},
+ AVG_CODE_ERROR: {value: 0.30, writable: true},
+ FORMAT: {value: "2of5"}
+ };
+
+const startPatternLength = properties.START_PATTERN.value.reduce((sum, val) => sum + val, 0);
+
+TwoOfFiveReader.prototype = Object.create(BarcodeReader.prototype, properties);
+TwoOfFiveReader.prototype.constructor = TwoOfFiveReader;
+
+TwoOfFiveReader.prototype._findPattern = function(pattern, offset, isWhite, tryHarder) {
+ var counter = [],
+ self = this,
+ i,
+ counterPos = 0,
+ bestMatch = {
+ error: Number.MAX_VALUE,
+ code: -1,
+ start: 0,
+ end: 0
+ },
+ error,
+ j,
+ sum,
+ epsilon = self.AVG_CODE_ERROR;
+
+ isWhite = isWhite || false;
+ tryHarder = tryHarder || false;
+
+ if (!offset) {
+ offset = self._nextSet(self._row);
+ }
+
+ for ( i = 0; i < pattern.length; i++) {
+ counter[i] = 0;
+ }
+
+ for ( i = offset; i < self._row.length; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ if (counterPos === counter.length - 1) {
+ sum = 0;
+ for ( j = 0; j < counter.length; j++) {
+ sum += counter[j];
+ }
+ error = self._matchPattern(counter, pattern);
+ if (error < epsilon) {
+ bestMatch.error = error;
+ bestMatch.start = i - sum;
+ bestMatch.end = i;
+ return bestMatch;
+ }
+ if (tryHarder) {
+ for (j = 0; j < counter.length - 2; j++) {
+ counter[j] = counter[j + 2];
+ }
+ counter[counter.length - 2] = 0;
+ counter[counter.length - 1] = 0;
+ counterPos--;
+ } else {
+ return null;
+ }
+ } else {
+ counterPos++;
+ }
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
+ }
+ }
+ return null;
+};
+
+TwoOfFiveReader.prototype._findStart = function() {
+ var self = this,
+ leadingWhitespaceStart,
+ offset = self._nextSet(self._row),
+ startInfo,
+ narrowBarWidth = 1;
+
+ while (!startInfo) {
+ startInfo = self._findPattern(self.START_PATTERN, offset, false, true);
+ if (!startInfo) {
+ return null;
+ }
+ narrowBarWidth = Math.floor((startInfo.end - startInfo.start) / startPatternLength);
+ leadingWhitespaceStart = startInfo.start - narrowBarWidth * 5;
+ if (leadingWhitespaceStart >= 0) {
+ if (self._matchRange(leadingWhitespaceStart, startInfo.start, 0)) {
+ return startInfo;
+ }
+ }
+ offset = startInfo.end;
+ startInfo = null;
+ }
+};
+
+TwoOfFiveReader.prototype._verifyTrailingWhitespace = function(endInfo) {
+ var self = this,
+ trailingWhitespaceEnd;
+
+ trailingWhitespaceEnd = endInfo.end + ((endInfo.end - endInfo.start) / 2);
+ if (trailingWhitespaceEnd < self._row.length) {
+ if (self._matchRange(endInfo.end, trailingWhitespaceEnd, 0)) {
+ return endInfo;
+ }
+ }
+ return null;
+};
+
+TwoOfFiveReader.prototype._findEnd = function() {
+ var self = this,
+ endInfo,
+ tmp,
+ offset;
+
+ self._row.reverse();
+ offset = self._nextSet(self._row);
+ endInfo = self._findPattern(self.STOP_PATTERN, offset, false, true);
+ self._row.reverse();
+
+ if (endInfo === null) {
+ return null;
+ }
+
+ // reverse numbers
+ tmp = endInfo.start;
+ endInfo.start = self._row.length - endInfo.end;
+ endInfo.end = self._row.length - tmp;
+
+ return endInfo !== null ? self._verifyTrailingWhitespace(endInfo) : null;
+};
+
+TwoOfFiveReader.prototype._decodeCode = function(counter) {
+ var j,
+ self = this,
+ sum = 0,
+ normalized,
+ error,
+ epsilon = self.AVG_CODE_ERROR,
+ code,
+ bestMatch = {
+ error: Number.MAX_VALUE,
+ code: -1,
+ start: 0,
+ end: 0
+ };
+
+ for ( j = 0; j < counter.length; j++) {
+ sum += counter[j];
+ }
+ for (code = 0; code < self.CODE_PATTERN.length; code++) {
+ error = self._matchPattern(counter, self.CODE_PATTERN[code]);
+ if (error < bestMatch.error) {
+ bestMatch.code = code;
+ bestMatch.error = error;
+ }
+ }
+ if (bestMatch.error < epsilon) {
+ return bestMatch;
+ }
+};
+
+TwoOfFiveReader.prototype._decodePayload = function(counters, result, decodedCodes) {
+ var i,
+ self = this,
+ pos = 0,
+ counterLength = counters.length,
+ counter = [0, 0, 0, 0, 0],
+ code;
+
+ while (pos < counterLength) {
+ for (i = 0; i < 5; i++) {
+ counter[i] = counters[pos] * this.barSpaceRatio[0];
+ pos += 2;
+ }
+ code = self._decodeCode(counter);
+ if (!code) {
+ return null;
+ }
+ result.push(code.code + "");
+ decodedCodes.push(code);
+ }
+ return code;
+};
+
+TwoOfFiveReader.prototype._verifyCounterLength = function(counters) {
+ return (counters.length % 10 === 0);
+};
+
+TwoOfFiveReader.prototype._decode = function() {
+ var startInfo,
+ endInfo,
+ self = this,
+ code,
+ result = [],
+ decodedCodes = [],
+ counters;
+
+ startInfo = self._findStart();
+ if (!startInfo) {
+ return null;
+ }
+ decodedCodes.push(startInfo);
+
+ endInfo = self._findEnd();
+ if (!endInfo) {
+ return null;
+ }
+
+ counters = self._fillCounters(startInfo.end, endInfo.start, false);
+ if (!self._verifyCounterLength(counters)) {
+ return null;
+ }
+ code = self._decodePayload(counters, result, decodedCodes);
+ if (!code) {
+ return null;
+ }
+ if (result.length < 5) {
+ return null;
+ }
+
+ decodedCodes.push(endInfo);
+ return {
+ code: result.join(""),
+ start: startInfo.start,
+ end: endInfo.end,
+ startInfo: startInfo,
+ decodedCodes: decodedCodes
+ };
+};
+
+export default TwoOfFiveReader;
diff --git a/src/reader/barcode_reader.js b/src/reader/barcode_reader.js
index 67e8de4..74005f9 100644
--- a/src/reader/barcode_reader.js
+++ b/src/reader/barcode_reader.js
@@ -1,3 +1,5 @@
+import ArrayHelper from '../common/array_helper';
+
function BarcodeReader(config, supplements) {
this._row = [];
this.config = config || {};
@@ -195,6 +197,33 @@ BarcodeReader.prototype._fillCounters = function(offset, end, isWhite) {
return counters;
};
+BarcodeReader.prototype._toCounters = function(start, counter) {
+ var self = this,
+ numCounters = counter.length,
+ end = self._row.length,
+ isWhite = !self._row[start],
+ i,
+ counterPos = 0;
+
+ ArrayHelper.init(counter, 0);
+
+ for ( i = start; i < end; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ counterPos++;
+ if (counterPos === numCounters) {
+ break;
+ } else {
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
+ }
+ }
+ }
+
+ return counter;
+};
+
Object.defineProperty(BarcodeReader.prototype, "FORMAT", {
value: 'unknown',
writeable: false
diff --git a/src/reader/code_39_reader.js b/src/reader/code_39_reader.js
index 5b66b19..5981107 100644
--- a/src/reader/code_39_reader.js
+++ b/src/reader/code_39_reader.js
@@ -20,33 +20,6 @@ var properties = {
Code39Reader.prototype = Object.create(BarcodeReader.prototype, properties);
Code39Reader.prototype.constructor = Code39Reader;
-Code39Reader.prototype._toCounters = function(start, counter) {
- var self = this,
- numCounters = counter.length,
- end = self._row.length,
- isWhite = !self._row[start],
- i,
- counterPos = 0;
-
- ArrayHelper.init(counter, 0);
-
- for ( i = start; i < end; i++) {
- if (self._row[i] ^ isWhite) {
- counter[counterPos]++;
- } else {
- counterPos++;
- if (counterPos === numCounters) {
- break;
- } else {
- counter[counterPos] = 1;
- isWhite = !isWhite;
- }
- }
- }
-
- return counter;
-};
-
Code39Reader.prototype._decode = function() {
var self = this,
counters = [0, 0, 0, 0, 0, 0, 0, 0, 0],
diff --git a/src/reader/code_93_reader.js b/src/reader/code_93_reader.js
new file mode 100644
index 0000000..33c55d9
--- /dev/null
+++ b/src/reader/code_93_reader.js
@@ -0,0 +1,251 @@
+import BarcodeReader from './barcode_reader';
+import ArrayHelper from '../common/array_helper';
+
+function Code93Reader() {
+ BarcodeReader.call(this);
+}
+
+const ALPHABETH_STRING = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*";
+
+var properties = {
+ ALPHABETH_STRING: {value: ALPHABETH_STRING},
+ ALPHABET: {value: ALPHABETH_STRING.split('').map(char => char.charCodeAt(0))},
+ CHARACTER_ENCODINGS: {value: [
+ 0x114, 0x148, 0x144, 0x142, 0x128, 0x124, 0x122, 0x150, 0x112, 0x10A,
+ 0x1A8, 0x1A4, 0x1A2, 0x194, 0x192, 0x18A, 0x168, 0x164, 0x162, 0x134,
+ 0x11A, 0x158, 0x14C, 0x146, 0x12C, 0x116, 0x1B4, 0x1B2, 0x1AC, 0x1A6,
+ 0x196, 0x19A, 0x16C, 0x166, 0x136, 0x13A, 0x12E, 0x1D4, 0x1D2, 0x1CA,
+ 0x16E, 0x176, 0x1AE, 0x126, 0x1DA, 0x1D6, 0x132, 0x15E
+ ]},
+ ASTERISK: {value: 0x15E},
+ FORMAT: {value: "code_93", writeable: false}
+};
+
+Code93Reader.prototype = Object.create(BarcodeReader.prototype, properties);
+Code93Reader.prototype.constructor = Code93Reader;
+
+Code93Reader.prototype._decode = function() {
+ var self = this,
+ counters = [0, 0, 0, 0, 0, 0],
+ result = [],
+ start = self._findStart(),
+ decodedChar,
+ lastStart,
+ pattern,
+ nextStart;
+
+ if (!start) {
+ return null;
+ }
+ nextStart = self._nextSet(self._row, start.end);
+
+ do {
+ counters = self._toCounters(nextStart, counters);
+ pattern = self._toPattern(counters);
+ if (pattern < 0) {
+ return null;
+ }
+ decodedChar = self._patternToChar(pattern);
+ if (decodedChar < 0){
+ return null;
+ }
+ result.push(decodedChar);
+ lastStart = nextStart;
+ nextStart += ArrayHelper.sum(counters);
+ nextStart = self._nextSet(self._row, nextStart);
+ } while (decodedChar !== '*');
+ result.pop();
+
+ if (!result.length) {
+ return null;
+ }
+
+ if (!self._verifyEnd(lastStart, nextStart, counters)) {
+ return null;
+ }
+
+ if (!self._verifyChecksums(result)) {
+ return null;
+ }
+
+ result = result.slice(0, result.length - 2);
+ if ((result = self._decodeExtended(result)) === null) {
+ return null;
+ };
+
+ return {
+ code: result.join(""),
+ start: start.start,
+ end: nextStart,
+ startInfo: start,
+ decodedCodes: result
+ };
+};
+
+Code93Reader.prototype._verifyEnd = function(lastStart, nextStart) {
+ if (lastStart === nextStart || !this._row[nextStart]) {
+ return false;
+ }
+ return true;
+};
+
+Code93Reader.prototype._patternToChar = function(pattern) {
+ var i,
+ self = this;
+
+ for (i = 0; i < self.CHARACTER_ENCODINGS.length; i++) {
+ if (self.CHARACTER_ENCODINGS[i] === pattern) {
+ return String.fromCharCode(self.ALPHABET[i]);
+ }
+ }
+ return -1;
+};
+
+Code93Reader.prototype._toPattern = function(counters) {
+ const numCounters = counters.length;
+ let pattern = 0;
+ let sum = 0;
+ for (let i = 0; i < numCounters; i++) {
+ sum += counters[i];
+ }
+
+ for (let i = 0; i < numCounters; i++) {
+ let normalized = Math.round(counters[i] * 9 / sum);
+ if (normalized < 1 || normalized > 4) {
+ return -1;
+ }
+ if ((i & 1) === 0) {
+ for (let j = 0; j < normalized; j++) {
+ pattern = (pattern << 1) | 1;
+ }
+ } else {
+ pattern <<= normalized;
+ }
+ }
+
+ return pattern;
+};
+
+Code93Reader.prototype._findStart = function() {
+ var self = this,
+ offset = self._nextSet(self._row),
+ patternStart = offset,
+ counter = [0, 0, 0, 0, 0, 0],
+ counterPos = 0,
+ isWhite = false,
+ i,
+ j,
+ whiteSpaceMustStart;
+
+ for ( i = offset; i < self._row.length; i++) {
+ if (self._row[i] ^ isWhite) {
+ counter[counterPos]++;
+ } else {
+ if (counterPos === counter.length - 1) {
+ // find start pattern
+ if (self._toPattern(counter) === self.ASTERISK) {
+ whiteSpaceMustStart = Math.floor(Math.max(0, patternStart - ((i - patternStart) / 4)));
+ if (self._matchRange(whiteSpaceMustStart, patternStart, 0)) {
+ return {
+ start: patternStart,
+ end: i
+ };
+ }
+ }
+
+ patternStart += counter[0] + counter[1];
+ for ( j = 0; j < 4; j++) {
+ counter[j] = counter[j + 2];
+ }
+ counter[4] = 0;
+ counter[5] = 0;
+ counterPos--;
+ } else {
+ counterPos++;
+ }
+ counter[counterPos] = 1;
+ isWhite = !isWhite;
+ }
+ }
+ return null;
+};
+
+Code93Reader.prototype._decodeExtended = function(charArray) {
+ const length = charArray.length;
+ const result = [];
+ for (let i = 0; i < length; i++) {
+ const char = charArray[i];
+ if (char >= 'a' && char <= 'd') {
+ if (i > (length - 2)) {
+ return null;
+ }
+ const nextChar = charArray[++i];
+ const nextCharCode = nextChar.charCodeAt(0);
+ let decodedChar;
+ switch (char) {
+ case 'a':
+ if (nextChar >= 'A' && nextChar <= 'Z') {
+ decodedChar = String.fromCharCode(nextCharCode - 64);
+ } else {
+ return null;
+ }
+ break;
+ case 'b':
+ if (nextChar >= 'A' && nextChar <= 'E') {
+ decodedChar = String.fromCharCode(nextCharCode - 38);
+ } else if (nextChar >= 'F' && nextChar <= 'J') {
+ decodedChar = String.fromCharCode(nextCharCode - 11);
+ } else if (nextChar >= 'K' && nextChar <= 'O') {
+ decodedChar = String.fromCharCode(nextCharCode + 16);
+ } else if (nextChar >= 'P' && nextChar <= 'S') {
+ decodedChar = String.fromCharCode(nextCharCode + 43);
+ } else if (nextChar >= 'T' && nextChar <= 'Z') {
+ decodedChar = String.fromCharCode(127);
+ } else {
+ return null;
+ }
+ break;
+ case 'c':
+ if (nextChar >= 'A' && nextChar <= 'O') {
+ decodedChar = String.fromCharCode(nextCharCode - 32);
+ } else if (nextChar === 'Z') {
+ decodedChar = ':';
+ } else {
+ return null;
+ }
+ break;
+ case 'd':
+ if (nextChar >= 'A' && nextChar <= 'Z') {
+ decodedChar = String.fromCharCode(nextCharCode + 32);
+ } else {
+ return null;
+ }
+ break;
+ }
+ result.push(decodedChar);
+ } else {
+ result.push(char);
+ }
+ }
+ return result;
+};
+
+Code93Reader.prototype._verifyChecksums = function(charArray) {
+ return this._matchCheckChar(charArray, charArray.length - 2, 20)
+ && this._matchCheckChar(charArray, charArray.length - 1, 15);
+};
+
+Code93Reader.prototype._matchCheckChar = function(charArray, index, maxWeight) {
+ const arrayToCheck = charArray.slice(0, index);
+ const length = arrayToCheck.length;
+ const weightedSums = arrayToCheck.reduce((sum, char, i) => {
+ const weight = (((i * -1) + (length - 1)) % maxWeight) + 1;
+ const value = this.ALPHABET.indexOf(char.charCodeAt(0));
+ return sum + (weight * value);
+ }, 0);
+
+ const checkChar = this.ALPHABET[(weightedSums % 47)];
+ return checkChar === charArray[index].charCodeAt(0);
+};
+
+export default Code93Reader;
diff --git a/test/fixtures/2of5/image-001.jpg b/test/fixtures/2of5/image-001.jpg
new file mode 100644
index 0000000..77744b9
Binary files /dev/null and b/test/fixtures/2of5/image-001.jpg differ
diff --git a/test/fixtures/2of5/image-002.jpg b/test/fixtures/2of5/image-002.jpg
new file mode 100644
index 0000000..eea372a
Binary files /dev/null and b/test/fixtures/2of5/image-002.jpg differ
diff --git a/test/fixtures/2of5/image-003.jpg b/test/fixtures/2of5/image-003.jpg
new file mode 100644
index 0000000..bd60e84
Binary files /dev/null and b/test/fixtures/2of5/image-003.jpg differ
diff --git a/test/fixtures/2of5/image-004.jpg b/test/fixtures/2of5/image-004.jpg
new file mode 100644
index 0000000..b7e58fe
Binary files /dev/null and b/test/fixtures/2of5/image-004.jpg differ
diff --git a/test/fixtures/2of5/image-005.jpg b/test/fixtures/2of5/image-005.jpg
new file mode 100644
index 0000000..06e379e
Binary files /dev/null and b/test/fixtures/2of5/image-005.jpg differ
diff --git a/test/fixtures/2of5/image-006.jpg b/test/fixtures/2of5/image-006.jpg
new file mode 100644
index 0000000..74f4ba5
Binary files /dev/null and b/test/fixtures/2of5/image-006.jpg differ
diff --git a/test/fixtures/2of5/image-007.jpg b/test/fixtures/2of5/image-007.jpg
new file mode 100644
index 0000000..70677d1
Binary files /dev/null and b/test/fixtures/2of5/image-007.jpg differ
diff --git a/test/fixtures/2of5/image-008.jpg b/test/fixtures/2of5/image-008.jpg
new file mode 100644
index 0000000..5eecc3f
Binary files /dev/null and b/test/fixtures/2of5/image-008.jpg differ
diff --git a/test/fixtures/2of5/image-009.jpg b/test/fixtures/2of5/image-009.jpg
new file mode 100644
index 0000000..c7c88cb
Binary files /dev/null and b/test/fixtures/2of5/image-009.jpg differ
diff --git a/test/fixtures/2of5/image-010.jpg b/test/fixtures/2of5/image-010.jpg
new file mode 100644
index 0000000..d419d71
Binary files /dev/null and b/test/fixtures/2of5/image-010.jpg differ
diff --git a/test/fixtures/2of5/image-012.jpg b/test/fixtures/2of5/image-012.jpg
new file mode 100644
index 0000000..f704037
Binary files /dev/null and b/test/fixtures/2of5/image-012.jpg differ
diff --git a/test/fixtures/2of5/image-015.jpg b/test/fixtures/2of5/image-015.jpg
new file mode 100644
index 0000000..496f6b2
Binary files /dev/null and b/test/fixtures/2of5/image-015.jpg differ
diff --git a/test/fixtures/2of5/image-016.jpg b/test/fixtures/2of5/image-016.jpg
new file mode 100644
index 0000000..c30e78a
Binary files /dev/null and b/test/fixtures/2of5/image-016.jpg differ
diff --git a/test/fixtures/2of5/image-017.jpg b/test/fixtures/2of5/image-017.jpg
new file mode 100644
index 0000000..9ce5d9f
Binary files /dev/null and b/test/fixtures/2of5/image-017.jpg differ
diff --git a/test/fixtures/code_93/image-001.jpg b/test/fixtures/code_93/image-001.jpg
new file mode 100644
index 0000000..795196b
Binary files /dev/null and b/test/fixtures/code_93/image-001.jpg differ
diff --git a/test/fixtures/code_93/image-002.jpg b/test/fixtures/code_93/image-002.jpg
new file mode 100644
index 0000000..5bad400
Binary files /dev/null and b/test/fixtures/code_93/image-002.jpg differ
diff --git a/test/fixtures/code_93/image-003.jpg b/test/fixtures/code_93/image-003.jpg
new file mode 100644
index 0000000..2a523e6
Binary files /dev/null and b/test/fixtures/code_93/image-003.jpg differ
diff --git a/test/fixtures/code_93/image-004.jpg b/test/fixtures/code_93/image-004.jpg
new file mode 100644
index 0000000..39758ec
Binary files /dev/null and b/test/fixtures/code_93/image-004.jpg differ
diff --git a/test/fixtures/code_93/image-005.jpg b/test/fixtures/code_93/image-005.jpg
new file mode 100644
index 0000000..227f6fe
Binary files /dev/null and b/test/fixtures/code_93/image-005.jpg differ
diff --git a/test/fixtures/code_93/image-006.jpg b/test/fixtures/code_93/image-006.jpg
new file mode 100644
index 0000000..f4622bc
Binary files /dev/null and b/test/fixtures/code_93/image-006.jpg differ
diff --git a/test/fixtures/code_93/image-007.jpg b/test/fixtures/code_93/image-007.jpg
new file mode 100644
index 0000000..6bf7d02
Binary files /dev/null and b/test/fixtures/code_93/image-007.jpg differ
diff --git a/test/fixtures/code_93/image-008.jpg b/test/fixtures/code_93/image-008.jpg
new file mode 100644
index 0000000..21021b6
Binary files /dev/null and b/test/fixtures/code_93/image-008.jpg differ
diff --git a/test/fixtures/code_93/image-009.jpg b/test/fixtures/code_93/image-009.jpg
new file mode 100644
index 0000000..1250685
Binary files /dev/null and b/test/fixtures/code_93/image-009.jpg differ
diff --git a/test/fixtures/code_93/image-010.jpg b/test/fixtures/code_93/image-010.jpg
new file mode 100644
index 0000000..8f6a20e
Binary files /dev/null and b/test/fixtures/code_93/image-010.jpg differ
diff --git a/test/integration/integration.spec.js b/test/integration/integration.spec.js
index 4ff125d..8e0cf0b 100644
--- a/test/integration/integration.spec.js
+++ b/test/integration/integration.spec.js
@@ -304,4 +304,78 @@ describe('decodeSingle', function () {
});
_runTestSet(testSet, config);
});
+
+ describe("2of5", function() {
+ var config = config = {
+ inputStream: {
+ size: 800,
+ singleChannel: false
+ },
+ locator: {
+ patchSize: "medium",
+ halfSample: true
+ },
+ numOfWorkers: 0,
+ decoder: {
+ readers: ["2of5_reader"]
+ },
+ locate: true,
+ src: null
+ },
+ testSet = [
+ {"name": "image-001.jpg", "result": "9577149002"},
+ {"name": "image-002.jpg", "result": "9577149002"},
+ {"name": "image-003.jpg", "result": "5776158811"},
+ {"name": "image-004.jpg", "result": "0463381455"},
+ {"name": "image-005.jpg", "result": "3261594101"},
+ {"name": "image-006.jpg", "result": "3261594101"},
+ {"name": "image-007.jpg", "result": "3261594101"},
+ {"name": "image-008.jpg", "result": "6730705801"},
+ {"name": "image-009.jpg", "result": "5776158811"},
+ {"name": "image-010.jpg", "result": "5776158811"}
+ ];
+
+ testSet.forEach(function(sample) {
+ sample.format = "2of5";
+ });
+
+ _runTestSet(testSet, config);
+ });
+
+ describe("code_93", function() {
+ var config = config = {
+ inputStream: {
+ size: 800,
+ singleChannel: false
+ },
+ locator: {
+ patchSize: "large",
+ halfSample: true
+ },
+ numOfWorkers: 0,
+ decoder: {
+ readers: ["code_93_reader"]
+ },
+ locate: true,
+ src: null
+ },
+ testSet = [
+ {"name": "image-001.jpg", "result": "WIWV8ETQZ1"},
+ {"name": "image-002.jpg", "result": "EH3C-%GU23RK3"},
+ {"name": "image-003.jpg", "result": "O308SIHQOXN5SA/PJ"},
+ {"name": "image-004.jpg", "result": "DG7Q$TV8JQ/EN"},
+ {"name": "image-005.jpg", "result": "DG7Q$TV8JQ/EN"},
+ {"name": "image-006.jpg", "result": "O308SIHQOXN5SA/PJ"},
+ {"name": "image-007.jpg", "result": "VOFD1DB5A.1F6QU"},
+ {"name": "image-008.jpg", "result": "WIWV8ETQZ1"},
+ {"name": "image-009.jpg", "result": "4SO64P4X8 U4YUU1T-"},
+ {"name": "image-010.jpg", "result": "4SO64P4X8 U4YUU1T-"}
+ ];
+
+ testSet.forEach(function(sample) {
+ sample.format = "code_93";
+ });
+
+ _runTestSet(testSet, config);
+ });
});
diff --git a/test/spec/camera_access.spec.js b/test/spec/camera_access.spec.js
index 18bf11b..54d5f00 100644
--- a/test/spec/camera_access.spec.js
+++ b/test/spec/camera_access.spec.js
@@ -153,21 +153,6 @@ describe("camera_access", () => {
done();
});
});
-
- it("should set deviceId if facingMode is set to environment", (done) => {
- setDevices([{deviceId: "front", kind: "videoinput", label: "front Facing"},
- {deviceId: "back", label: "back Facing", kind: "videoinput"}]);
- const givenConstraints = {width: 180, facingMode: "environment"};
- return pickConstraints(givenConstraints).then((actualConstraints) => {
- expect(actualConstraints.video).to.deep.equal({width: 180, deviceId: "back"});
- done();
- })
- .catch((err) => {
- console.log(err);
- expect(err).to.equal(null);
- done();
- });
- });
});
});
});